On Tue, Feb 24, 2015 at 11:53 AM, Vishwas Srivastava
<[email protected]> wrote:
>
> Hi Sannu,
>             1G/3G address split is for virtual address. I am not talking 
> about physical address translation stuff here.
> When a kernel code is compiled for a 32 bit architecture, my assumption is, 
> compiler will generate the code for the full 4G address range. So there must 
> be somebody who is relocating/translating the kernel code address between 
> 0-4G to 3G--4G address space.
> Who is that guy? and is my understanding correct??
>
>
> On Tue, Feb 24, 2015 at 10:54 PM, Sannu K <[email protected]> wrote:
>>
>> Address generated by the linker is virtual address, it is not same as 
>> physical address. Kernel / MMU will do the virtual to physical address 
>> mapping.
>>
>> Hope this helps,
>> PrasannaKumar
>
>
>
> _______________________________________________
> Kernelnewbies mailing list
> [email protected]
> http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies
>

I believe it is done as part of kernel image linker script, please
have a look at linux/arch/x86/kernel/vmlinux.lds.S. The very first
logical address inside script is derived from LOAD_OFFSET (for x86_32)
or __PAGE_OFFSET which is 3G mark. Hope I am pointing you in right
way.

-Rajat

_______________________________________________
Kernelnewbies mailing list
[email protected]
http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies

Reply via email to