Date: Tue, 26 Jun 2007 10:54:14 +0800 From: "jj shen" <kbottle@gmail.com> To: "Jung-uk Kim" <jkim@freebsd.org> Cc: freebsd-current@freebsd.org Subject: Re: The relation between %fs and fs base Message-ID: <293b12a20706251954g479c0d72o9144832682f2cc54@mail.gmail.com> In-Reply-To: <200706251851.15377.jkim@FreeBSD.org> References: <293b12a20706251037t39a0227p45434a8d71feeba1@mail.gmail.com> <200706251851.15377.jkim@FreeBSD.org>
next in thread | previous in thread | raw e-mail | index | archive | help
Hi, I know that NPTL use %fs to access thread local data. It seems that when the base address can be fitted in 32 bits, a GDT entry is used for better performance and the selector is loaded to %fs; otherwise, if the base address is larger than 0xffffffff, it is loaded to FS_BASE MSR and %fs is set to zero. I need to maintain these two kinds of TLS simultaneously (for system simulation), but was confused with the %fs and fs base. Maybe, someone can help me, at least my last two questions. Thanks! On 6/26/07, Jung-uk Kim <jkim@freebsd.org> wrote: > On Monday 25 June 2007 01:37 pm, jj shen wrote: > > Hi, > > > > I want to access different TLS through both fs base and GDT > > simultaneously. Let us call the two ways TLS_FSBASE and TLS_GDT > > respectively. > > > > (1) Can I switch from TLS_FSBASE to TLS_GDT just by: "movl GDT_SEL, > > %fs" (where GDT_SEL is the selector of GDT entry)? > > Will this instruction destroy the content of the IA32_FS_BASE MSR? > > > > (2) When switching from TLS_GDT to TLS_FSBASE, can I just set %fs > > to zero to indicate the fs base should be used, or must I invoke > > the > > *wrmsrl*instruction to reset IA32_FS_BASE once again? > > > > (3) What is the length of %fs? What I get by "movl %fs, %eax" in > > %eax? In the programmer manual from AMD, it is said somewhere that > > segment registers are still 16 bits as in x86, and it is also said > > otherwhere that "segment loads into FS and GS load a standard > > 32-bit base value in the hidden portion of the segment descriptor > > register". > > > > (4) What is the content of %fs, a descriptor selector or a base > > address smaller than 0xffffffff? > > What is effect of "movl val, %fs", loading a GDT selector or a > > 32-bit base address to %fs? > > Seen from the citation above, I think *val *should be a 32-bit > > base address; however seen from the implementation of Linux > > *arch_prctl* system call, it is a GDT selector loaded into %fs. > > I don't know what you are trying to achieve but don't mess up with %fs > and %gs on amd64 unless you are absolutely sure. It is deprecated > and it won't work as you expected. The only way to get/set %fs and > %gs properly on amd64 is via proper API, i.e., sysarch(2) with > AMD64_{GET,SET}_{FS,GS}BASE. If you use the API, the MSR will be > properly saved and restored while switching contexts. However, it is > very much discouraged as the manual page says, e. g., it will cause > serious problem if the application is threaded, etc. In fact, the > API should be only used by threading libraries. > > Jung-uk Kim >
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?293b12a20706251954g479c0d72o9144832682f2cc54>