diff options
author | Sascha Hauer <s.hauer@pengutronix.de> | 2013-10-15 12:48:53 +0200 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2013-10-16 09:45:31 +0200 |
commit | 297661763584f6e22470b9225b0f2494b1abc6c0 (patch) | |
tree | fcc5e90443d7bd8a8a153e08a996614621431fa0 /arch/arm/boards/raspberry-pi | |
parent | 16dd5e5603e281710f7f5a260bcdd16bd43bb5a8 (diff) | |
download | barebox-297661763584f6e22470b9225b0f2494b1abc6c0.tar.gz barebox-297661763584f6e22470b9225b0f2494b1abc6c0.tar.xz |
ARM: rpi: add SD card environment support
Similar to the OMAP boards mount the SD card to /boot and expect
the environment as /boot/barebox.env
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'arch/arm/boards/raspberry-pi')
-rw-r--r-- | arch/arm/boards/raspberry-pi/rpi.c | 33 |
1 files changed, 31 insertions, 2 deletions
diff --git a/arch/arm/boards/raspberry-pi/rpi.c b/arch/arm/boards/raspberry-pi/rpi.c index d4912ccdc7..971a603bf0 100644 --- a/arch/arm/boards/raspberry-pi/rpi.c +++ b/arch/arm/boards/raspberry-pi/rpi.c @@ -15,6 +15,9 @@ #include <common.h> #include <init.h> +#include <fs.h> +#include <linux/stat.h> +#include <envfs.h> #include <asm/armlinux.h> #include <generated/mach-types.h> @@ -37,11 +40,37 @@ static int rpi_console_init(void) } console_initcall(rpi_console_init); +static int rpi_env_init(void) +{ + struct stat s; + const char *diskdev = "/dev/disk0.0"; + int ret; + + device_detect_by_name("mci0"); + + ret = stat(diskdev, &s); + if (ret) { + printf("no %s. using default env\n", diskdev); + return 0; + } + + mkdir("/boot", 0666); + ret = mount(diskdev, "fat", "/boot"); + if (ret) { + printf("failed to mount %s\n", diskdev); + return 0; + } + + default_environment_path = "/boot/barebox.env"; + + return 0; +} + static int rpi_devices_init(void) { armlinux_set_architecture(MACH_TYPE_BCM2708); armlinux_set_bootparams((void *)(0x00000100)); + rpi_env_init(); return 0; } - -device_initcall(rpi_devices_init); +late_initcall(rpi_devices_init); |