On Sat, Dec 08, 2007 at 08:24:57PM -0800, John Reiser wrote:
>In source file arch/um/os-Linux/process.c there is a warning:
>-----
>/* Don't use the glibc version, which caches the result in TLS. It misses some
> * syscalls, and also breaks with clone(), which does not unshare the TLS.
> */
> 
>int os_getpid(void)

AFAIK, there are two reasons that we make sure we call the system call
getpid -
        when we're testing ptrace, we want getpid to result in exactly
one system call
        there was a brief bug in libc where getpid returned the wrong
answer due to caching across a clone

This bug did get into the wild, and people did try to run UML on such
systems, so that's why the code is careful about making the system call.

> I see no os_clone(), yet the glibc clone() does the same caching of pid in
> ThreadLocalStorage [TLS], and the TLS still may be shared.  If nobody reads
> glibc's shared TLS slot for PID then an actual bug will be avoided.  However,
> it is unsafe to leave such a tempting pitfall.

What's the actual bug, exactly?  As long as libc's getpid gives us the
right answer, we're happy.

> Also, if you are ptrace()ing
> through a glibc clone(), then in many cases you will see syscall(__NR_getpid)
> *from glibc* immediately following!  There is an "extra" getpid()
> that the tracking logic might not expect.

Where do we care about how clone translates into a system call?

>    arch/um/drivers/ubd_user.c
>    arch/um/kernel/tt/tracer.c
>    arch/um/os/tt.c
>    arch/um/os/start_up.c
>    arch/um/os/skas/process.c

These guys all just want a new process - they don't care how it
happens.

Is something in here causing valgrind some trouble?

                                Jeff

-- 
Work email - jdike at linux dot intel dot com

-------------------------------------------------------------------------
SF.Net email is sponsored by: 
Check out the new SourceForge.net Marketplace.
It's the best place to buy or sell services for
just about anything Open Source.
http://sourceforge.net/services/buy/index.php
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

Reply via email to