Hello
As you probably know AMD decided that only 48 bit addresses are supported. As there are 64 bits the other 16bits are forced to be the same as the 47th bit. So you end up with virtual addresses 0000 0000 0000 0000 - 0000 7FFF FFFF FFFF FFFF and FFFF 8000 0000 0000 0000 - FFFF FFFF FFFF FFFF . This leaves a big hole in the middle.
My question is why didn't they just simply say bits 48 - 62 must always be zero???? I would have thought virtual address space of 0000 0000 0000 0000 - 0000 7FFF FFFF FFFF FFFF and 1000 0000 0000 0000 - 1000 7FFF FFFF FFFF FFFF was much more logical.
Of course this is very theoretical. The important thing is a 48 bit user program will work with any future 64 bit kernel, that is covered either way.
Is there any specific reason for canonical addresses that i have missed?
AMD64 Canonical Address question
Re: AMD64 Canonical Address question
Hi,
The canonical address form, as you say, splits the address space in to a logical higher and lower half. Here, AMD have taken in to account the memory layout of most modern operating systems.
If your virtual kernel memory space starts at the top of the address space, you will be able to use the same memory layout whether the current CPU can address 48 bits, 64 bits or anything in between. The lower, user memory space simply expands upwards over CPU generations.
Cheers,
Adam
The canonical address form, as you say, splits the address space in to a logical higher and lower half. Here, AMD have taken in to account the memory layout of most modern operating systems.
If your virtual kernel memory space starts at the top of the address space, you will be able to use the same memory layout whether the current CPU can address 48 bits, 64 bits or anything in between. The lower, user memory space simply expands upwards over CPU generations.
Cheers,
Adam
Re: AMD64 Canonical Address question
And this is easily achieved by sign-extending the 48 to 64 bits.AJ wrote:The canonical address form, as you say, splits the address space in to a logical higher and lower half. Here, AMD have taken in to account the memory layout of most modern operating systems.
-
- Member
- Posts: 170
- Joined: Wed Jul 18, 2007 5:51 am
Re: AMD64 Canonical Address question
I am confused.
Take 32bit as an example.
I thought Windows / Linux starts at the 2GB boundary and grows UPWARDS?
Or they start at the 3GB boundary and grow upwards.
So wouldn't it be more logical for 64bit kernels to start at 0x1000 0000 0000 0000 instead of 0xFFFF 8000 0000 0000 ?
Take 32bit as an example.
I thought Windows / Linux starts at the 2GB boundary and grows UPWARDS?
Or they start at the 3GB boundary and grow upwards.
So wouldn't it be more logical for 64bit kernels to start at 0x1000 0000 0000 0000 instead of 0xFFFF 8000 0000 0000 ?
- JackScott
- Member
- Posts: 1033
- Joined: Thu Dec 21, 2006 3:03 am
- Location: Hobart, Australia
- Mastodon: https://aus.social/@jackscottau
- GitHub: https://github.com/JackScottAU
- Contact:
Re: AMD64 Canonical Address question
I think AMD were gambling on the fact that even considering today's bloated software, it's going to take a while before a kernel and it's drivers require (by my shockingly bad maths) 32TiB of memory.
- Owen
- Member
- Posts: 1700
- Joined: Fri Jun 13, 2008 3:21 pm
- Location: Cambridge, United Kingdom
- Contact:
Re: AMD64 Canonical Address question
The idea is that user mode occupy the lower half of the address space and kernel mode the upper half. Hence, there is always a constant boundary between user and kernel modes: 0x8000:0000:0000:0000 (Colons added for readability )
Re: AMD64 Canonical Address question
What do you mean with a kernel growing upwards? That the upper half is reserved for the kernel doesn't mean that it must be loaded at the boundary exactly.tom9876543 wrote:I thought Windows / Linux starts at the 2GB boundary and grows UPWARDS?
Or they start at the 3GB boundary and grow upwards.
So wouldn't it be more logical for 64bit kernels to start at 0x1000 0000 0000 0000 instead of 0xFFFF 8000 0000 0000 ?