diff options
Diffstat (limited to 'meta/recipes-bsp/u-boot')
6 files changed, 310 insertions, 0 deletions
diff --git a/meta/recipes-bsp/u-boot/files/0001-am335x_evm.h-Add-use-DEFAULT_LINUX_BOOT_ENV-environm.patch b/meta/recipes-bsp/u-boot/files/0001-am335x_evm.h-Add-use-DEFAULT_LINUX_BOOT_ENV-environm.patch new file mode 100644 index 0000000000..77e35bbc7c --- /dev/null +++ b/meta/recipes-bsp/u-boot/files/0001-am335x_evm.h-Add-use-DEFAULT_LINUX_BOOT_ENV-environm.patch | |||
@@ -0,0 +1,74 @@ | |||
1 | From 5701384cea4a829b772bf7a96a74825b58c22385 Mon Sep 17 00:00:00 2001 | ||
2 | From: Denys Dmytriyenko <denys@ti.com> | ||
3 | Date: Thu, 17 Apr 2014 12:25:40 -0400 | ||
4 | Subject: [PATCH] am335x_evm.h: Add, use DEFAULT_LINUX_BOOT_ENV environment | ||
5 | string | ||
6 | |||
7 | Modified version of the patch currently being reviewed for mainline: | ||
8 | http://patchwork.ozlabs.org/patch/334861/ | ||
9 | |||
10 | To deal with a reoccurring problem properly we need to specify addresses | ||
11 | for the Linux kernel, Flatted Device Tree and ramdisk that obey the | ||
12 | constraints within the kernel's Documentation/arm/Booting file but also | ||
13 | make sure that we relocate things within a valid address range. | ||
14 | |||
15 | Signed-off-by: Denys Dmytriyenko <denys@ti.com> | ||
16 | Signed-off-by: Tom Rini <trini@ti.com> | ||
17 | |||
18 | Upstream-Status: Pending | ||
19 | --- | ||
20 | include/configs/am335x_evm.h | 31 ++++++++++++++++++++++++++----- | ||
21 | 1 file changed, 26 insertions(+), 5 deletions(-) | ||
22 | |||
23 | diff --git a/include/configs/am335x_evm.h b/include/configs/am335x_evm.h | ||
24 | index c5a6d4b..01e32b3 100644 | ||
25 | --- a/include/configs/am335x_evm.h | ||
26 | +++ b/include/configs/am335x_evm.h | ||
27 | @@ -54,10 +54,7 @@ | ||
28 | #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG | ||
29 | #ifndef CONFIG_SPL_BUILD | ||
30 | #define CONFIG_EXTRA_ENV_SETTINGS \ | ||
31 | - "loadaddr=0x80200000\0" \ | ||
32 | - "fdtaddr=0x80F80000\0" \ | ||
33 | - "fdt_high=0xffffffff\0" \ | ||
34 | - "rdaddr=0x81000000\0" \ | ||
35 | + DEFAULT_LINUX_BOOT_ENV \ | ||
36 | "bootdir=/boot\0" \ | ||
37 | "bootfile=uImage\0" \ | ||
38 | "fdtfile=undefined\0" \ | ||
39 | @@ -197,7 +194,31 @@ | ||
40 | #define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_MEMTEST_START \ | ||
41 | + (8 * 1024 * 1024)) | ||
42 | |||
43 | -#define CONFIG_SYS_LOAD_ADDR 0x81000000 /* Default load address */ | ||
44 | +/* | ||
45 | + * Our DDR memory always starts at 0x80000000 and U-Boot shall have | ||
46 | + * relocated itself to higher in memory by the time this value is used. | ||
47 | + * However, set this to a 32MB offset to allow for easier Linux kernel | ||
48 | + * booting as the default is often used as the kernel load address. | ||
49 | + */ | ||
50 | +#define CONFIG_SYS_LOAD_ADDR 0x82000000 /* Default load address */ | ||
51 | + | ||
52 | +/* | ||
53 | + * We setup defaults based on constraints from the Linux kernel, which should | ||
54 | + * also be safe elsewhere. We have the default load at 32MB into DDR (for | ||
55 | + * the kernel), FDT above 128MB (the maximum location for the end of the | ||
56 | + * kernel), and the ramdisk 512KB above that (allowing for hopefully never | ||
57 | + * seen large trees). We say all of this must be within the first 256MB | ||
58 | + * as that will normally be within the kernel lowmem and thus visible via | ||
59 | + * bootm_size and we only run on platforms with 256MB or more of memory. | ||
60 | + */ | ||
61 | +#define DEFAULT_LINUX_BOOT_ENV \ | ||
62 | + "loadaddr=0x82000000\0" \ | ||
63 | + "kernel_addr_r=0x82000000\0" \ | ||
64 | + "fdtaddr=0x88000000\0" \ | ||
65 | + "fdt_addr_r=0x88000000\0" \ | ||
66 | + "rdaddr=0x88080000\0" \ | ||
67 | + "ramdisk_addr_r=0x88080000\0" \ | ||
68 | + "bootm_size=0x10000000\0" | ||
69 | |||
70 | #define CONFIG_MMC | ||
71 | #define CONFIG_GENERIC_MMC | ||
72 | -- | ||
73 | 1.9.2 | ||
74 | |||
diff --git a/meta/recipes-bsp/u-boot/u-boot-fw-utils-cross_2013.07.bb b/meta/recipes-bsp/u-boot/u-boot-fw-utils-cross_2013.07.bb new file mode 100644 index 0000000000..d686b33621 --- /dev/null +++ b/meta/recipes-bsp/u-boot/u-boot-fw-utils-cross_2013.07.bb | |||
@@ -0,0 +1,38 @@ | |||
1 | SUMMARY = "U-Boot bootloader fw_printenv/setenv utilities" | ||
2 | LICENSE = "GPLv2+" | ||
3 | LIC_FILES_CHKSUM = "file://COPYING;md5=1707d6db1d42237583f50183a5651ecb" | ||
4 | SECTION = "bootloader" | ||
5 | DEPENDS = "mtd-utils" | ||
6 | |||
7 | # This revision corresponds to the tag "v2013.07" | ||
8 | # We use the revision in order to avoid having to fetch it from the | ||
9 | # repo during parse | ||
10 | SRCREV = "62c175fbb8a0f9a926c88294ea9f7e88eb898f6c" | ||
11 | |||
12 | PV = "v2013.07+git${SRCPV}" | ||
13 | |||
14 | SRC_URI = "git://git.denx.de/u-boot.git;branch=master;protocol=git" | ||
15 | |||
16 | S = "${WORKDIR}/git" | ||
17 | |||
18 | inherit uboot-config cross | ||
19 | |||
20 | EXTRA_OEMAKE = 'CROSS_COMPILE=${TARGET_PREFIX} CC="${TARGET_PREFIX}gcc ${TOOLCHAIN_OPTIONS}"' | ||
21 | |||
22 | do_compile () { | ||
23 | oe_runmake ${UBOOT_MACHINE} | ||
24 | oe_runmake env | ||
25 | } | ||
26 | |||
27 | do_install () { | ||
28 | install -d ${D}${bindir_cross} | ||
29 | install -m 755 ${S}/tools/env/fw_printenv ${D}${bindir_cross}/fw_printenv | ||
30 | install -m 755 ${S}/tools/env/fw_printenv ${D}${bindir_cross}/fw_setenv | ||
31 | } | ||
32 | |||
33 | SYSROOT_PREPROCESS_FUNCS = "uboot_fw_utils_cross" | ||
34 | uboot_fw_utils_cross() { | ||
35 | sysroot_stage_dir ${D}${bindir_cross} ${SYSROOT_DESTDIR}${bindir_cross} | ||
36 | } | ||
37 | |||
38 | PACKAGE_ARCH = "${MACHINE_ARCH}" | ||
diff --git a/meta/recipes-bsp/u-boot/u-boot-fw-utils_2013.07.bb b/meta/recipes-bsp/u-boot/u-boot-fw-utils_2013.07.bb new file mode 100644 index 0000000000..8bab432a76 --- /dev/null +++ b/meta/recipes-bsp/u-boot/u-boot-fw-utils_2013.07.bb | |||
@@ -0,0 +1,35 @@ | |||
1 | SUMMARY = "U-Boot bootloader fw_printenv/setenv utilities" | ||
2 | LICENSE = "GPLv2+" | ||
3 | LIC_FILES_CHKSUM = "file://COPYING;md5=1707d6db1d42237583f50183a5651ecb" | ||
4 | SECTION = "bootloader" | ||
5 | DEPENDS = "mtd-utils" | ||
6 | |||
7 | # This revision corresponds to the tag "v2013.07" | ||
8 | # We use the revision in order to avoid having to fetch it from the | ||
9 | # repo during parse | ||
10 | SRCREV = "62c175fbb8a0f9a926c88294ea9f7e88eb898f6c" | ||
11 | |||
12 | PV = "v2013.07+git${SRCPV}" | ||
13 | |||
14 | SRC_URI = "git://git.denx.de/u-boot.git;branch=master;protocol=git" | ||
15 | |||
16 | S = "${WORKDIR}/git" | ||
17 | |||
18 | EXTRA_OEMAKE = 'HOSTCC="${CC}" HOSTSTRIP="true"' | ||
19 | |||
20 | inherit uboot-config | ||
21 | |||
22 | do_compile () { | ||
23 | oe_runmake ${UBOOT_MACHINE} | ||
24 | oe_runmake env | ||
25 | } | ||
26 | |||
27 | do_install () { | ||
28 | install -d ${D}${base_sbindir} | ||
29 | install -d ${D}${sysconfdir} | ||
30 | install -m 755 ${S}/tools/env/fw_printenv ${D}${base_sbindir}/fw_printenv | ||
31 | install -m 755 ${S}/tools/env/fw_printenv ${D}${base_sbindir}/fw_setenv | ||
32 | install -m 0644 ${S}/tools/env/fw_env.config ${D}${sysconfdir}/fw_env.config | ||
33 | } | ||
34 | |||
35 | PACKAGE_ARCH = "${MACHINE_ARCH}" | ||
diff --git a/meta/recipes-bsp/u-boot/u-boot-mkimage_2013.07.bb b/meta/recipes-bsp/u-boot/u-boot-mkimage_2013.07.bb new file mode 100644 index 0000000000..3173b0ac73 --- /dev/null +++ b/meta/recipes-bsp/u-boot/u-boot-mkimage_2013.07.bb | |||
@@ -0,0 +1,32 @@ | |||
1 | SUMMARY = "U-Boot bootloader image creation tool" | ||
2 | LICENSE = "GPLv2+" | ||
3 | LIC_FILES_CHKSUM = "file://COPYING;md5=1707d6db1d42237583f50183a5651ecb" | ||
4 | SECTION = "bootloader" | ||
5 | |||
6 | # This revision corresponds to the tag "v2013.07" | ||
7 | # We use the revision in order to avoid having to fetch it from the | ||
8 | # repo during parse | ||
9 | SRCREV = "62c175fbb8a0f9a926c88294ea9f7e88eb898f6c" | ||
10 | |||
11 | PV = "v2013.07+git${SRCPV}" | ||
12 | |||
13 | SRC_URI = "git://git.denx.de/u-boot.git;branch=master;protocol=git" | ||
14 | |||
15 | S = "${WORKDIR}/git" | ||
16 | |||
17 | EXTRA_OEMAKE = 'HOSTCC="${CC}" HOSTLD="${LD}" HOSTLDFLAGS="${LDFLAGS}" HOSTSTRIP=true' | ||
18 | |||
19 | do_compile () { | ||
20 | # Make sure the recompile is OK | ||
21 | rm -f ${B}/tools/.depend | ||
22 | |||
23 | oe_runmake tools | ||
24 | } | ||
25 | |||
26 | do_install () { | ||
27 | install -d ${D}${bindir} | ||
28 | install -m 0755 tools/mkimage ${D}${bindir}/uboot-mkimage | ||
29 | ln -sf uboot-mkimage ${D}${bindir}/mkimage | ||
30 | } | ||
31 | |||
32 | BBCLASSEXTEND = "native nativesdk" | ||
diff --git a/meta/recipes-bsp/u-boot/u-boot.inc b/meta/recipes-bsp/u-boot/u-boot.inc new file mode 100644 index 0000000000..602b71f39d --- /dev/null +++ b/meta/recipes-bsp/u-boot/u-boot.inc | |||
@@ -0,0 +1,122 @@ | |||
1 | SUMMARY = "Universal Boot Loader for embedded devices" | ||
2 | HOMEPAGE = "http://www.denx.de/wiki/U-Boot/WebHome" | ||
3 | SECTION = "bootloaders" | ||
4 | PROVIDES = "virtual/bootloader" | ||
5 | |||
6 | LICENSE = "GPLv2+" | ||
7 | LIC_FILES_CHKSUM = "file://COPYING;md5=1707d6db1d42237583f50183a5651ecb \ | ||
8 | file://README;beginline=1;endline=22;md5=78b195c11cb6ef63e6985140db7d7bab" | ||
9 | |||
10 | SRC_URI = "git://git.denx.de/u-boot.git;branch=master" | ||
11 | |||
12 | S = "${WORKDIR}/git" | ||
13 | |||
14 | PACKAGE_ARCH = "${MACHINE_ARCH}" | ||
15 | |||
16 | inherit uboot-config deploy | ||
17 | |||
18 | EXTRA_OEMAKE = 'CROSS_COMPILE=${TARGET_PREFIX} CC="${TARGET_PREFIX}gcc ${TOOLCHAIN_OPTIONS}"' | ||
19 | |||
20 | # Allow setting an additional version string that will be picked up by the | ||
21 | # u-boot build system and appended to the u-boot version. If the .scmversion | ||
22 | # file already exists it will not be overwritten. | ||
23 | UBOOT_LOCALVERSION ?= "" | ||
24 | |||
25 | # Some versions of u-boot use .bin and others use .img. By default use .bin | ||
26 | # but enable individual recipes to change this value. | ||
27 | UBOOT_SUFFIX ?= "bin" | ||
28 | UBOOT_IMAGE ?= "u-boot-${MACHINE}-${PV}-${PR}.${UBOOT_SUFFIX}" | ||
29 | UBOOT_BINARY ?= "u-boot.${UBOOT_SUFFIX}" | ||
30 | UBOOT_SYMLINK ?= "u-boot-${MACHINE}.${UBOOT_SUFFIX}" | ||
31 | UBOOT_MAKE_TARGET ?= "all" | ||
32 | |||
33 | # Some versions of u-boot build an SPL (Second Program Loader) image that | ||
34 | # should be packaged along with the u-boot binary as well as placed in the | ||
35 | # deploy directory. For those versions they can set the following variables | ||
36 | # to allow packaging the SPL. | ||
37 | SPL_BINARY ?= "" | ||
38 | SPL_IMAGE ?= "${SPL_BINARY}-${MACHINE}-${PV}-${PR}" | ||
39 | SPL_SYMLINK ?= "${SPL_BINARY}-${MACHINE}" | ||
40 | |||
41 | # Additional environment variables or a script can be installed alongside | ||
42 | # u-boot to be used automatically on boot. This file, typically 'uEnv.txt' | ||
43 | # or 'boot.scr', should be packaged along with u-boot as well as placed in the | ||
44 | # deploy directory. Machine configurations needing one of these files should | ||
45 | # include it in the SRC_URI and set the UBOOT_ENV parameter. | ||
46 | UBOOT_ENV_SUFFIX ?= "txt" | ||
47 | UBOOT_ENV ?= "" | ||
48 | UBOOT_ENV_BINARY ?= "${UBOOT_ENV}.${UBOOT_ENV_SUFFIX}" | ||
49 | UBOOT_ENV_IMAGE ?= "${UBOOT_ENV}-${MACHINE}-${PV}-${PR}.${UBOOT_ENV_SUFFIX}" | ||
50 | UBOOT_ENV_SYMLINK ?= "${UBOOT_ENV}-${MACHINE}.${UBOOT_ENV_SUFFIX}" | ||
51 | |||
52 | do_compile () { | ||
53 | if [ "${@bb.utils.contains('DISTRO_FEATURES', 'ld-is-gold', 'ld-is-gold', '', d)}" = "ld-is-gold" ] ; then | ||
54 | sed -i 's/$(CROSS_COMPILE)ld$/$(CROSS_COMPILE)ld.bfd/g' config.mk | ||
55 | fi | ||
56 | |||
57 | unset LDFLAGS | ||
58 | unset CFLAGS | ||
59 | unset CPPFLAGS | ||
60 | |||
61 | if [ ! -e ${B}/.scmversion -a ! -e ${S}/.scmversion ] | ||
62 | then | ||
63 | echo ${UBOOT_LOCALVERSION} > ${B}/.scmversion | ||
64 | echo ${UBOOT_LOCALVERSION} > ${S}/.scmversion | ||
65 | fi | ||
66 | |||
67 | oe_runmake ${UBOOT_MACHINE} | ||
68 | oe_runmake ${UBOOT_MAKE_TARGET} | ||
69 | } | ||
70 | |||
71 | do_install () { | ||
72 | install -d ${D}/boot | ||
73 | install ${S}/${UBOOT_BINARY} ${D}/boot/${UBOOT_IMAGE} | ||
74 | ln -sf ${UBOOT_IMAGE} ${D}/boot/${UBOOT_BINARY} | ||
75 | |||
76 | if [ -e ${WORKDIR}/fw_env.config ] ; then | ||
77 | install -d ${D}${sysconfdir} | ||
78 | install -m 644 ${WORKDIR}/fw_env.config ${D}${sysconfdir}/fw_env.config | ||
79 | fi | ||
80 | |||
81 | if [ "x${SPL_BINARY}" != "x" ] | ||
82 | then | ||
83 | install ${S}/${SPL_BINARY} ${D}/boot/${SPL_IMAGE} | ||
84 | ln -sf ${SPL_IMAGE} ${D}/boot/${SPL_BINARY} | ||
85 | fi | ||
86 | |||
87 | if [ "x${UBOOT_ENV}" != "x" ] | ||
88 | then | ||
89 | install ${WORKDIR}/${UBOOT_ENV_BINARY} ${D}/boot/${UBOOT_ENV_IMAGE} | ||
90 | ln -sf ${UBOOT_ENV_IMAGE} ${D}/boot/${UBOOT_ENV_BINARY} | ||
91 | fi | ||
92 | } | ||
93 | |||
94 | FILES_${PN} = "/boot ${sysconfdir}" | ||
95 | |||
96 | do_deploy () { | ||
97 | install -d ${DEPLOYDIR} | ||
98 | install ${S}/${UBOOT_BINARY} ${DEPLOYDIR}/${UBOOT_IMAGE} | ||
99 | |||
100 | cd ${DEPLOYDIR} | ||
101 | rm -f ${UBOOT_BINARY} ${UBOOT_SYMLINK} | ||
102 | ln -sf ${UBOOT_IMAGE} ${UBOOT_SYMLINK} | ||
103 | ln -sf ${UBOOT_IMAGE} ${UBOOT_BINARY} | ||
104 | |||
105 | if [ "x${SPL_BINARY}" != "x" ] | ||
106 | then | ||
107 | install ${S}/${SPL_BINARY} ${DEPLOYDIR}/${SPL_IMAGE} | ||
108 | rm -f ${DEPLOYDIR}/${SPL_BINARY} ${DEPLOYDIR}/${SPL_SYMLINK} | ||
109 | ln -sf ${SPL_IMAGE} ${DEPLOYDIR}/${SPL_BINARY} | ||
110 | ln -sf ${SPL_IMAGE} ${DEPLOYDIR}/${SPL_SYMLINK} | ||
111 | fi | ||
112 | |||
113 | if [ "x${UBOOT_ENV}" != "x" ] | ||
114 | then | ||
115 | install ${WORKDIR}/${UBOOT_ENV_BINARY} ${DEPLOYDIR}/${UBOOT_ENV_IMAGE} | ||
116 | rm -f ${DEPLOYDIR}/${UBOOT_ENV_BINARY} ${DEPLOYDIR}/${UBOOT_ENV_SYMLINK} | ||
117 | ln -sf ${UBOOT_ENV_IMAGE} ${DEPLOYDIR}/${UBOOT_ENV_BINARY} | ||
118 | ln -sf ${UBOOT_ENV_IMAGE} ${DEPLOYDIR}/${UBOOT_ENV_SYMLINK} | ||
119 | fi | ||
120 | } | ||
121 | |||
122 | addtask deploy before do_build after do_compile | ||
diff --git a/meta/recipes-bsp/u-boot/u-boot_2013.07.bb b/meta/recipes-bsp/u-boot/u-boot_2013.07.bb new file mode 100644 index 0000000000..f07fd7c567 --- /dev/null +++ b/meta/recipes-bsp/u-boot/u-boot_2013.07.bb | |||
@@ -0,0 +1,9 @@ | |||
1 | require u-boot.inc | ||
2 | |||
3 | # This revision corresponds to the tag "v2013.07" | ||
4 | # We use the revision in order to avoid having to fetch it from the repo during parse | ||
5 | SRCREV = "62c175fbb8a0f9a926c88294ea9f7e88eb898f6c" | ||
6 | |||
7 | PV = "v2013.07+git${SRCPV}" | ||
8 | |||
9 | SRC_URI += "file://0001-am335x_evm.h-Add-use-DEFAULT_LINUX_BOOT_ENV-environm.patch" | ||