x86/xen: require ballooned pages for grant maps
authorJennifer Herbert <jennifer.herbert@citrix.com>
Wed, 24 Dec 2014 14:03:16 +0000 (14:03 +0000)
committerDavid Vrabel <david.vrabel@citrix.com>
Wed, 28 Jan 2015 14:03:11 +0000 (14:03 +0000)
Ballooned pages are always used for grant maps which means the
original frame does not need to be saved in page->index nor restored
after the grant unmap.

This allows the workaround in netback for the conflicting use of the
(unionized) page->index and page->pfmemalloc to be removed.

Signed-off-by: Jennifer Herbert <jennifer.herbert@citrix.com>
Reviewed-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
arch/x86/xen/p2m.c
drivers/net/xen-netback/netback.c

index c9bc53f64359b921c76a777d2b3280af71eecb57..a8691cb084201fd243345696e3e00eb18c3d9bf7 100644 (file)
@@ -682,9 +682,10 @@ int set_foreign_p2m_mapping(struct gnttab_map_grant_ref *map_ops,
                pfn = page_to_pfn(pages[i]);
 
                WARN_ON(PagePrivate(pages[i]));
+               WARN(pfn_to_mfn(pfn) != INVALID_P2M_ENTRY, "page must be ballooned");
+
                SetPagePrivate(pages[i]);
                set_page_private(pages[i], mfn);
-               pages[i]->index = pfn_to_mfn(pfn);
 
                if (unlikely(!set_phys_to_machine(pfn, FOREIGN_FRAME(mfn)))) {
                        ret = -ENOMEM;
@@ -718,7 +719,7 @@ int clear_foreign_p2m_mapping(struct gnttab_unmap_grant_ref *unmap_ops,
                set_page_private(pages[i], INVALID_P2M_ENTRY);
                WARN_ON(!PagePrivate(pages[i]));
                ClearPagePrivate(pages[i]);
-               set_phys_to_machine(pfn, pages[i]->index);
+               set_phys_to_machine(pfn, INVALID_P2M_ENTRY);
        }
        if (kunmap_ops)
                ret = HYPERVISOR_grant_table_op(GNTTABOP_unmap_grant_ref,
index 908e65e9b8219783ae4b99e5d06e4701478c830d..64413189ad06e4a8d84094484b3c1197c5ebd028 100644 (file)
@@ -1241,12 +1241,6 @@ static void xenvif_fill_frags(struct xenvif_queue *queue, struct sk_buff *skb)
                /* Take an extra reference to offset network stack's put_page */
                get_page(queue->mmap_pages[pending_idx]);
        }
-       /* FIXME: __skb_fill_page_desc set this to true because page->pfmemalloc
-        * overlaps with "index", and "mapping" is not set. I think mapping
-        * should be set. If delivered to local stack, it would drop this
-        * skb in sk_filter unless the socket has the right to use it.
-        */
-       skb->pfmemalloc = false;
 }
 
 static int xenvif_get_extras(struct xenvif_queue *queue,