+2000-08-15 Ulrich Drepper <drepper@redhat.com>
+
+ * include/link.h: Undo last patches. Hurd now had stat64.
+ * elf/Makefile: Likewise.
+ * elf/dl-load.c: Likewise.
+ * elf/dl-misc.c: Likewise.
+ * elf/dl-profile.c: Likewise.
+ * sysdeps/generic/sysd-link.h: Removed.
+ * sysdeps/unix/sysv/linux/sysd-link.h: Removed.
+
+ * rt/aio_notify.c (notify_func_wrapper): Wrapper function to call
+ thread event callback function.
+ (__aio_notify_only): Use function above.
+ Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
+
2000-08-16 Mark Kettenis <kettenis@gnu.org>
* sysdeps/mach/hurd/lseek64.c: New file.
vismain.c vismod1.c vismod2.c vismod3.c \
constload2.c constload3.c filtmod1.c filtmod2.c \
nodlopenmod.c nodelete.c nodelmod1.c nodelmod2.c \
- nodelmod3.c nodelmod4.c nodlopen.c \
- sysd-link.h
+ nodelmod3.c nodelmod4.c nodlopen.c
include ../Makeconfig
int type;
char *readbuf;
ssize_t readlength;
- struct elf_stat st;
+ struct stat64 st;
/* Get file information. */
- if (elf_fxstat (_STAT_VER, fd, &st) < 0)
+ if (__fxstat64 (_STAT_VER, fd, &st) < 0)
LOSE (errno, N_("cannot stat shared object"));
/* Look again to see if the real name matched another already loaded. */
{
/* We failed to open machine dependent library. Let's
test whether there is any directory at all. */
- struct elf_stat st;
+ struct stat64 st;
buf[buflen - namelen - 1] = '\0';
- if (elf_xstat (_STAT_VER, buf, &st) != 0
+ if (__xstat64 (_STAT_VER, buf, &st) != 0
|| ! S_ISDIR (st.st_mode))
/* The directory does not exist or it is no directory. */
this_dir->status[cnt] = nonexisting;
/* This is an extra security effort to make sure nobody can
preload broken shared objects which are in the trusted
directories and so exploit the bugs. */
- struct elf_stat st;
+ struct stat64 st;
- if (elf_fxstat (_STAT_VER, fd, &st) != 0
+ if (__fxstat64 (_STAT_VER, fd, &st) != 0
|| (st.st_mode & S_ISUID) == 0)
{
/* The shared object cannot be tested for being SUID
_dl_sysdep_read_whole_file (const char *file, size_t *sizep, int prot)
{
void *result;
- struct elf_stat st;
+ struct stat64 st;
int fd = __open (file, O_RDONLY);
if (fd < 0)
return NULL;
- if (elf_fxstat (_STAT_VER, fd, &st) < 0
+ if (__fxstat64 (_STAT_VER, fd, &st) < 0
/* No need to map the file if it is empty. */
|| st.st_size == 0)
result = NULL;
{
char *filename;
int fd;
- struct elf_stat st;
+ struct stat64 st;
const ElfW(Phdr) *ph;
ElfW(Addr) mapstart = ~((ElfW(Addr)) 0);
ElfW(Addr) mapend = 0;
return;
}
- if (elf_fxstat (_STAT_VER, fd, &st) < 0 || !S_ISREG (st.st_mode))
+ if (__fxstat64 (_STAT_VER, fd, &st) < 0 || !S_ISREG (st.st_mode))
{
/* Not stat'able or not a regular file => don't use it. */
char buf[400];
#include <bits/elfclass.h> /* Defines __ELF_NATIVE_CLASS. */
-/* Get some system specific definitions. */
-#include <sysd-link.h>
-
/* Rendezvous structure used by the run-time dynamic linker to communicate
details of shared object loading to the debugger. If the executable's
dynamic section has a DT_DEBUG element, the run-time linker sets that
/* This information is kept to check for sure whether a shared
object is the same as one already loaded. */
dev_t l_dev;
- elf_ino_t l_ino;
+ ino64_t l_ino;
/* Collected information about own RUNPATH directories. */
struct r_search_path_elem **l_runpath_dirs;
+++ /dev/null
-/* In general we don't have stat64 available. */
-#define elf_stat stat
-#define elf_fxstat __fxstat
-#define elf_xstat __xstat
-#define elf_ino_t ino_t
+++ /dev/null
-/* On Linux we have stat64 available. */
-#define elf_stat stat64
-#define elf_fxstat __fxstat64
-#define elf_xstat __xstat64
-#define elf_ino_t ino64_t