On 15:38 Mon 21 Jan , Jean-Christophe PLAGNIOL-VILLARD wrote: > Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@xxxxxxxxxxxx> > --- > Hi, > > just compiled not tested Sascha can you test it on panda or beagle? Best Regards, J. > .../configs/am335x_beaglebone_mlo_small_defconfig | 2 + > arch/arm/configs/archosg9_xload_defconfig | 2 + > arch/arm/configs/omap3530_beagle_xload_defconfig | 3 + > arch/arm/configs/panda_xload_defconfig | 2 + > arch/arm/configs/pcm049_xload_defconfig | 3 + > arch/arm/configs/phycard_a_l1_xload_defconfig | 3 + > arch/arm/configs/phycard_a_xl2_xload_defconfig | 3 + > arch/arm/mach-omap/xload.c | 292 +++++--------------- > 8 files changed, 88 insertions(+), 222 deletions(-) > rewrite arch/arm/mach-omap/xload.c (70%) > > diff --git a/arch/arm/configs/am335x_beaglebone_mlo_small_defconfig b/arch/arm/configs/am335x_beaglebone_mlo_small_defconfig > index 886dad9..91c18a5 100644 > --- a/arch/arm/configs/am335x_beaglebone_mlo_small_defconfig > +++ b/arch/arm/configs/am335x_beaglebone_mlo_small_defconfig > @@ -29,3 +29,5 @@ CONFIG_MCI_OMAP_HSMMC=y > # CONFIG_FS_DEVFS is not set > CONFIG_FS_FAT=y > CONFIG_FS_FAT_LFN=y > +CONFIG_BOOTSTRAP=y > +CONFIG_BOOTSTRAP_DISK=y > diff --git a/arch/arm/configs/archosg9_xload_defconfig b/arch/arm/configs/archosg9_xload_defconfig > index 6c6782f..26de57e 100644 > --- a/arch/arm/configs/archosg9_xload_defconfig > +++ b/arch/arm/configs/archosg9_xload_defconfig > @@ -22,3 +22,5 @@ CONFIG_DRIVER_SERIAL_OMAP4_USBBOOT=y > # CONFIG_FS_RAMFS is not set > # CONFIG_FS_DEVFS is not set > CONFIG_FS_OMAP4_USBBOOT=y > +CONFIG_BOOTSTRAP=y > +CONFIG_BOOTSTRAP_DISK=y > diff --git a/arch/arm/configs/omap3530_beagle_xload_defconfig b/arch/arm/configs/omap3530_beagle_xload_defconfig > index d951b1c..2164208 100644 > --- a/arch/arm/configs/omap3530_beagle_xload_defconfig > +++ b/arch/arm/configs/omap3530_beagle_xload_defconfig > @@ -36,3 +36,6 @@ CONFIG_MCI_OMAP_HSMMC=y > # CONFIG_FS_RAMFS is not set > # CONFIG_FS_DEVFS is not set > CONFIG_FS_FAT=y > +CONFIG_BOOTSTRAP=y > +CONFIG_BOOTSTRAP_DEVFS=y > +CONFIG_BOOTSTRAP_DISK=y > diff --git a/arch/arm/configs/panda_xload_defconfig b/arch/arm/configs/panda_xload_defconfig > index fec09ce..84cebbf 100644 > --- a/arch/arm/configs/panda_xload_defconfig > +++ b/arch/arm/configs/panda_xload_defconfig > @@ -25,3 +25,5 @@ CONFIG_MCI_OMAP_HSMMC=y > # CONFIG_FS_RAMFS is not set > # CONFIG_FS_DEVFS is not set > CONFIG_FS_FAT=y > +CONFIG_BOOTSTRAP=y > +CONFIG_BOOTSTRAP_DISK=y > diff --git a/arch/arm/configs/pcm049_xload_defconfig b/arch/arm/configs/pcm049_xload_defconfig > index b6d3a7a..44f9194 100644 > --- a/arch/arm/configs/pcm049_xload_defconfig > +++ b/arch/arm/configs/pcm049_xload_defconfig > @@ -39,3 +39,6 @@ CONFIG_MCI_OMAP_HSMMC=y > # CONFIG_FS_RAMFS is not set > # CONFIG_FS_DEVFS is not set > CONFIG_FS_FAT=y > +CONFIG_BOOTSTRAP=y > +CONFIG_BOOTSTRAP_DEVFS=y > +CONFIG_BOOTSTRAP_DISK=y > diff --git a/arch/arm/configs/phycard_a_l1_xload_defconfig b/arch/arm/configs/phycard_a_l1_xload_defconfig > index 30253cb..d1e3bed 100644 > --- a/arch/arm/configs/phycard_a_l1_xload_defconfig > +++ b/arch/arm/configs/phycard_a_l1_xload_defconfig > @@ -41,3 +41,6 @@ CONFIG_MCI_OMAP_HSMMC=y > # CONFIG_FS_RAMFS is not set > # CONFIG_FS_DEVFS is not set > CONFIG_FS_FAT=y > +CONFIG_BOOTSTRAP=y > +CONFIG_BOOTSTRAP_DEVFS=y > +CONFIG_BOOTSTRAP_DISK=y > diff --git a/arch/arm/configs/phycard_a_xl2_xload_defconfig b/arch/arm/configs/phycard_a_xl2_xload_defconfig > index 7975220..d6b5daa 100644 > --- a/arch/arm/configs/phycard_a_xl2_xload_defconfig > +++ b/arch/arm/configs/phycard_a_xl2_xload_defconfig > @@ -39,3 +39,6 @@ CONFIG_MCI_OMAP_HSMMC=y > # CONFIG_FS_RAMFS is not set > # CONFIG_FS_DEVFS is not set > CONFIG_FS_FAT=y > +CONFIG_BOOTSTRAP=y > +CONFIG_BOOTSTRAP_DEVFS=y > +CONFIG_BOOTSTRAP_DISK=y > diff --git a/arch/arm/mach-omap/xload.c b/arch/arm/mach-omap/xload.c > dissimilarity index 70% > index 41533a9..c02e37e 100644 > --- a/arch/arm/mach-omap/xload.c > +++ b/arch/arm/mach-omap/xload.c > @@ -1,222 +1,70 @@ > -#include <common.h> > -#include <partition.h> > -#include <nand.h> > -#include <init.h> > -#include <driver.h> > -#include <linux/mtd/mtd.h> > -#include <fs.h> > -#include <fcntl.h> > -#include <mach/xload.h> > -#include <sizes.h> > -#include <filetype.h> > - > -static void *read_image_head(const char *name) > -{ > - void *header = xmalloc(ARM_HEAD_SIZE); > - struct cdev *cdev; > - int ret; > - > - cdev = cdev_open(name, O_RDONLY); > - if (!cdev) { > - printf("failed to open partition\n"); > - return NULL; > - } > - > - ret = cdev_read(cdev, header, ARM_HEAD_SIZE, 0, 0); > - cdev_close(cdev); > - > - if (ret != ARM_HEAD_SIZE) { > - printf("failed to read from partition\n"); > - return NULL; > - } > - > - return header; > -} > - > -static unsigned int get_image_size(void *head) > -{ > - unsigned int ret = 0; > - unsigned int *psize = head + ARM_HEAD_SIZE_OFFSET; > - > - if (is_barebox_arm_head(head)) > - ret = *psize; > - debug("Detected barebox image size %u\n", ret); > - > - return ret; > -} > - > -static void *omap_xload_boot_nand(int offset) > -{ > - int ret; > - int size; > - void *to, *header; > - struct cdev *cdev; > - > - devfs_add_partition("nand0", offset, SZ_1M, DEVFS_PARTITION_FIXED, "x"); > - dev_add_bb_dev("x", "bbx"); > - > - header = read_image_head("bbx"); > - if (header == NULL) > - return NULL; > - > - size = get_image_size(header); > - if (!size) { > - printf("failed to get image size\n"); > - return NULL; > - } > - > - to = xmalloc(size); > - > - cdev = cdev_open("bbx", O_RDONLY); > - if (!cdev) { > - printf("failed to open nand\n"); > - return NULL; > - } > - > - ret = cdev_read(cdev, to, size, 0, 0); > - if (ret != size) { > - printf("failed to read from nand\n"); > - return NULL; > - } > - > - return to; > -} > - > -static void *omap_xload_boot_mmc(void) > -{ > - int ret; > - void *buf; > - int len; > - const char *diskdev = "disk0.0"; > - > - ret = mount(diskdev, "fat", "/"); > - if (ret) { > - printf("Unable to mount %s (%d)\n", diskdev, ret); > - return NULL; > - } > - > - buf = read_file("/barebox.bin", &len); > - if (!buf) { > - printf("could not read barebox.bin from sd card\n"); > - return NULL; > - } > - > - return buf; > -} > - > -static void *omap_xload_boot_spi(int offset) > -{ > - int ret; > - int size; > - void *to, *header; > - struct cdev *cdev; > - > - devfs_add_partition("m25p0", offset, SZ_1M, DEVFS_PARTITION_FIXED, "x"); > - > - header = read_image_head("x"); > - if (header == NULL) > - return NULL; > - > - size = get_image_size(header); > - if (!size) { > - printf("failed to get image size\n"); > - return NULL; > - } > - > - to = xmalloc(size); > - > - cdev = cdev_open("x", O_RDONLY); > - if (!cdev) { > - printf("failed to open spi flash\n"); > - return NULL; > - } > - > - ret = cdev_read(cdev, to, size, 0, 0); > - if (ret != size) { > - printf("failed to read from spi flash\n"); > - return NULL; > - } > - > - return to; > -} > - > -static void *omap4_xload_boot_usb(void){ > - int ret; > - void *buf; > - int len; > - > - ret = mount("omap4_usbboot", "omap4_usbbootfs", "/"); > - if (ret) { > - printf("Unable to mount omap4_usbbootfs (%d)\n", ret); > - return NULL; > - } > - > - buf = read_file("/barebox.bin", &len); > - if (!buf) > - printf("could not read barebox.bin from omap4_usbbootfs\n"); > - > - return buf; > -} > - > -enum omap_boot_src omap_bootsrc(void) > -{ > -#if defined(CONFIG_ARCH_OMAP3) > - return omap3_bootsrc(); > -#elif defined(CONFIG_ARCH_OMAP4) > - return omap4_bootsrc(); > -#elif defined(CONFIG_ARCH_AM33XX) > - return am33xx_bootsrc(); > -#endif > -} > - > -/* > - * Replaces the default shell in xload configuration > - */ > -static __noreturn int omap_xload(void) > -{ > - int (*func)(void) = NULL; > - > - switch (omap_bootsrc()) > - { > - case OMAP_BOOTSRC_MMC1: > - printf("booting from MMC1\n"); > - func = omap_xload_boot_mmc(); > - break; > - case OMAP_BOOTSRC_USB1: > - if (IS_ENABLED(CONFIG_FS_OMAP4_USBBOOT)) { > - printf("booting from USB1\n"); > - func = omap4_xload_boot_usb(); > - break; > - } else { > - printf("booting from usb1 not enabled\n"); > - } > - case OMAP_BOOTSRC_UNKNOWN: > - printf("unknown boot source. Fall back to nand\n"); > - case OMAP_BOOTSRC_NAND: > - printf("booting from NAND\n"); > - func = omap_xload_boot_nand(SZ_128K); > - break; > - case OMAP_BOOTSRC_SPI1: > - printf("booting from SPI1\n"); > - func = omap_xload_boot_spi(SZ_128K); > - break; > - } > - > - if (!func) { > - printf("booting failed\n"); > - while (1); > - } > - > - shutdown_barebox(); > - func(); > - > - while (1); > -} > - > -static int omap_set_xload(void) > -{ > - barebox_main = omap_xload; > - > - return 0; > -} > -late_initcall(omap_set_xload); > +#include <common.h> > +#include <partition.h> > +#include <nand.h> > +#include <init.h> > +#include <driver.h> > +#include <linux/mtd/mtd.h> > +#include <fs.h> > +#include <fcntl.h> > +#include <mach/xload.h> > +#include <sizes.h> > +#include <filetype.h> > +#include <bootstrap.h> > + > +enum omap_boot_src omap_bootsrc(void) > +{ > +#if defined(CONFIG_ARCH_OMAP3) > + return omap3_bootsrc(); > +#elif defined(CONFIG_ARCH_OMAP4) > + return omap4_bootsrc(); > +#elif defined(CONFIG_ARCH_AM33XX) > + return am33xx_bootsrc(); > +#endif > +} > + > +/* > + * Replaces the default shell in xload configuration > + */ > +static __noreturn int omap_xload(void) > +{ > + int (*func)(void) = NULL; > + > + switch (omap_bootsrc()) > + { > + case OMAP_BOOTSRC_MMC1: > + printf("booting from MMC1\n"); > + func = bootstrap_read_disk("disk0.0", NULL); > + break; > + case OMAP_BOOTSRC_USB1: > + if (IS_ENABLED(CONFIG_FS_OMAP4_USBBOOT)) { > + printf("booting from USB1\n"); > + func = bootstrap_read_disk("omap4_usbboot", "omap4_usbbootfs"); > + break; > + } else { > + printf("booting from usb1 not enabled\n"); > + } > + case OMAP_BOOTSRC_UNKNOWN: > + printf("unknown boot source. Fall back to nand\n"); > + case OMAP_BOOTSRC_NAND: > + printf("booting from NAND\n"); > + func = bootstrap_read_devfs("nand0", true, SZ_128K, SZ_256K, SZ_1M); > + break; > + case OMAP_BOOTSRC_SPI1: > + printf("booting from SPI1\n"); > + func = bootstrap_read_devfs("m25p0", false, SZ_128K, SZ_256K, SZ_1M); > + break; > + } > + > + bootstrap_boot(func, false); > + bootstrap_err("... failed\n"); > + > + while (1); > +} > + > +static int omap_set_xload(void) > +{ > + barebox_main = omap_xload; > + > + return 0; > +} > +late_initcall(omap_set_xload); > -- > 1.7.10.4 > _______________________________________________ barebox mailing list barebox@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/barebox