How TLS is used in Kernel thread



By looking through _pthread_create() code and find it uses a magic cookie -- TLS -- created
by rtld_allocate_tls(), and passed into kernel by sysarch() via _tcb_set() / _kcb_set().

The information seems to be set by rtld (ld-elf.so.1) in digest_phdr() under tag PT_TLS.
But it is very magic for where the TLS object is created and how it is passed to digest_phdr().

The whole object passed into kernel (as sd.gsbase) looks like this:

TCB: ______________________________
| TLS | TCB |
|______________|_______________|

Can someone give some basic exaplain on following questions?

1) What TLS stand for?
2) Where TLS object is created? (below is the tls assigned, but I couls not find where ph is from)
case PT_TLS:
obj->tlsindex = 1;
obj->tlssize = ph->p_memsz;
obj->tlsalign = ph->p_align;
obj->tlsinitsize = ph->p_filesz;
obj->tlsinit = (void*) ph->p_vaddr;

3) Where in kernel the TLS is used for thread operation?

Thanks in advance,
-Jin
_______________________________________________
freebsd-hackers@xxxxxxxxxxx mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "freebsd-hackers-unsubscribe@xxxxxxxxxxx"



Relevant Pages

  • Re: Assignment of GDT entries
    ... aware of segments, for a rather perverse reason: the TLS stuff. ... Or is it only used in kernel code? ... and obviously we'd like to keep them in the same cacheline too. ...
    (Linux-Kernel)
  • Re: TLS - implementing linux one in fbsd
    ... implement TLS, M:N implements it in userland, while 1:1 implements it in kernel. ... not have to set TLS via syscall later. ... those syscalls to not to setup TLS because linux wants to set it ...
    (freebsd-hackers)
  • Re: How TLS is used in Kernel thread
    ... The whole object passed into kernel looks like this: ... What TLS stand for? ... Static programs have a slightly simpler mechanism (simpler because there ... support for the thread libraries needs. ...
    (freebsd-hackers)
  • Re: Assignment of GDT entries
    ... user code segment number is the same as the kernel code segment +2 (ie ... Or is it only used in kernel code? ... and obviously we'd like to keep them in the same cacheline too. ... - TLS #1 ...
    (Linux-Kernel)
  • Re: how to implement Thread Local Storage (TLS) in kernel
    ... there is no concept of TLS in kernel. ... table on the side using the current thread ID + current IRQL as the lookup, ... TLS doesn't make much sense. ... Please do not send e-mail directly to this alias. ...
    (microsoft.public.win32.programmer.kernel)