Date: Wed, 30 Aug 2006 15:28:20 GMT From: tkuik <tkuik@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 105330 for review Message-ID: <200608301528.k7UFSKkd084947@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=105330 Change 105330 by tkuik@tkuik_freebsd on 2006/08/30 15:28:02 Clear PMAP1 & PMAP2 entries after use to prevent grant transfer failures in case the page being mapped is later transferred to another domain. Affected files ... .. //depot/projects/xen3/src/sys/i386-xen/i386-xen/pmap.c#7 edit Differences ... ==== //depot/projects/xen3/src/sys/i386-xen/i386-xen/pmap.c#7 (text+ko) ==== @@ -249,6 +249,9 @@ #endif static pt_entry_t *PMAP1 = 0, *PMAP2; static pt_entry_t *PADDR1 = 0, *PADDR2; +#ifdef XEN +static int PMAP1_inuse = 0, PMAP2_inuse = 0; +#endif #ifdef SMP static int PMAP1cpu; static int PMAP1changedcpu; @@ -765,6 +768,7 @@ if (tmppf != newpf) { PT_SET_VA(PMAP2, newpf | PG_V | PG_A, FALSE); pmap_invalidate_page(kernel_pmap, (vm_offset_t)PADDR2); + PMAP2_inuse = 1; } #else @@ -827,13 +831,14 @@ return (vtopte(va)); mtx_assert(&vm_page_queue_mtx, MA_OWNED); KASSERT(curthread->td_pinned > 0, ("curthread not pinned")); - newpf = *pde & PG_FRAME; #ifdef XEN newpf = PT_GET(pde) & PG_FRAME; tmppf = PT_GET(PMAP1) & PG_FRAME; if (tmppf != newpf) { PT_SET_VA(PMAP1, newpf | PG_V | PG_A, TRUE); + PMAP1_inuse = 1; #else + newpf = *pde & PG_FRAME; if ((*PMAP1 & PG_FRAME) != newpf) { *PMAP1 = newpf | PG_RW | PG_V | PG_A | PG_M; #endif @@ -889,6 +894,12 @@ rtval = (*pte & PG_FRAME) | (va & PAGE_MASK); #endif pmap_pte_release(pte); +#ifdef XEN + if (PMAP2_inuse) { + PT_CLEAR_VA(PMAP2, TRUE); + PMAP2_inuse = 0; + } +#endif } PMAP_UNLOCK(pmap); return (rtval); @@ -918,6 +929,12 @@ pte = pmap_pte(pmap, va); rtval = (*pte & PG_FRAME) | (va & PAGE_MASK); pmap_pte_release(pte); +#ifdef XEN + if (PMAP2_inuse) { + PT_CLEAR_VA(PMAP2, TRUE); + PMAP2_inuse = 0; + } +#endif } PMAP_UNLOCK(pmap); return (rtval); @@ -957,6 +974,10 @@ sched_pin(); #ifdef XEN pte = PT_GET(pmap_pte_quick(pmap, va)); + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } #else pte = *pmap_pte_quick(pmap, va); #endif @@ -1739,6 +1760,12 @@ free_pv_entry(pv); } } +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif sched_unpin(); if (allocated_pv == NULL) { if (vpq == &vm_page_queues[PQ_INACTIVE]) { @@ -1845,10 +1872,16 @@ mtx_assert(&vm_page_queue_mtx, MA_OWNED); KASSERT(curthread->td_pinned > 0, ("curthread not pinned")); PMAP_LOCK_ASSERT(pmap, MA_OWNED); - if ((pte = pmap_pte_quick(pmap, va)) == NULL || *pte == 0) - return; - pmap_remove_pte(pmap, pte, va); - pmap_invalidate_page(pmap, va); + if ((pte = pmap_pte_quick(pmap, va)) && *pte) { + pmap_remove_pte(pmap, pte, va); + pmap_invalidate_page(pmap, va); + } +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif } /* @@ -1939,6 +1972,12 @@ break; } } +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif out: sched_unpin(); vm_page_unlock_queues(); @@ -2006,6 +2045,12 @@ free_pv_entry(pv); } vm_page_flag_clear(m, PG_WRITEABLE); +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif sched_unpin(); } @@ -2106,6 +2151,12 @@ } } } +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif sched_unpin(); vm_page_unlock_queues(); if (anychanged) @@ -2302,6 +2353,12 @@ } else pte_store(pte, newpte | PG_A); } +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif sched_unpin(); vm_page_unlock_queues(); PMAP_UNLOCK(pmap); @@ -2542,6 +2599,12 @@ */ pmap_pte_set_w(pte, wired); pmap_pte_release(pte); +#ifdef XEN + if (PMAP2_inuse) { + PT_CLEAR_VA(PMAP2, TRUE); + PMAP2_inuse = 0; + } +#endif PMAP_UNLOCK(pmap); } @@ -2666,6 +2729,12 @@ } } PT_UPDATES_FLUSH(); +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif sched_unpin(); vm_page_unlock_queues(); PMAP_UNLOCK(src_pmap); @@ -2956,6 +3025,12 @@ pmap_unuse_pt(pmap, pv->pv_va); free_pv_entry(pv); } +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif sched_unpin(); pmap_invalidate_all(pmap); PMAP_UNLOCK(pmap); @@ -2996,6 +3071,12 @@ if (rv) break; } +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif sched_unpin(); return (rv); } @@ -3094,6 +3175,12 @@ } if (bit == PG_RW) vm_page_flag_clear(m, PG_WRITEABLE); +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif sched_unpin(); } @@ -3172,6 +3259,12 @@ } PMAP_UNLOCK(pv->pv_pmap); } while ((pv = pvn) != NULL && pv != pvf); +#ifdef XEN + if (PMAP1_inuse) { + PT_CLEAR_VA(PMAP1, TRUE); + PMAP1_inuse = 0; + } +#endif } sched_unpin(); @@ -3270,6 +3363,12 @@ ptep = pmap_pte(pmap, addr); pte = (ptep != NULL) ? PT_GET(ptep) : 0; pmap_pte_release(ptep); +#ifdef XEN + if (PMAP2_inuse) { + PT_CLEAR_VA(PMAP2, TRUE); + PMAP2_inuse = 0; + } +#endif PMAP_UNLOCK(pmap); if (pte != 0) { @@ -3401,8 +3500,7 @@ index = 0; printf("\n"); } - sx_sunlock(&allproc_lock); - return npte; + goto done; } pte = pmap_pte(pmap, va); if (pte && pmap_pte_v(pte)) { @@ -3426,6 +3524,13 @@ } } } + done: +#ifdef XEN + if (PMAP2_inuse) { + PT_CLEAR_VA(PMAP2, TRUE); + PMAP2_inuse = 0; + } +#endif sx_sunlock(&allproc_lock); return npte; } @@ -3460,6 +3565,12 @@ printf("%x:%x ", va, *ptep); }; +#ifdef XEN + if (PMAP2_inuse) { + PT_CLEAR_VA(PMAP2, TRUE); + PMAP2_inuse = 0; + } +#endif } void @@ -3492,6 +3603,10 @@ pmap_pte_release(pte); } PT_UPDATES_FLUSH(); + if (PMAP2_inuse) { + PT_CLEAR_VA(PMAP2, TRUE); + PMAP2_inuse = 0; + } } void @@ -3506,6 +3621,10 @@ pmap_pte_release(pte); } PT_UPDATES_FLUSH(); + if (PMAP2_inuse) { + PT_CLEAR_VA(PMAP2, TRUE); + PMAP2_inuse = 0; + } }
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200608301528.k7UFSKkd084947>