Module Name: src Committed By: jym Date: Sun Mar 11 17:14:30 UTC 2012
Modified Files: src/sys/arch/xen/x86: xen_pmap.c Log Message: Split the map/unmap code from the sync/flush code: move xpq_flush_queue() calls after pmap_{,un}map_recursive_entries() so that pmap's handlers handle the flush themselves. Now pmap_{,un}map_recursive_entries() do what their names imply, nothing more. Fix pmap_xen_suspend()'s comment: APDPs are now gone. pmap's handlers are called deep during kernel save/restore. We already are at IPL_VM + kpreemption disabled. No need to wrap the xpq_flush_queue() with splvm/splx. To generate a diff of this commit: cvs rdiff -u -r1.19 -r1.20 src/sys/arch/xen/x86/xen_pmap.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/arch/xen/x86/xen_pmap.c diff -u src/sys/arch/xen/x86/xen_pmap.c:1.19 src/sys/arch/xen/x86/xen_pmap.c:1.20 --- src/sys/arch/xen/x86/xen_pmap.c:1.19 Fri Mar 2 16:38:14 2012 +++ src/sys/arch/xen/x86/xen_pmap.c Sun Mar 11 17:14:30 2012 @@ -1,4 +1,4 @@ -/* $NetBSD: xen_pmap.c,v 1.19 2012/03/02 16:38:14 bouyer Exp $ */ +/* $NetBSD: xen_pmap.c,v 1.20 2012/03/11 17:14:30 jym Exp $ */ /* * Copyright (c) 2007 Manuel Bouyer. @@ -102,7 +102,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: xen_pmap.c,v 1.19 2012/03/02 16:38:14 bouyer Exp $"); +__KERNEL_RCSID(0, "$NetBSD: xen_pmap.c,v 1.20 2012/03/11 17:14:30 jym Exp $"); #include "opt_user_ldt.h" #include "opt_lockdebug.h" @@ -236,22 +236,16 @@ pmap_extract_ma(struct pmap *pmap, vaddr } /* - * Flush all APDP entries found in pmaps - * Required during Xen save/restore operations, as Xen does not - * handle alternative recursive mappings properly + * Xen pmap's handlers for save/restore */ void pmap_xen_suspend(void) { - int s; - - s = splvm(); - xpq_flush_queue(); - splx(s); - #ifdef PAE pmap_unmap_recursive_entries(); #endif + + xpq_flush_queue(); } void @@ -260,6 +254,8 @@ pmap_xen_resume(void) #ifdef PAE pmap_map_recursive_entries(); #endif + + xpq_flush_queue(); } #ifdef PAE @@ -294,10 +290,13 @@ pmap_map_recursive_entries(void) xpmap_ptom(pmap_pdirpa(pmap_kernel(), PDIR_SLOT_PTE + i)), xpmap_ptom(pmap_kernel()->pm_pdirpa[i]) | PG_V); } - - xpq_flush_queue(); } +/* + * Unmap recursive entries found in pmaps. Required during Xen + * save/restore operations, as Xen does not handle recursive mappings + * properly. + */ void pmap_unmap_recursive_entries(void) { @@ -322,13 +321,11 @@ pmap_unmap_recursive_entries(void) mutex_exit(&pmaps_lock); /* do it for pmap_kernel() too! */ - for (i = 0; i < PDP_SIZE; i++) + for (i = 0; i < PDP_SIZE; i++) { xpq_queue_pte_update( xpmap_ptom(pmap_pdirpa(pmap_kernel(), PDIR_SLOT_PTE + i)), 0); - - xpq_flush_queue(); - + } } #endif /* PAE */