| #include "pthread_impl.h" |
| #include "atomic.h" |
| #include "syscall.h" |
| /* cheat and reuse CRTJMP macro from dynlink code */ |
| #include "dynlink.h" |
| |
| static volatile int lock; |
| static void* unmap_base; |
| static size_t unmap_size; |
| static char shared_stack[256]; |
| |
| static void do_unmap() { |
| __syscall(SYS_munmap, unmap_base, unmap_size); |
| __syscall(SYS_exit); |
| } |
| |
| void __unmapself(void* base, size_t size) { |
| int tid = __pthread_self()->tid; |
| char* stack = shared_stack + sizeof shared_stack; |
| stack -= (uintptr_t)stack % 16; |
| while (lock || a_cas(&lock, 0, tid)) |
| a_spin(); |
| __syscall(SYS_set_tid_address, &lock); |
| unmap_base = base; |
| unmap_size = size; |
| CRTJMP(do_unmap, stack); |
| } |