Browse Source

patch from njk: make x86_64 __uniclone branchless.

rs-1.0
Rich Felker 15 years ago
parent
commit
22cd9cae81
  1. 12
      src/thread/x86_64/clone.s

12
src/thread/x86_64/clone.s

@ -4,6 +4,7 @@
.type __uniclone,%function .type __uniclone,%function
/* rdi = child_stack, rsi = start, rdx = pthread_struct */ /* rdi = child_stack, rsi = start, rdx = pthread_struct */
__uniclone: __uniclone:
subq $8,%rsp /* pad parent stack to prevent branch later */
subq $16,%rdi /* grow child_stack */ subq $16,%rdi /* grow child_stack */
mov %rsi,8(%rdi) /* push start onto child_stack as return ptr */ mov %rsi,8(%rdi) /* push start onto child_stack as return ptr */
mov %rdx,0(%rdi) /* push pthread_struct onto child_stack */ mov %rdx,0(%rdi) /* push pthread_struct onto child_stack */
@ -13,10 +14,9 @@ __uniclone:
movl $56,%eax /* clone syscall number */ movl $56,%eax /* clone syscall number */
movl $0x7d0f00,%edi /* rdi = flags */ movl $0x7d0f00,%edi /* rdi = flags */
mov %r10,%rdx /* rdx = parent_id */ mov %r10,%rdx /* rdx = parent_id */
syscall /* clone(flags, child_stack, parent_id, syscall /* clone(flags, child_stack, parent_id,
* child_id, tls) */ * child_id, tls) */
test %rax,%rax pop %rdi /* child stack: restore pthread_struct
jnz 1f /* if we're in the parent -> goto 1f */ * parent stack: undo rsp displacement */
pop %rdi /* restore pthread_struct from child stack */ ret
1: ret
.size __uniclone,.-__uniclone .size __uniclone,.-__uniclone

Loading…
Cancel
Save