Author: alc
Date: Wed Dec 28 19:59:54 2011
New Revision: 228935
URL: http://svn.freebsd.org/changeset/base/228935

Log:
  Fix a bug in the Xen pmap's implementation of pmap_extract_and_hold():
  If the page lock acquisition is retried, then the underlying thread is
  not unpinned.
  
  Wrap nearby lines that exceed 80 columns.

Modified:
  head/sys/amd64/amd64/pmap.c
  head/sys/i386/i386/pmap.c
  head/sys/i386/xen/pmap.c

Modified: head/sys/amd64/amd64/pmap.c
==============================================================================
--- head/sys/amd64/amd64/pmap.c Wed Dec 28 19:37:03 2011        (r228934)
+++ head/sys/amd64/amd64/pmap.c Wed Dec 28 19:59:54 2011        (r228935)
@@ -1255,8 +1255,8 @@ retry:
        if (pdep != NULL && (pde = *pdep)) {
                if (pde & PG_PS) {
                        if ((pde & PG_RW) || (prot & VM_PROT_WRITE) == 0) {
-                               if (vm_page_pa_tryrelock(pmap, (pde & 
PG_PS_FRAME) |
-                                      (va & PDRMASK), &pa))
+                               if (vm_page_pa_tryrelock(pmap, (pde &
+                                   PG_PS_FRAME) | (va & PDRMASK), &pa))
                                        goto retry;
                                m = PHYS_TO_VM_PAGE((pde & PG_PS_FRAME) |
                                    (va & PDRMASK));
@@ -1266,7 +1266,8 @@ retry:
                        pte = *pmap_pde_to_pte(pdep, va);
                        if ((pte & PG_V) &&
                            ((pte & PG_RW) || (prot & VM_PROT_WRITE) == 0)) {
-                               if (vm_page_pa_tryrelock(pmap, pte & PG_FRAME, 
&pa))
+                               if (vm_page_pa_tryrelock(pmap, pte & PG_FRAME,
+                                   &pa))
                                        goto retry;
                                m = PHYS_TO_VM_PAGE(pte & PG_FRAME);
                                vm_page_hold(m);

Modified: head/sys/i386/i386/pmap.c
==============================================================================
--- head/sys/i386/i386/pmap.c   Wed Dec 28 19:37:03 2011        (r228934)
+++ head/sys/i386/i386/pmap.c   Wed Dec 28 19:59:54 2011        (r228935)
@@ -1368,8 +1368,8 @@ retry:
        if (pde != 0) {
                if (pde & PG_PS) {
                        if ((pde & PG_RW) || (prot & VM_PROT_WRITE) == 0) {
-                               if (vm_page_pa_tryrelock(pmap, (pde & 
PG_PS_FRAME) |
-                                      (va & PDRMASK), &pa))
+                               if (vm_page_pa_tryrelock(pmap, (pde &
+                                   PG_PS_FRAME) | (va & PDRMASK), &pa))
                                        goto retry;
                                m = PHYS_TO_VM_PAGE((pde & PG_PS_FRAME) |
                                    (va & PDRMASK));
@@ -1381,7 +1381,8 @@ retry:
                        pmap_pte_release(ptep);
                        if (pte != 0 &&
                            ((pte & PG_RW) || (prot & VM_PROT_WRITE) == 0)) {
-                               if (vm_page_pa_tryrelock(pmap, pte & PG_FRAME, 
&pa))
+                               if (vm_page_pa_tryrelock(pmap, pte & PG_FRAME,
+                                   &pa))
                                        goto retry;
                                m = PHYS_TO_VM_PAGE(pte & PG_FRAME);
                                vm_page_hold(m);

Modified: head/sys/i386/xen/pmap.c
==============================================================================
--- head/sys/i386/xen/pmap.c    Wed Dec 28 19:37:03 2011        (r228934)
+++ head/sys/i386/xen/pmap.c    Wed Dec 28 19:59:54 2011        (r228935)
@@ -1134,8 +1134,8 @@ retry:
        if (pde != 0) {
                if (pde & PG_PS) {
                        if ((pde & PG_RW) || (prot & VM_PROT_WRITE) == 0) {
-                               if (vm_page_pa_tryrelock(pmap, (pde & 
PG_PS_FRAME) |
-                                      (va & PDRMASK), &pa))
+                               if (vm_page_pa_tryrelock(pmap, (pde &
+                                   PG_PS_FRAME) | (va & PDRMASK), &pa))
                                        goto retry;
                                m = PHYS_TO_VM_PAGE((pde & PG_PS_FRAME) |
                                    (va & PDRMASK));
@@ -1148,8 +1148,11 @@ retry:
                                PT_SET_MA(PADDR1, 0);
                        if ((pte & PG_V) &&
                            ((pte & PG_RW) || (prot & VM_PROT_WRITE) == 0)) {
-                               if (vm_page_pa_tryrelock(pmap, pte & PG_FRAME, 
&pa))
+                               if (vm_page_pa_tryrelock(pmap, pte & PG_FRAME,
+                                   &pa)) {
+                                       sched_unpin();
                                        goto retry;
+                               }
                                m = PHYS_TO_VM_PAGE(pte & PG_FRAME);
                                vm_page_hold(m);
                        }
_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to