| # HG changeset patch
# User Keir Fraser <keir.fraser@xxxxxxxxxx>
# Date 1261992759 0
# Node ID cba7ef4d08a3a3a31fe29b706878a7475c3d03b2
# Parent  4ad86f682f430428d5f9c7877259b8b951ff95e0
grant_table: Build fixes for IA64.
Signed-off-by: Keir Fraser <keir.fraser@xxxxxxxxxx>
---
 xen/common/grant_table.c |   39 +++++++++++++++++++++++++--------------
 1 files changed, 25 insertions(+), 14 deletions(-)
diff -r 4ad86f682f43 -r cba7ef4d08a3 xen/common/grant_table.c
--- a/xen/common/grant_table.c  Mon Dec 28 09:14:16 2009 +0000
+++ b/xen/common/grant_table.c  Mon Dec 28 09:32:39 2009 +0000
@@ -105,8 +105,17 @@ static unsigned inline int max_nr_maptra
     return (max_nr_grant_frames * MAX_MAPTRACK_TO_GRANTS_RATIO);
 }
 
-#define gfn_to_mfn_private(_d, _gfn, _p2mt) \
-    mfn_x(gfn_to_mfn_unshare(_d, _gfn, _p2mt, 1)) 
+#ifdef CONFIG_X86
+#define gfn_to_mfn_private(_d, _gfn) ({                     \
+    p2m_type_t __p2mt;                                      \
+    unsigned long __x;                                      \
+    __x = mfn_x(gfn_to_mfn_unshare(_d, _gfn, &__p2mt, 1));  \
+    if ( !p2m_is_valid(__p2mt) )                            \
+        __x = INVALID_MFN;                                  \
+    __x; })
+#else
+#define gfn_to_mfn_private(_d, _gfn) gmfn_to_mfn(rd, act->gfn)
+#endif
 
 #define SHGNT_PER_PAGE_V1 (PAGE_SIZE / sizeof(grant_entry_v1_t))
 #define shared_entry_v1(t, e) \
@@ -495,8 +504,6 @@ __gnttab_map_grant_ref(
 
         if ( !act->pin )
         {
-            p2m_type_t p2mt;
-
             act->domid = ld->domain_id;
             if ( sha1 )
                 act->gfn = sha1->frame;
@@ -504,7 +511,7 @@ __gnttab_map_grant_ref(
                 act->gfn = sha2->full_page.frame;
             act->frame = (op->flags & GNTMAP_readonly) ?  
                             gmfn_to_mfn(rd, act->gfn) :
-                            gfn_to_mfn_private(rd, act->gfn, &p2mt); 
+                            gfn_to_mfn_private(rd, act->gfn); 
             act->start = 0;
             act->length = PAGE_SIZE;
             act->is_sub_page = 0;
@@ -1371,7 +1378,6 @@ gnttab_transfer(
     struct gnttab_transfer gop;
     unsigned long mfn;
     unsigned int max_bitsize;
-    p2m_type_t p2mt;
 
     for ( i = 0; i < count; i++ )
     {
@@ -1386,7 +1392,7 @@ gnttab_transfer(
             return -EFAULT;
         }
 
-        mfn = gfn_to_mfn_private(d, gop.mfn, &p2mt);
+        mfn = gfn_to_mfn_private(d, gop.mfn);
 
         /* Check the passed page frame for basic validity. */
         if ( unlikely(!mfn_valid(mfn)) )
@@ -1657,7 +1663,6 @@ __acquire_grant_for_copy(
     int is_sub_page;
     struct domain *ignore;
     s16 rc = GNTST_okay;
-    p2m_type_t p2mt;
 
     *owning_domain = NULL;
 
@@ -1771,7 +1776,7 @@ __acquire_grant_for_copy(
         {
             act->gfn = sha1->frame;
             grant_frame = readonly ? gmfn_to_mfn(rd, act->gfn) :
-                                     gfn_to_mfn_private(rd, act->gfn, &p2mt);
+                                     gfn_to_mfn_private(rd, act->gfn);
             is_sub_page = 0;
             trans_page_off = 0;
             trans_length = PAGE_SIZE;
@@ -1781,7 +1786,7 @@ __acquire_grant_for_copy(
         {
             act->gfn = sha2->full_page.frame;
             grant_frame = readonly ? gmfn_to_mfn(rd, act->gfn) :
-                                     gfn_to_mfn_private(rd, act->gfn, &p2mt);
+                                     gfn_to_mfn_private(rd, act->gfn);
             is_sub_page = 0;
             trans_page_off = 0;
             trans_length = PAGE_SIZE;
@@ -1791,7 +1796,7 @@ __acquire_grant_for_copy(
         {
             act->gfn = sha2->sub_page.frame;
             grant_frame = readonly ? gmfn_to_mfn(rd, act->gfn) :
-                                     gfn_to_mfn_private(rd, act->gfn, &p2mt);
+                                     gfn_to_mfn_private(rd, act->gfn);
             is_sub_page = 1;
             trans_page_off = sha2->sub_page.page_off;
             trans_length = sha2->sub_page.length;
@@ -1886,6 +1891,7 @@ __gnttab_copy(
     }
     else
     {
+#ifdef CONFIG_X86
         p2m_type_t p2mt;
         s_frame = mfn_x(gfn_to_mfn(sd, op->source.u.gmfn, &p2mt));
         if ( !p2m_is_valid(p2mt) )
@@ -1893,10 +1899,12 @@ __gnttab_copy(
         if ( p2m_is_paging(p2mt) )
         {
             p2m_mem_paging_populate(sd, op->source.u.gmfn);
-
             rc = -ENOENT;
             goto error_out;
         }
+#else
+        s_frame = gmfn_to_mfn(sd, op->source.u.gmfn);        
+#endif
         source_domain = sd;
     }
     if ( unlikely(!mfn_valid(s_frame)) )
@@ -1929,17 +1937,20 @@ __gnttab_copy(
     }
     else
     {
+#ifdef CONFIG_X86
         p2m_type_t p2mt;
-        d_frame = gfn_to_mfn_private(dd, op->dest.u.gmfn, &p2mt);
+        d_frame = mfn_x(gfn_to_mfn_unshare(dd, op->dest.u.gmfn, &p2mt, 1));
         if ( !p2m_is_valid(p2mt) )
           d_frame = INVALID_MFN;
         if ( p2m_is_paging(p2mt) )
         {
             p2m_mem_paging_populate(dd, op->dest.u.gmfn);
-
             rc = -ENOENT;
             goto error_out;
         }
+#else
+        d_frame = gmfn_to_mfn(dd, op->dest.u.gmfn);
+#endif
         dest_domain = dd;
     }
     if ( unlikely(!mfn_valid(d_frame)) )
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog
 |