[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] Fix building the p2m table for shadow translate mode guests.
# HG changeset patch # User cl349@xxxxxxxxxxxxxxxxxxxx # Node ID de0408f095f88a0121956a1c290da17d1d529564 # Parent 166322cd55df5d5e624bed730169a6bf7751ecea Fix building the p2m table for shadow translate mode guests. Signed-off-by: Christian Limpach <Christian.Limpach@xxxxxxxxxxxx> diff -r 166322cd55df -r de0408f095f8 xen/arch/x86/shadow32.c --- a/xen/arch/x86/shadow32.c Tue Feb 14 23:37:15 2006 +++ b/xen/arch/x86/shadow32.c Wed Feb 15 09:43:14 2006 @@ -842,7 +842,7 @@ unmap_domain_page_with_cache(l2, l2cache); l1 = map_domain_page_with_cache(l2e_get_pfn(l2e), l1cache); - l1[l1_table_offset(va)] = l1e_from_pfn(mfn, __PAGE_HYPERVISOR); + l1[l1_table_offset(va)] = (l1_pgentry_t) { mfn }; unmap_domain_page_with_cache(l1, l1cache); return 1; @@ -860,42 +860,48 @@ l2_pgentry_t l2e = { 0 }; l1_pgentry_t l1e = { 0 }; + struct page_info *page; unsigned long pfn; int i; - ASSERT ( pagetable_get_pfn(d->vcpu[0]->arch.monitor_table)); - - l2tab = map_domain_page( - pagetable_get_pfn(d->vcpu[0]->arch.monitor_table)); - - list_ent = d->page_list.next; - - for ( i = 0; list_ent != &d->page_list; i++ ) - { - struct page_info *page; - page = list_entry(list_ent, struct page_info, list); - pfn = page_to_mfn(page); - + if ( pagetable_get_pfn(d->vcpu[0]->arch.monitor_table) ) + { + l2tab = map_domain_page( + pagetable_get_pfn(d->vcpu[0]->arch.monitor_table)); l2e = l2tab[l2_table_offset(va)]; if ( !(l2e_get_flags(l2e) & _PAGE_PRESENT) ) { page = alloc_domheap_page(NULL); - if ( !l1tab ) - unmap_domain_page(l1tab); l1tab = map_domain_page(page_to_mfn(page)); memset(l1tab, 0, PAGE_SIZE); l2e = l2tab[l2_table_offset(va)] = l2e_from_page(page, __PAGE_HYPERVISOR); } - else if ( l1tab == NULL) + else l1tab = map_domain_page(l2e_get_pfn(l2e)); + } + else + { + page = alloc_domheap_page(NULL); + + l1tab = map_domain_page(page_to_mfn(page)); + memset(l1tab, 0, PAGE_SIZE); + d->arch.phys_table = mk_pagetable(page_to_maddr(page)); + } + + list_ent = d->page_list.next; + + for ( i = 0; list_ent != &d->page_list; i++ ) + { + page = list_entry(list_ent, struct page_info, list); + pfn = page_to_mfn(page); l1e = l1tab[l1_table_offset(va)]; if ( !(l1e_get_flags(l1e) & _PAGE_PRESENT) ) { page = alloc_domheap_page(NULL); - if ( !l0tab ) + if ( l0tab ) unmap_domain_page(l0tab); l0tab = map_domain_page(page_to_mfn(page)); memset(l0tab, 0, PAGE_SIZE ); @@ -910,7 +916,8 @@ va += sizeof(pfn); } - unmap_domain_page(l2tab); + if (l2tab) + unmap_domain_page(l2tab); unmap_domain_page(l1tab); unmap_domain_page(l0tab); @@ -1582,14 +1589,7 @@ __func__, d->domain_id, gpfn, l1_pgentry_val(l1e) >> PAGE_SHIFT, tabpfn, l2e, l1tab, l1e); #endif - if ( !(l1e_get_flags(l1e) & _PAGE_PRESENT) ) - { - printk("%s(d->id=%d, gpfn=%lx) => 0 l1e=%" PRIpte "\n", - __func__, d->domain_id, gpfn, l1e_get_intpte(l1e)); - return INVALID_MFN; - } - - return l1e_get_pfn(l1e); + return l1e_get_intpte(l1e); } static unsigned long @@ -1704,6 +1704,7 @@ { unsigned long hl2mfn; + ASSERT(pagetable_get_paddr(d->arch.phys_table)); spl2e[l2_table_offset(RO_MPT_VIRT_START)] = l2e_from_paddr(pagetable_get_paddr(d->arch.phys_table), __PAGE_HYPERVISOR); _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |