Re: Getting big areas of memory, in 2.3.x?

Kanoj Sarcar (kanoj@google.engr.sgi.com)
Thu, 9 Dec 1999 14:27:26 -0800 (PST)


>
>
> On Thu, 9 Dec 1999, Kanoj Sarcar wrote:
>
> > Well, at least in 2.3, kernel data (and page caches) are below 1G,
> > which means there's a lot of memory possible out there with
> > references only from user memory. Shm page references are
> > revokable too. [...]
>
> we already kindof replace pages, see replace_with_highmem(). Reverse ptes
> do help, but are not a necessity to get this. Neither reverse ptes, nor
> any other method guarantees that a large amount of continuous RAM can be
> allocated. Only boot-time allocation can be guaranteed.
>
> -- mingo
>

Unfortunately, a bunch of these drivers are loadable modules, so unless
they do some trickery, boot-time allocation does not apply for them.

A similar category of drivers would like to do this dynamically too.

For drivers that want to do this a fixed number of time at bootup,
yes, boot-time allocation is the answer ...

If I am not wrong, replace_with_highmem() replaces a page when the
kernel is quite sure there's exactly one reference on the page, and
that is from the executing code. For the dynamic case, the problem
is in trying to rip away unknown number of kernel/user references
from a given page. Rmaps do not guarantee it, they just improve the
chances of success in such problems at an affordable cost.

Kanoj

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