create_module.c 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /* vi: set sw=4 ts=4: */
  2. /* Syscalls for uClibc
  3. *
  4. * Copyright (C) 2000 by Lineo, inc. and Erik Andersen
  5. * Copyright (C) 2000-2006 Erik Andersen <andersen@uclibc.org>
  6. */
  7. #include <errno.h>
  8. #include <unistd.h>
  9. #include <features.h>
  10. #include <sys/types.h>
  11. #include <sys/syscall.h>
  12. #ifdef __NR_create_module
  13. #if defined(__UCLIBC_BROKEN_CREATE_MODULE__)
  14. # define __NR___create_module __NR_create_module
  15. static inline _syscall2(long, __create_module, const char *, name, size_t, size);
  16. /* By checking the value of errno, we know if we have been fooled
  17. * by the syscall2 macro making a very high address look like a
  18. * negative, so we we fix it up here. */
  19. unsigned long create_module(const char *name, size_t size)
  20. {
  21. long ret = __create_module(name, size);
  22. /* Jump through hoops to fixup error return codes */
  23. if (ret == -1 && errno > 125) {
  24. ret = -errno;
  25. __set_errno(0);
  26. }
  27. return ret;
  28. }
  29. #elif defined(__UCLIBC_SLIGHTLY_BROKEN_CREATE_MODULE__)
  30. # define __NR___create_module __NR_create_module
  31. /* Alpha doesn't have the same problem, exactly, but a bug in older
  32. kernels fails to clear the error flag. Clear it here explicitly. */
  33. static inline _syscall4(unsigned long, __create_module, const char *, name,
  34. size_t, size, size_t, dummy, size_t, err);
  35. unsigned long create_module(const char *name, size_t size)
  36. {
  37. return __create_module(name, size, 0, 0);
  38. }
  39. #else
  40. /* Sparc, MIPS, etc don't mistake return values for errors. */
  41. _syscall2(unsigned long, create_module, const char *, name, size_t, size);
  42. #endif
  43. #else /* !__NR_create_module */
  44. caddr_t create_module(const char *name attribute_unused, size_t size attribute_unused)
  45. {
  46. __set_errno(ENOSYS);
  47. return (caddr_t)-1;
  48. }
  49. #endif