[PATCH 2/2] ARM: rpi_b: use bcm2835 mbox driver to get memory size

Stephen Warren swarren at wwwdotorg.org
Tue Oct 16 01:10:36 EDT 2012


The firmware running on the bcm2835 SoC's VideoCore CPU determines how
much of the system RAM is available for use by the ARM CPU. Previously,
U-Boot assumed that only 128MB was available, since this was the
smallest value configured by any public firmware. However, we can now
query the actual value at run-time from the firmware using the mbox
property protocol.

Signed-off-by: Stephen Warren <swarren at wwwdotorg.org>
---
 board/raspberrypi/rpi_b/rpi_b.c |   20 +++++++++++++++++++-
 1 file changed, 19 insertions(+), 1 deletion(-)

diff --git a/board/raspberrypi/rpi_b/rpi_b.c b/board/raspberrypi/rpi_b/rpi_b.c
index 688b0aa..88f8c58 100644
--- a/board/raspberrypi/rpi_b/rpi_b.c
+++ b/board/raspberrypi/rpi_b/rpi_b.c
@@ -15,13 +15,31 @@
  */
 
 #include <common.h>
+#include <asm/arch/mbox.h>
 #include <asm/global_data.h>
 
 DECLARE_GLOBAL_DATA_PTR;
 
 int dram_init(void)
 {
-	gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
+	ALLOC_ALIGN_BUFFER(struct bcm2835_mbox_buf_get_arm_mem, buf, 1, 16);
+
+	memset(buf, 0, sizeof(*buf));
+	buf->hdr.buf_size = sizeof(*buf);
+	buf->hdr.code = BCM2835_MBOX_REQ_CODE;
+	buf->tag_hdr.tag = BCM2835_MBOX_TAG_GET_ARM_MEMORY;
+	buf->tag_hdr.val_buf_size = sizeof(buf->body);
+	buf->tag_hdr.val_len = sizeof(buf->body.req);
+
+	bcm2835_mbox_call_prop(BCM2835_MBOX_PROP_CHAN, &buf->hdr);
+
+	if ((buf->hdr.code != BCM2835_MBOX_RESP_CODE_SUCCESS) ||
+	    (!(buf->tag_hdr.val_len & BCM2835_MBOX_TAG_VAL_LEN_RESPONSE))) {
+		printf("BCM2835_MBOX_TAG_GET_ARM_MEMORY failed\n");
+		return -1;
+	}
+
+	gd->ram_size = buf->body.resp.mem_size;
 
 	return 0;
 }
-- 
1.7.9.5




More information about the linux-rpi-kernel mailing list