lseek.c 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. /* vi: set sw=4 ts=4: */
  2. /*
  3. * lseek() for uClibc
  4. *
  5. * Copyright (C) 2000-2006 Erik Andersen <andersen@uclibc.org>
  6. *
  7. * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball.
  8. */
  9. #include <sys/syscall.h>
  10. #include <unistd.h>
  11. #include <cancel.h>
  12. #ifdef __NR_lseek
  13. # define __NR___lseek_nocancel __NR_lseek
  14. _syscall3(off_t, __NC(lseek), int, fd, off_t, offset, int, whence)
  15. #elif !defined __NR_lseek && defined __NR_llseek
  16. #include <endian.h>
  17. off_t __NC(lseek)(int fd, off_t offset, int whence)
  18. {
  19. #if __WORDSIZE == 32
  20. __off64_t result;
  21. __off_t high = 0;
  22. return INLINE_SYSCALL(llseek, 5, fd, high, offset, &result, whence) ?: result;
  23. #else
  24. return lseek64(fd, offset, whence);
  25. #endif
  26. /* No need to handle __WORDSIZE == 64 as such a kernel won't define __NR_llseek */
  27. }
  28. #else
  29. # include <errno.h>
  30. off_t __NC(lseek)(int fd, off_t offset attribute_unused, int whence)
  31. {
  32. if (fd < 0) {
  33. __set_errno(EBADF);
  34. return -1;
  35. }
  36. switch(whence) {
  37. case SEEK_SET:
  38. case SEEK_CUR:
  39. case SEEK_END:
  40. break;
  41. default:
  42. __set_errno(EINVAL);
  43. return -1;
  44. }
  45. __set_errno(ENOSYS);
  46. return -1;
  47. }
  48. #endif
  49. CANCELLABLE_SYSCALL(off_t, lseek, (int fd, off_t offset, int whence), (fd, offset, whence))
  50. lt_libc_hidden(lseek)
  51. #if __WORDSIZE == 64 || (!defined __NR__llseek && !defined __NR_llseek)
  52. strong_alias_untyped(__NC(lseek),__NC(lseek64))
  53. strong_alias_untyped(lseek,lseek64)
  54. lt_strong_alias(lseek64)
  55. lt_libc_hidden(lseek64)
  56. #endif