Fwd: Re: buildworld panics with yesterday's kernel ...
Andrew Atrens
atrens at nortelnetworks.com
Wed May 5 21:39:57 PDT 2004
Thanks Matt!
I'll give it a try tomorrow morning and report back ...
Cheers,
Andrew.
Matthew Dillon wrote:
> Andrew, I fixed it. I was calling pmap_qremove() with a bad argument
> in pmap_unmapdev(). It was totally my fault. Damn. :-)
>
> I've committed an update to i386/i386/pmap.c, also included below.
>
> Note that the filesystem corruption you were getting prior to this
> commit was related to the same pmap_unmapdev code... the original
> FBsd code failed to remove the pte's that had been installed, which
> can corrupt kernel_map. The older incarnation of the FP code could
> also cause corruption. Since ACPICA and ACPICA5 are the only ones
> that actually call pmap_unmapdev(), this tended to result in corruption
> for people running acpica which is why it was so hard to track down.
> I had added the qremove to remove the pte's and fix the corruption,
> but I got the arguments wrong :-(.
>
> -Matt
>
>Index: i386/i386/pmap.c
>===================================================================
>RCS file: /cvs/src/sys/i386/i386/pmap.c,v
>retrieving revision 1.37
>diff -u -r1.37 pmap.c
>--- i386/i386/pmap.c 5 May 2004 19:26:38 -0000 1.37
>+++ i386/i386/pmap.c 5 May 2004 22:03:45 -0000
>@@ -3220,10 +3220,10 @@
> {
> vm_offset_t base, offset;
>
>- pmap_qremove(va, size);
> base = va & PG_FRAME;
> offset = va & PAGE_MASK;
> size = roundup(offset + size, PAGE_SIZE);
>+ pmap_qremove(va, size >> PAGE_SHIFT);
> kmem_free(kernel_map, base, size);
> }
>
>
>
More information about the Bugs
mailing list