]> git.proxmox.com Git - qemu.git/commitdiff
hw/vexpress.c: Allow >4GB of RAM for Cortex-A15 daughterboard
authorPeter Maydell <peter.maydell@linaro.org>
Fri, 20 Jul 2012 12:34:50 +0000 (13:34 +0100)
committerPeter Maydell <peter.maydell@linaro.org>
Fri, 20 Jul 2012 12:34:50 +0000 (13:34 +0100)
Now that we have LPAE support and can handle passing 64 bit
RAM sizes to Linux via the device tree, we can lift the
restriction in the Versatile Express A15 daughterboard model
on not having more than 2GB of RAM. Allow up to 30GB, which
is the maximum that can fit in the address map before running
into the (unmodelled) aliases of the first 2GB.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
hw/vexpress.c

index 8072c5ada96f2081ff65e24e9a235b7b649c647b..b2dc8a5ab329c735b3f26770469d351cef113203 100644 (file)
@@ -284,9 +284,16 @@ static void a15_daughterboard_init(const VEDBoardInfo *daughterboard,
         cpu_irq[n] = irqp[ARM_PIC_CPU_IRQ];
     }
 
-    if (ram_size > 0x80000000) {
-        fprintf(stderr, "vexpress-a15: cannot model more than 2GB RAM\n");
-        exit(1);
+    {
+        /* We have to use a separate 64 bit variable here to avoid the gcc
+         * "comparison is always false due to limited range of data type"
+         * warning if we are on a host where ram_addr_t is 32 bits.
+         */
+        uint64_t rsz = ram_size;
+        if (rsz > (30ULL * 1024 * 1024 * 1024)) {
+            fprintf(stderr, "vexpress-a15: cannot model more than 30GB RAM\n");
+            exit(1);
+        }
     }
 
     memory_region_init_ram(ram, "vexpress.highmem", ram_size);