Re: What is the truth about Linux 2.4's RAM limitations?
Jonathan Lundell (jlundell@pobox.com)
Tue, 10 Jul 2001 12:26:39 -0700
At 2:45 PM -0400 2001-07-10, Richard B. Johnson wrote:
> > AT&T days that there were Unix ports with separate kernel (vs user)
>> address spaces, as well as processors with special instructions for
>
>No. The difference between kernel and user address space is protection.
>Let's say that you decided to revamp all the user space to go from
>0 to 2^32-1. You call the kernel with a pointer to a buffer into
>which you need to write kernel data:
>
>You will need to set a selector that will access both user and
>kernel data at the same time. Since the user address space is
>paged, this will not be possible, you get one or the other, but
>not both. Therefore, you need to use two selectors. In the case
>of ix86 stuff, you could set DS = KERNEL_DS and ES = a separately
>calculated selector that represents the base address of the caller's
>virtual address space. Note that you can't just use the caller's
>DS or ES because they can be changed by the caller.
Sure, for IA-32, it's a royal pain. But Unix runs, after all, on
other CPUs. In point of simple historical fact, there have been Unix
ports with separate kernel and user address spaces, and there are
CPUs that, unlike IA-32, can simultaneously address the two spaces,
by virtue of having separate page table pointers and instructions for
copying between the two spaces.
To the extent that we're talking about Linux on IA-32, though, I
entirely agree that the cost of expanding user space from 3GB to 4GB
far outweighs any benefit. Especially with 64-bit architectures
coming online.
--
/Jonathan Lundell.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/