On Tue, 22 Mar 2005, David S. Miller wrote:
> On Tue, 22 Mar 2005 19:36:46 +0000 (GMT)
> Hugh Dickins <[email protected]> wrote:
>
> > I notice that although both i386 and sparc64 use pgtable-nopud.h, the
> > i386 pud_clear does nothing at all and the sparc64 pud_clear resets to 0.
>
> This was a dead end. I386 doesn't do anything with pud_clear() in
> order to work around a chip erratum.
>
> IA64 does clear in pud_clear() just like sparc64.
My mind kept flipping back and forth on whether it was pud_clear().
I agree, I can't see that it's the issue now.
> I think it's the floor/ceiling stuff.
>
> At that pud_clear(), we do it if floor-->ceiling (after masking)
> covers the whole PUD. Not whether start/end do, which is what
> the code sort of does right now.
Not an explanation I understood ;)
> "start" and "end" say which specific entries we might be purging.
Yes.
> "floor" and "ceiling" say that once that purging is done, the
> extent of the potential address space freed.
Well, they specify the limits beyond which we cannot free,
because there's other stuff still making use of addresses beyond.
> I cooked up a quick patch that changes the logic to:
>
> floor &= PUD_MASK;
> ceiling &= PUD_MASK;
> if (floor - 1 >= ceiling - 1)
> return;
That can't be right. In exit_mmap, for example, floor will be 0
throughout, and the condition will be true for all values of ceiling.
> pmd = pmd_offset(pud, start);
> pud_clear(pud);
> pmd_free_tlb(tlb, pmd);
>
> and things start to basically work.
Because none of your higher level tables are being freed at all:
eventually you'll run out of memory.
I still can't see what's wrong with the code that's already
there. My brain is seizing up, I'm taking a break.
Hugh
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]