On 02/11/2013 11:10 AM, Gleb Natapov wrote:
Upstream test device does not implement port 0xd1.

I remember sending a similar patch a while ago, but it seems like it didn't get applied.

One thing that does occur to me - we will have to keep testing RHEL5, RHEL6 and Fedora with their old test devices. This change seems backwards compatible, since instead of using port 0xd1 we're getting RAM size from the firmware, which should work for both cases.

Given all that, this patch looks good to me. ACK.

Reviewed-by: Lucas Meneghel Rodrigues <l...@redhat.com>

Signed-off-by: Gleb Natapov <g...@redhat.com>
diff --git a/lib/x86/vm.c b/lib/x86/vm.c
index 71b70fd..2852c6c 100644
--- a/lib/x86/vm.c
+++ b/lib/x86/vm.c
@@ -1,3 +1,4 @@
+#include "fwcfg.h"
  #include "vm.h"
  #include "libcflat.h"

@@ -185,16 +186,9 @@ static void setup_mmu(unsigned long len)
      printf("cr4 = %x\n", read_cr4());
  }

-static unsigned int inl(unsigned short port)
-{
-    unsigned int val;
-    asm volatile("inl %w1, %0" : "=a"(val) : "Nd"(port));
-    return val;
-}
-
  void setup_vm()
  {
-    end_of_memory = inl(0xd1);
+    end_of_memory = fwcfg_get_u64(FW_CFG_RAM_SIZE);
      free_memory(&edata, end_of_memory - (unsigned long)&edata);
      setup_mmu(end_of_memory);
  }
diff --git a/x86/rmap_chain.c b/x86/rmap_chain.c
index 9add9b8..0df1bcb 100644
--- a/x86/rmap_chain.c
+++ b/x86/rmap_chain.c
@@ -1,6 +1,7 @@
  /* test long rmap chains */

  #include "libcflat.h"
+#include "fwcfg.h"
  #include "vm.h"
  #include "smp.h"

@@ -21,7 +22,7 @@ int main (void)

      setup_vm();

-    nr_pages = inl(0xd1) / PAGE_SIZE;
+    nr_pages = fwcfg_get_u64(FW_CFG_RAM_SIZE) / PAGE_SIZE;
      nr_pages -= 1000;
      target_page = alloc_page();

--
                        Gleb.


--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to