123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- .text
- ENTRY (name) \
- SINGLE_THREAD_P(a15)
- bnez a15, .Lpseudo_cancel
- DO_CALL (syscall_name, args)
- bgez a2, .Lpseudo_done
- movi a4, -4095
- blt a2, a4, .Lpseudo_done
- j SYSCALL_ERROR_LABEL; \
- .Lpseudo_done: \
- retw
- .Lpseudo_cancel: \
- \
- CENABLE
- \
- DO_CALL (syscall_name, args)
- CDISABLE
- bgez a2, .Lpseudo_end
- movi a4, -4095
- blt a2, a4, .Lpseudo_end
- j SYSCALL_ERROR_LABEL; \
- .Lpseudo_end:
- callx8 a8
- callx8 a8
- .text
- ENTRY (name) \
- SINGLE_THREAD_P(a10)
- bnez a10, .Lpseudo_cancel
- DO_CALL (syscall_name, args)
- bgez a2, .Lpseudo_done
- movi a4, -4095
- blt a2, a4, .Lpseudo_done
- j SYSCALL_ERROR_LABEL; \
- .Lpseudo_done: \
- ret
- .Lpseudo_cancel: \
- addi a1, a1, -32
- \
- s32i a0, a1, 0
- s32i a2, a1, 4
- s32i a3, a1, 8
- s32i a4, a1, 12
- s32i a5, a1, 16
- s32i a6, a1, 20
- s32i a7, a1, 24
- CENABLE
- \
- mov a10, a2
- l32i a2, a1, 4
- l32i a3, a1, 8
- l32i a4, a1, 12
- l32i a5, a1, 16
- l32i a6, a1, 20
- l32i a7, a1, 24
- DO_CALL (syscall_name, args)
- s32i a2, a1, 4
- mov a2, a10
- CDISABLE
- l32i a2, a1, 4
- l32i a0, a1, 0
- addi a1, a1, 32
- bgez a2, .Lpseudo_end
- movi a4, -4095
- blt a2, a4, .Lpseudo_end
- j SYSCALL_ERROR_LABEL; \
- .Lpseudo_end:
- callx0 a0
- callx0 a0
- extern int __local_multiple_threads attribute_hidden;
- l32i reg, reg, 0;
- __builtin_expect (THREAD_GETMEM (THREAD_SELF, \
- header.multiple_threads) == 0, 1)
- rur reg, threadptr
- l32i reg, reg, MULTIPLE_THREADS_OFFSET;
- __builtin_expect (THREAD_GETMEM (THREAD_SELF, \
- header.multiple_threads) == 0, 1)
|