-
Notifications
You must be signed in to change notification settings - Fork 122
intercept_hook_point_clone_child() is not called within the thread created by fork(), not pthread_create(). #135
Comments
Until someone more knowledgeable answers, maybe this can help... $ strace -f -e trace=clone,clone3,fork,vfork ./fork
clone(child_stack=NULL, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7fa6a81d6a10)
$ strace -f -e trace=clone,clone3,fork,vfork ./pthread
clone3({flags=CLONE_VM|CLONE_FS|CLONE_FILES|CLONE_SIGHAND|CLONE_THREAD|CLONE_SYSVSEM|CLONE_SETTLS|CLONE_PARENT_SETTID|CLONE_CHILD_CLEARTID, child_tid=0x7fe92aa70990, parent_tid=0x7fe92aa70990, exit_signal=0, stack=0x7fe92a270000, stack_size=0x7fff80, tls=0x7fe92aa706c0} => {parent_tid=[93337]}, 88) The problem is not in the syscall itself ( I don't know what could be a negative implication of that code change. [ Tested Environment ] |
This is actually the exact conclusion I have come up with. Although I also don't know why it checks new stack frames and thought that was related to handling of separate child/parent hooks. |
You can't return after calling |
Yes, I already know that. What I and the above comment meant is why it checks |
Now that I understand the internals of the library a bit better, I can appreciate what @en4bz meant by his comment above. In short, if cloning with a new (empty) stack would be done in intercept_routine:691 the child wouldn't be able to return to intercept_wrapper.S:171 nor a child would be able to restore context in intercept_wrapper.S:195 from an empty stack. That's why it is needed to return to the assembly part of the library, restore context there, and then execute the I'm clarifying this for users like me and @hurryman2212 who expect that |
intercept_hook_point_clone_child()
is called only when the child thread is created bypthread_create()
, but not withfork()
, although both GLIBC'sfork()
andpthread_create()
with NPTL uses the same system call,clone()
.[ Tested Environment ]
Ubuntu 24.04 / 6.8.0-35-generic x86_64 GNU/Linux (from official Ubuntu repository) / GLIBC 2.39-0ubuntu8.2 (also)
The text was updated successfully, but these errors were encountered: