#define __NR_io_setup 243 #define __NR_io_destroy 244 #define __NR_io_getevents 245 #define __NR_io_submit 246 #define __NR_io_cancel 247 #define io_svc_clobber "1", "cc", "memory" #define io_syscall1(type,fname,sname,type1,arg1) \ type fname(type1 arg1) { \ register type1 __arg1 asm("2") = arg1; \ register long __svcres asm("2"); \ long __res; \ __asm__ __volatile__ ( \ " .if %1 < 256\n" \ " svc %b1\n" \ " .else\n" \ " la %%r1,%1\n" \ " .svc 0\n" \ " .endif" \ : "=d" (__svcres) \ : "i" (__NR_##sname), \ "0" (__arg1) \ : io_svc_clobber ); \ __res = __svcres; \ return (type) __res; \ } #define io_syscall2(type,fname,sname,type1,arg1,type2,arg2) \ type fname(type1 arg1, type2 arg2) { \ register type1 __arg1 asm("2") = arg1; \ register type2 __arg2 asm("3") = arg2; \ register long __svcres asm("2"); \ long __res; \ __asm__ __volatile__ ( \ " .if %1 < 256\n" \ " svc %b1\n" \ " .else\n" \ " la %%r1,%1\n" \ " svc 0\n" \ " .endif" \ : "=d" (__svcres) \ : "i" (__NR_##sname), \ "0" (__arg1), \ "d" (__arg2) \ : io_svc_clobber ); \ __res = __svcres; \ return (type) __res; \ } #define io_syscall3(type,fname,sname,type1,arg1,type2,arg2, \ type3,arg3) \ type fname(type1 arg1, type2 arg2, type3 arg3) { \ register type1 __arg1 asm("2") = arg1; \ register type2 __arg2 asm("3") = arg2; \ register type3 __arg3 asm("4") = arg3; \ register long __svcres asm("2"); \ long __res; \ __asm__ __volatile__ ( \ " .if %1 < 256\n" \ " svc %b1\n" \ " .else\n" \ " la %%r1,%1\n" \ " svc 0\n" \ " .endif" \ : "=d" (__svcres) \ : "i" (__NR_##sname), \ "0" (__arg1), \ "d" (__arg2), \ "d" (__arg3) \ : io_svc_clobber ); \ __res = __svcres; \ return (type) __res; \ } #define io_syscall4(type,fname,sname,type1,arg1,type2,arg2, \ type3,arg3,type4,arg4) \ type fname(type1 arg1, type2 arg2, type3 arg3, type4 arg4) { \ register type1 __arg1 asm("2") = arg1; \ register type2 __arg2 asm("3") = arg2; \ register type3 __arg3 asm("4") = arg3; \ register type4 __arg4 asm("5") = arg4; \ register long __svcres asm("2"); \ long __res; \ __asm__ __volatile__ ( \ " .if %1 < 256\n" \ " svc %b1\n" \ " .else\n" \ " la %%r1,%1\n" \ " svc 0\n" \ " .endif" \ : "=d" (__svcres) \ : "i" (__NR_##sname), \ "0" (__arg1), \ "d" (__arg2), \ "d" (__arg3), \ "d" (__arg4) \ : io_svc_clobber ); \ __res = __svcres; \ return (type) __res; \ } #define io_syscall5(type,fname,sname,type1,arg1,type2,arg2, \ type3,arg3,type4,arg4,type5,arg5) \ type fname(type1 arg1, type2 arg2, type3 arg3, type4 arg4, \ type5 arg5) { \ register type1 __arg1 asm("2") = arg1; \ register type2 __arg2 asm("3") = arg2; \ register type3 __arg3 asm("4") = arg3; \ register type4 __arg4 asm("5") = arg4; \ register type5 __arg5 asm("6") = arg5; \ register long __svcres asm("2"); \ long __res; \ __asm__ __volatile__ ( \ " .if %1 < 256\n" \ " svc %b1\n" \ " .else\n" \ " la %%r1,%1\n" \ " svc 0\n" \ " .endif" \ : "=d" (__svcres) \ : "i" (__NR_##sname), \ "0" (__arg1), \ "d" (__arg2), \ "d" (__arg3), \ "d" (__arg4), \ "d" (__arg5) \ : io_svc_clobber ); \ __res = __svcres; \ return (type) __res; \ }