Date: Mon, 5 Mar 2007 21:40:11 +0000 (UTC) From: Alan Cox <alc@FreeBSD.org> To: src-committers@FreeBSD.org, cvs-src@FreeBSD.org, cvs-all@FreeBSD.org Subject: cvs commit: src/sys/amd64/amd64 mp_machdep.c pmap.c src/sys/i386/i386 mp_machdep.c pmap.c vm_machdep.c Message-ID: <200703052140.l25LeBYa056016@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
alc 2007-03-05 21:40:11 UTC FreeBSD src repository Modified files: sys/amd64/amd64 mp_machdep.c pmap.c sys/i386/i386 mp_machdep.c pmap.c vm_machdep.c Log: Acquiring smp_ipi_mtx on every call to pmap_invalidate_*() is wasteful. For example, during a buildworld more than half of the calls do not generate an IPI because the only TLB entry invalidated is on the calling processor. This revision pushes down the acquisition and release of smp_ipi_mtx into smp_tlb_shootdown() and smp_targeted_tlb_shootdown() and instead uses sched_pin() and sched_unpin() in pmap_invalidate_*() so that thread migration doesn't lead to a missed TLB invalidation. Reviewed by: jhb MFC after: 3 weeks Revision Changes Path 1.282 +8 -2 src/sys/amd64/amd64/mp_machdep.c 1.580 +8 -64 src/sys/amd64/amd64/pmap.c 1.275 +9 -2 src/sys/i386/i386/mp_machdep.c 1.582 +8 -64 src/sys/i386/i386/pmap.c 1.276 +0 -2 src/sys/i386/i386/vm_machdep.c
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200703052140.l25LeBYa056016>