X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2Flfs.h;h=8fc048948875d13786956de0ed2f00b82444626f;hb=ca885e18959ced4df7084ccf262c7b5df5848bdb;hp=59b9a5e108cf743322369a0c1edf2f841fe5b2f5;hpb=f95c936825d0d4150d9ee2484c6b50a1596bb8dc;p=libucw.git diff --git a/lib/lfs.h b/lib/lfs.h index 59b9a5e1..8fc04894 100644 --- a/lib/lfs.h +++ b/lib/lfs.h @@ -1,53 +1,37 @@ /* * 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 - -#define SHERLOCK_O_LARGEFILE O_LARGEFILE - -#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 SHERLOCK_O_LARGEFILE 0 +#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 */ + +#define SHERLOCK_HAVE_PREAD + #endif /* !_SHERLOCK_LFS_H */