mirror of the now-defunct rocklinux.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

457 lines
9.7 KiB

/* ROCK Linux Wrapper for getting a list of created files
*
* --- ROCK-COPYRIGHT-NOTE-BEGIN ---
*
* This copyright note is auto-generated by ./scripts/Create-CopyPatch.
* Please add additional copyright information _after_ the line containing
* the ROCK-COPYRIGHT-NOTE-END tag. Otherwise it might get removed by
* the ./scripts/Create-CopyPatch script. Do not edit this copyright text!
*
* ROCK Linux: rock-src/misc/tools-source/fl_wrapper_open.c
* ROCK Linux is Copyright (C) 1998 - 2006 Clifford Wolf
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. A copy of the GNU General Public
* License can be found at Documentation/COPYING.
*
* Many people helped and are helping developing ROCK Linux. Please
* have a look at http://www.rocklinux.org/ and the Documentation/TEAM
* file for details.
*
* --- ROCK-COPYRIGHT-NOTE-END ---
*/
extern int open(const char* f, int a, ...);
int (*orig_open)(const char* f, int a, ...) = 0;
int open(const char* f, int a, ...)
{
struct status_t status;
int old_errno=errno;
int rc;
handle_file_access_before("open", f, &status);
if (!orig_open) orig_open = get_dl_symbol("open");
errno=old_errno;
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original open(\"%s\", ...) at %p (wrapper is at %p).\n",
getpid(), f, orig_open, open);
# endif
if (a & O_CREAT)
{
va_list ap;
mode_t b = 0;
va_start(ap, a);
b = va_arg(ap, mode_t);
va_end(ap);
rc = orig_open(f, a, b);
}
else
rc = orig_open(f, a);
old_errno=errno;
# if FD_TRACKER == 1
if (rc != -1)
{
char *buf = 0;
int free_buf = 0;
if (f[0] != '/')
{
char *buf2 = get_current_dir_name();
if (asprintf(&buf,"%s%s%s", buf2,
strcmp(buf2,"/") ? "/" : "", f) != -1)
{
f = buf; free_buf = 1;
}
free(buf2);
}
register_fd(rc, f, &status);
if (free_buf) free(buf);
}
# else
handle_file_access_after("open", f, &status);
# endif
errno=old_errno;
return rc;
}
extern int open64(const char* f, int a, ...);
int (*orig_open64)(const char* f, int a, ...) = 0;
int open64(const char* f, int a, ...)
{
struct status_t status;
int old_errno=errno;
int rc;
handle_file_access_before("open64", f, &status);
if (!orig_open64) orig_open64 = get_dl_symbol("open64");
errno=old_errno;
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original open64(\"%s\", ...) at %p (wrapper is at %p).\n",
getpid(), f, orig_open64, open64);
# endif
if (a & O_CREAT)
{
va_list ap;
mode_t b = 0;
va_start(ap, a);
b = va_arg(ap, mode_t);
va_end(ap);
rc = orig_open64(f, a, b);
}
else
rc = orig_open64(f, a);
old_errno=errno;
# if FD_TRACKER == 1
if (rc != -1)
{
char *buf = 0;
int free_buf = 0;
if (f[0] != '/')
{
char *buf2 = get_current_dir_name();
if (asprintf(&buf,"%s%s%s", buf2,
strcmp(buf2,"/") ? "/" : "", f) != -1)
{
f = buf; free_buf = 1;
}
free(buf2);
}
register_fd(rc, f, &status);
if (free_buf) free(buf);
}
# else
handle_file_access_after("open64", f, &status);
# endif
errno=old_errno;
return rc;
}
extern int creat(const char* f, mode_t m);
int (*orig_creat)(const char* f, mode_t m) = 0;
int creat(const char* f, mode_t m)
{
struct status_t status;
int old_errno=errno;
int rc;
handle_file_access_before("creat", f, &status);
if (!orig_creat) orig_creat = get_dl_symbol("creat");
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original creat(\"%s\", ...) at %p (wrapper is at %p).\n",
getpid(), f, orig_creat, creat);
# endif
errno=old_errno;
rc = orig_creat(f, m);
old_errno=errno;
# if FD_TRACKER == 1
if (rc != -1)
{
char *buf = 0;
int free_buf = 0;
if (f[0] != '/')
{
char *buf2 = get_current_dir_name();
if (asprintf(&buf,"%s%s%s", buf2,
strcmp(buf2,"/") ? "/" : "", f) != -1)
{
f = buf; free_buf = 1;
}
free(buf2);
}
register_fd(rc, f, &status);
if (free_buf) free(buf);
}
# else
handle_file_access_after("creat", f, &status);
# endif
errno=old_errno;
return rc;
}
extern int creat64(const char* f, mode_t m);
int (*orig_creat64)(const char* f, mode_t m) = 0;
int creat64(const char* f, mode_t m)
{
struct status_t status;
int old_errno=errno;
int rc;
handle_file_access_before("creat64", f, &status);
if (!orig_creat64) orig_creat64 = get_dl_symbol("creat64");
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original creat64(%s, ...) at %p (wrapper is at %p).\n",
getpid(), f, orig_creat64, creat64);
# endif
errno=old_errno;
rc = orig_creat64(f, m);
old_errno=errno;
# if FD_TRACKER == 1
if (rc != -1)
{
char *buf = 0;
int free_buf = 0;
if (f[0] != '/')
{
char *buf2 = get_current_dir_name();
if (asprintf(&buf,"%s%s%s", buf2,
strcmp(buf2,"/") ? "/" : "", f) != -1)
{
f = buf; free_buf = 1;
}
free(buf2);
}
register_fd(rc, f, &status);
if (free_buf) free(buf);
}
# else
handle_file_access_after("creat64", f, &status);
# endif
errno=old_errno;
return rc;
}
extern FILE* fopen(const char* f, const char* g);
FILE* (*orig_fopen)(const char* f, const char* g) = 0;
FILE* fopen(const char* f, const char* g)
{
struct status_t status;
int old_errno=errno;
FILE* rc;
handle_file_access_before("fopen", f, &status);
if (!orig_fopen) orig_fopen = get_dl_symbol("fopen");
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original fopen() at %p (wrapper is at %p).\n",
getpid(), orig_fopen, fopen);
# endif
errno=old_errno;
rc = orig_fopen(f, g);
old_errno=errno;
# if FD_TRACKER == 1
if (rc != 0)
{
char *buf = 0;
int free_buf = 0;
if (f[0] != '/')
{
char *buf2 = get_current_dir_name();
if (asprintf(&buf,"%s%s%s", buf2,
strcmp(buf2,"/") ? "/" : "", f) != -1)
{
f = buf; free_buf = 1;
}
free(buf2);
}
register_fd(fileno(rc), f, &status);
if (free_buf) free(buf);
}
# else
handle_file_access_after("fopen", f, &status);
# endif
errno=old_errno;
return rc;
}
extern FILE* fopen64(const char* f, const char* g);
FILE* (*orig_fopen64)(const char* f, const char* g) = 0;
FILE* fopen64(const char* f, const char* g)
{
struct status_t status;
int old_errno=errno;
FILE* rc;
handle_file_access_before("fopen64", f, &status);
if (!orig_fopen64) orig_fopen64 = get_dl_symbol("fopen64");
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original fopen64() at %p (wrapper is at %p).\n",
getpid(), orig_fopen64, fopen64);
# endif
errno=old_errno;
rc = orig_fopen64(f, g);
old_errno=errno;
# if FD_TRACKER == 1
if (rc != 0)
{
char *buf = 0;
int free_buf = 0;
if (f[0] != '/')
{
char *buf2 = get_current_dir_name();
if (asprintf(&buf,"%s%s%s", buf2,
strcmp(buf2,"/") ? "/" : "", f) != -1)
{
f = buf; free_buf = 1;
}
free(buf2);
}
register_fd(fileno(rc), f, &status);
if (free_buf) free(buf);
}
# else
handle_file_access_after("fopen64", f, &status);
# endif
errno=old_errno;
return rc;
}
extern int dup(int fd);
int (*orig_dup)(int fd) = 0;
int dup(int fd)
{
int old_errno = errno;
int rc;
if (!orig_dup) orig_dup = get_dl_symbol("dup");
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original dup(%d) at %p (wrapper is at %p).\n",
getpid(), fd, orig_dup, dup);
# endif
errno=old_errno;
rc = orig_dup(fd);
old_errno = errno;
# if FD_TRACKER == 1
if (rc != -1)
{
struct pid_reg *pid = *find_pid(getpid());
if (pid)
{
struct fd_reg *oldfd = *find_fd(pid, fd);
if (oldfd) register_fd(rc, oldfd->filename, &oldfd->status);
}
}
# endif
errno=old_errno;
return rc;
}
extern int dup2(int fd, int fd2);
int (*orig_dup2)(int fd, int fd2) = 0;
int dup2(int oldfd, int newfd)
{
int old_errno = errno;
int rc;
if (!orig_dup2) orig_dup2 = get_dl_symbol("dup2");
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original dup2(%d, %d) at %p (wrapper is at %p).\n",
getpid(), oldfd, newfd, orig_dup2, dup2);
# endif
errno=old_errno;
rc = orig_dup2(oldfd, newfd);
old_errno = errno;
# if FD_TRACKER == 1
if (rc != -1)
{
struct pid_reg *pid = *find_pid(getpid());
if (pid)
{
struct fd_reg *fd = *find_fd(pid, newfd);
if (fd && oldfd != newfd)
{
handle_file_access_after("dup2", fd->filename, &fd->status);
deregister_fd(newfd);
}
fd = *find_fd(pid, oldfd);
if (fd) register_fd(rc, fd->filename, &fd->status);
}
}
# endif
errno=old_errno;
return rc;
}
extern int fcntl(int fd, int cmd, ...);
int (*orig_fcntl)(int fd, int cmd, ...) = 0;
int fcntl(int fd, int cmd, ...)
{
int old_errno = errno;
int rc;
int fd2 = -1;
if (!orig_fcntl) orig_fcntl = get_dl_symbol("fcntl");
# if DEBUG == 1
if (debug) fprintf(stderr, "fl_wrapper.so debug [%d]: going to run original fcntl(%d, %d, ...) at %p (wrapper is at %p).\n",
getpid(), fd, cmd, orig_fcntl, fcntl);
# endif
errno=old_errno;
if (cmd & F_GETLK || cmd & F_SETLK || cmd & F_SETLKW)
{
va_list ap;
struct flock *b = 0;
va_start(ap, cmd);
b = va_arg(ap, struct flock*);
va_end(ap);
rc = orig_fcntl(fd, cmd, b);
} else {
va_list ap;
long b = 0;
va_start(ap, cmd);
b = va_arg(ap, long);
va_end(ap);
rc = orig_fcntl(fd, cmd, b);
fd2 = (int) b;
}
old_errno = errno;
# if FD_TRACKER == 1
if (rc != -1 && cmd == F_DUPFD)
{
struct pid_reg *pid = *find_pid(getpid());
if (pid)
{
struct fd_reg *oldfd = *find_fd(pid, fd);
if (oldfd) register_fd(rc, oldfd->filename, &oldfd->status);
}
}
# endif
errno=old_errno;
return rc;
}