syscall-sparc.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #include <errno.h>
  2. #define __NR_io_setup 268
  3. #define __NR_io_destroy 269
  4. #define __NR_io_submit 270
  5. #define __NR_io_cancel 271
  6. #define __NR_io_getevents 272
  7. #define io_syscall1(type,fname,sname,type1,arg1) \
  8. type fname(type1 arg1) \
  9. { \
  10. long __res; \
  11. register long __g1 __asm__ ("g1") = __NR_##sname; \
  12. register long __o0 __asm__ ("o0") = (long)(arg1); \
  13. __asm__ __volatile__ ("t 0x10\n\t" \
  14. "bcc 1f\n\t" \
  15. "mov %%o0, %0\n\t" \
  16. "sub %%g0, %%o0, %0\n\t" \
  17. "1:\n\t" \
  18. : "=r" (__res), "=&r" (__o0) \
  19. : "1" (__o0), "r" (__g1) \
  20. : "cc"); \
  21. return (type) __res; \
  22. }
  23. #define io_syscall2(type,fname,sname,type1,arg1,type2,arg2) \
  24. type fname(type1 arg1,type2 arg2) \
  25. { \
  26. long __res; \
  27. register long __g1 __asm__ ("g1") = __NR_##sname; \
  28. register long __o0 __asm__ ("o0") = (long)(arg1); \
  29. register long __o1 __asm__ ("o1") = (long)(arg2); \
  30. __asm__ __volatile__ ("t 0x10\n\t" \
  31. "bcc 1f\n\t" \
  32. "mov %%o0, %0\n\t" \
  33. "sub %%g0, %%o0, %0\n\t" \
  34. "1:\n\t" \
  35. : "=r" (__res), "=&r" (__o0) \
  36. : "1" (__o0), "r" (__o1), "r" (__g1) \
  37. : "cc"); \
  38. return (type) __res; \
  39. }
  40. #define io_syscall3(type,fname,sname,type1,arg1,type2,arg2,type3,arg3) \
  41. type fname(type1 arg1,type2 arg2,type3 arg3) \
  42. { \
  43. long __res; \
  44. register long __g1 __asm__ ("g1") = __NR_##sname; \
  45. register long __o0 __asm__ ("o0") = (long)(arg1); \
  46. register long __o1 __asm__ ("o1") = (long)(arg2); \
  47. register long __o2 __asm__ ("o2") = (long)(arg3); \
  48. __asm__ __volatile__ ("t 0x10\n\t" \
  49. "bcc 1f\n\t" \
  50. "mov %%o0, %0\n\t" \
  51. "sub %%g0, %%o0, %0\n\t" \
  52. "1:\n\t" \
  53. : "=r" (__res), "=&r" (__o0) \
  54. : "1" (__o0), "r" (__o1), "r" (__o2), "r" (__g1) \
  55. : "cc"); \
  56. return (type) __res; \
  57. }
  58. #define io_syscall4(type,fname,sname,type1,arg1,type2,arg2,type3,arg3,type4,arg4) \
  59. type fname (type1 arg1, type2 arg2, type3 arg3, type4 arg4) \
  60. { \
  61. long __res; \
  62. register long __g1 __asm__ ("g1") = __NR_##sname; \
  63. register long __o0 __asm__ ("o0") = (long)(arg1); \
  64. register long __o1 __asm__ ("o1") = (long)(arg2); \
  65. register long __o2 __asm__ ("o2") = (long)(arg3); \
  66. register long __o3 __asm__ ("o3") = (long)(arg4); \
  67. __asm__ __volatile__ ("t 0x10\n\t" \
  68. "bcc 1f\n\t" \
  69. "mov %%o0, %0\n\t" \
  70. "sub %%g0, %%o0, %0\n\t" \
  71. "1:\n\t" \
  72. : "=r" (__res), "=&r" (__o0) \
  73. : "1" (__o0), "r" (__o1), "r" (__o2), "r" (__o3), "r" (__g1) \
  74. : "cc"); \
  75. return (type) __res; \
  76. }
  77. #define io_syscall5(type,fname,sname,type1,arg1,type2,arg2,type3,arg3,type4,arg4, \
  78. type5,arg5) \
  79. type fname (type1 arg1,type2 arg2,type3 arg3,type4 arg4,type5 arg5) \
  80. { \
  81. long __res; \
  82. register long __g1 __asm__ ("g1") = __NR_##sname; \
  83. register long __o0 __asm__ ("o0") = (long)(arg1); \
  84. register long __o1 __asm__ ("o1") = (long)(arg2); \
  85. register long __o2 __asm__ ("o2") = (long)(arg3); \
  86. register long __o3 __asm__ ("o3") = (long)(arg4); \
  87. register long __o4 __asm__ ("o4") = (long)(arg5); \
  88. __asm__ __volatile__ ("t 0x10\n\t" \
  89. "bcc 1f\n\t" \
  90. "mov %%o0, %0\n\t" \
  91. "sub %%g0, %%o0, %0\n\t" \
  92. "1:\n\t" \
  93. : "=r" (__res), "=&r" (__o0) \
  94. : "1" (__o0), "r" (__o1), "r" (__o2), "r" (__o3), "r" (__o4), "r" (__g1) \
  95. : "cc"); \
  96. return (type) __res; \
  97. }