X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2Flfs.h;h=5802e1a4665eb60ae7ca6750c510fb0a5ac74c38;hb=c982330d65a5ff8930682b250612ea135db2d4f6;hp=ab9d8e7188de3ddec612196278fd76246a674f00;hpb=824c295c7aebba96d28f8aaa9da317eca3e2225f;p=libucw.git diff --git a/lib/lfs.h b/lib/lfs.h index ab9d8e71..5802e1a4 100644 --- a/lib/lfs.h +++ b/lib/lfs.h @@ -1,50 +1,35 @@ /* * Sherlock Library -- Large File Support * - * (c) 1999 Martin Mares, + * (c) 1999--2002 Martin Mares */ #ifndef _SHERLOCK_LFS_H #define _SHERLOCK_LFS_H -#ifdef SHERLOCK_CONFIG_LFS - -#ifndef O_LARGEFILE -#if defined(__linux__) && defined(__i386__) -#define O_LARGEFILE 0100000 -#else -#error O_LARGEFILE unknown -#endif -#endif - -#if 0 - -/* A "do it yourself" solution */ - -#include -#include +#include +#include -_syscall5(int, _llseek, int, fd, int, hi, int, lo, loff_t *, result, int, whence); - -extern inline loff_t sh_seek(int fd, sh_off_t pos, int whence) -{ - loff_t result; - int err; - - err = _llseek(fd, pos >> 32, pos, &result, whence); - return (err < 0) ? err : result; -} -#else - -/* Touching hidden places in glibc */ -extern loff_t llseek(int fd, loff_t pos, int whence); -#define sh_seek(f,o,w) llseek(f,o,w) +#ifdef SHERLOCK_CONFIG_LFS -#endif +#define sh_open open64 +#define sh_seek lseek64 +#define sh_pread pread64 +#define sh_pwrite pwrite64 +#define sh_ftruncate ftruncate64 +#define sh_mmap(a,l,p,f,d,o) mmap64(a,l,p,f,d,o) +#define sh_pread pread64 +#define sh_pwrite pwrite64 #else /* !SHERLOCK_CONFIG_LFS */ +#define sh_open open #define sh_seek(f,o,w) lseek(f,o,w) +#define sh_ftruncate(f,o) ftruncate(f,o) +#define sh_mmap(a,l,p,f,d,o) mmap(a,l,p,f,d,o) +#define sh_pread pread +#define sh_pwrite pwrite #endif /* !SHERLOCK_CONFIG_LFS */ + #endif /* !_SHERLOCK_LFS_H */