[PATCH] Add support for default env and mounting /boot to BeagleBoard

Premi, Sanjeev premi at ti.com
Thu Feb 9 09:54:28 EST 2012


> -----Original Message-----
> From: barebox-bounces at lists.infradead.org 
> [mailto:barebox-bounces at lists.infradead.org] On Behalf Of 
> Robert P. J. Day
> Sent: Thursday, February 09, 2012 7:10 PM
> To: U-Boot Version 2 (barebox)
> Subject: [PATCH] Add support for default env and mounting 
> /boot to BeagleBoard
> 
> 
> Stealing shamelessly from the panda/board.c file, add equivalent
> support for checking for the default environment and automounting the
> /boot partition on the SD card.
> 
> Also, include the necessary header files for this, and fix the
> filename reference at the top of the file.
> 
> Signed-off-by: Robert P. J. Day <rpjday at crashcourse.ca>
> 
> ---
> 
>   a quick and dirty theft of code from panda/board.c, it builds and
> boots and appears to work.  thoughts?
> 
> diff --git a/arch/arm/boards/beagle/board.c 
> b/arch/arm/boards/beagle/board.c
> index faeaf8e..6825ef2 100644
> --- a/arch/arm/boards/beagle/board.c
> +++ b/arch/arm/boards/beagle/board.c
> @@ -27,7 +27,7 @@
>  /**
>   * @page ti_beagle Texas Instruments Beagle Board
>   *
> - * FileName: arch/arm/boards/omap/board-beagle.c
> + * FileName: arch/arm/boards/beagle/board.c
>   *
>   * Beagle Board from Texas Instruments as described here:
>   * http://www.beagleboard.org
> @@ -55,6 +55,7 @@
>  #include <common.h>
>  #include <console.h>
>  #include <init.h>
> +#include <fs.h>
>  #include <driver.h>
>  #include <sizes.h>
>  #include <io.h>
> @@ -72,8 +73,10 @@
>  #include <mach/ehci.h>
>  #include <i2c/i2c.h>
>  #include <linux/err.h>
> +#include <linux/stat.h>
>  #include <usb/ehci.h>
>  #include <mach/xload.h>
> +#include <environment.h>
> 
>  /******************** Board Boot Time *******************/
> 
> @@ -317,3 +320,30 @@ static int beagle_devices_init(void)
>  	return 0;
>  }
>  device_initcall(beagle_devices_init);
> +
> +#ifdef CONFIG_DEFAULT_ENVIRONMENT
> +static int beagle_env_init(void)
> +{
> +	struct stat s;
> +	char *diskdev = "/dev/disk0.0";
> +	int ret;
> +
> +	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/bareboxenv";
> +
> +	return 0;
> +}
> +late_initcall(beagle_env_init);
> +#endif

Keeping this sequence, in init scripts makes things more & easily configurable.

~sanjeev


More information about the barebox mailing list