Re: [x86] do_arch_prctl - bug?

From: Eric Lacombe
Date: Tue Nov 18 2008 - 18:44:26 EST


I look at the Intel docs (vol. 3A) again, and see that in 64 bits mode the
hidden field gs.base are physically mapped to the MSR, so it seems that in
order to load gs.base we don't need to load gs (like in 32 bits mode), but
rather we only need to load the MSR.

So I don't understand the purpose of load_gs_index in that context :

if (doit) {
load_gs_index(0);
ret = checking_wrmsrl(MSR_KERNEL_GS_BASE, addr);
}

Why don't we only load the MSR ?
What is the purpose of calling load_gs_index with 0 as parameter ?

Thanks in advance for your response,

Eric

> ENTRY(native_load_gs_index)
> CFI_STARTPROC
> pushf
> CFI_ADJUST_CFA_OFFSET 8
> DISABLE_INTERRUPTS(CLBR_ANY | ~(CLBR_RDI))
> SWAPGS
> gs_change:
> movl %edi,%gs
> 2: mfence /* workaround */
> SWAPGS
> popf
> CFI_ADJUST_CFA_OFFSET -8
> ret
> CFI_ENDPROC
> ENDPROC(native_load_gs_index)

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/