diff options
Diffstat (limited to 'recipes-bsp')
-rw-r--r-- | recipes-bsp/apptrk/apptrk_git.bb | 1 | ||||
-rw-r--r-- | recipes-bsp/boot-format/boot-format/flags.patch | 21 | ||||
-rw-r--r-- | recipes-bsp/boot-format/boot-format_git.bb | 20 | ||||
-rw-r--r-- | recipes-bsp/ipc/ipc-ust_git.bb | 50 | ||||
-rw-r--r-- | recipes-bsp/ipc/ipc.inc | 7 | ||||
-rw-r--r-- | recipes-bsp/pkc-firmware/pkc-firmware_git.bb | 41 | ||||
-rw-r--r-- | recipes-bsp/qe-ucode/qe-ucode_git.bb | 2 | ||||
-rw-r--r-- | recipes-bsp/rcw/rcw_git.bb | 2 | ||||
-rw-r--r-- | recipes-bsp/u-boot/files/0001-u-boot-mpc85xx-u-boot-.lds-remove-_GLOBAL_OFFSET_TAB.patch | 77 | ||||
-rw-r--r-- | recipes-bsp/u-boot/files/Fix-the-depend-race-issue.patch | 38 | ||||
-rw-r--r-- | recipes-bsp/u-boot/u-boot-qoriq_2015.01.bb | 189 |
11 files changed, 446 insertions, 2 deletions
diff --git a/recipes-bsp/apptrk/apptrk_git.bb b/recipes-bsp/apptrk/apptrk_git.bb index 4453cf87..1d251070 100644 --- a/recipes-bsp/apptrk/apptrk_git.bb +++ b/recipes-bsp/apptrk/apptrk_git.bb | |||
@@ -18,6 +18,7 @@ S = "${WORKDIR}/git" | |||
18 | EXTRA_OEMAKE = "" | 18 | EXTRA_OEMAKE = "" |
19 | 19 | ||
20 | CFLAGS += " -I${STAGING_INCDIR}" | 20 | CFLAGS += " -I${STAGING_INCDIR}" |
21 | CFLAGS_append_powerpc64 = " -DENABLE_64BIT_SUPPORT" | ||
21 | 22 | ||
22 | do_install() { | 23 | do_install() { |
23 | oe_runmake install DESTDIR=${D} | 24 | oe_runmake install DESTDIR=${D} |
diff --git a/recipes-bsp/boot-format/boot-format/flags.patch b/recipes-bsp/boot-format/boot-format/flags.patch new file mode 100644 index 00000000..cddb34cd --- /dev/null +++ b/recipes-bsp/boot-format/boot-format/flags.patch | |||
@@ -0,0 +1,21 @@ | |||
1 | Index: git/Makefile | ||
2 | =================================================================== | ||
3 | --- git.orig/Makefile | ||
4 | +++ git/Makefile | ||
5 | @@ -3,14 +3,14 @@ | ||
6 | INSTALL=install | ||
7 | PREFIX=/usr | ||
8 | |||
9 | -CFLAGS=-Wall | ||
10 | +override CFLAGS+=-Wall | ||
11 | |||
12 | all: boot_format | ||
13 | |||
14 | boot_format.o: boot_format.c boot_format.h | ||
15 | |||
16 | boot_format: boot_format.o | ||
17 | - $(CC) $< -o $@ | ||
18 | + $(CC) $(CFLAGS) $< -o $@ $(LDFLAGS) | ||
19 | |||
20 | install: boot_format | ||
21 | $(INSTALL) -d $(DESTDIR)$(PREFIX)/bin | ||
diff --git a/recipes-bsp/boot-format/boot-format_git.bb b/recipes-bsp/boot-format/boot-format_git.bb new file mode 100644 index 00000000..2d9f9b1d --- /dev/null +++ b/recipes-bsp/boot-format/boot-format_git.bb | |||
@@ -0,0 +1,20 @@ | |||
1 | DESCRIPTION = "Boot format utility for booting from eSDHC/eSPI" | ||
2 | LICENSE = "GPLv2" | ||
3 | PR = "r6" | ||
4 | LIC_FILES_CHKSUM = "file://COPYING;md5=b234ee4d69f5fce4486a80fdaf4a4263" | ||
5 | |||
6 | SRC_URI = "git://git.freescale.com/ppc/sdk/boot-format.git;nobranch=1 \ | ||
7 | file://flags.patch" | ||
8 | SRCREV = "4eb81a6797ef4e58bf7d9b2d58afb37a21c1f550" | ||
9 | |||
10 | S = "${WORKDIR}/git" | ||
11 | EXTRA_OEMAKE = 'CC="${CC}" CFLAGS="${CFLAGS}" LDFLAGS="${LDFLAGS}"' | ||
12 | |||
13 | do_install(){ | ||
14 | oe_runmake DESTDIR=${D} PREFIX=${prefix} install | ||
15 | } | ||
16 | |||
17 | PACKAGES =+ "${PN}-config" | ||
18 | FILES_${PN}-config += "${datadir}/*" | ||
19 | |||
20 | BBCLASSEXTEND = "native nativesdk" | ||
diff --git a/recipes-bsp/ipc/ipc-ust_git.bb b/recipes-bsp/ipc/ipc-ust_git.bb new file mode 100644 index 00000000..c6b3cfe6 --- /dev/null +++ b/recipes-bsp/ipc/ipc-ust_git.bb | |||
@@ -0,0 +1,50 @@ | |||
1 | SUMMARY = "Linux IPC Userspace Tool" | ||
2 | DESCRIPTION = "DSP boot application and ipc test application" | ||
3 | LICENSE = "BSD" | ||
4 | LIC_FILES_CHKSUM = "file://COPYING;md5=fa38cd73d71527dc6efb546474f64d10" | ||
5 | |||
6 | require ipc.inc | ||
7 | |||
8 | S = "${WORKDIR}/git" | ||
9 | |||
10 | # workaround for issue of parallel build, required a actual fix in ipc source | ||
11 | PARALLEL_MAKE = "" | ||
12 | |||
13 | EXTRA_OEMAKE = 'CROSS_COMPILE="${TARGET_PREFIX}" CC="${CC}" AR="${AR}"' | ||
14 | |||
15 | do_compile () { | ||
16 | case ${MACHINE} in | ||
17 | bsc9132qds|bsc9131rdb) SOC=B913x;; | ||
18 | b4860qds|b4420qds|b4860qds-64b) SOC=B4860;; | ||
19 | esac | ||
20 | oe_runmake ${SOC}=1 | ||
21 | } | ||
22 | |||
23 | do_install () { | ||
24 | install -d ${D}${bindir} | ||
25 | install -d ${D}${includedir} | ||
26 | install -d ${D}/ipc | ||
27 | install -m 755 ${S}/dsp_boot/dsp_bt ${D}/ipc | ||
28 | install -m 755 ${S}/ipc/ipc_test ${D}/ipc | ||
29 | install -m 755 ${S}/ipc/ipc_test67 ${D}/ipc | ||
30 | install -m 755 ${S}/ipc/l1d_app ${D}/ipc | ||
31 | install -m 755 ${S}/fsl_shm/app ${D}${bindir}/lg_shm_test | ||
32 | install -d ${D}${base_libdir} | ||
33 | install -m 755 ${S}/ipc/libipc.so ${D}${base_libdir} | ||
34 | install -m 755 ${S}/ipc/libmem.so ${D}${base_libdir} | ||
35 | install -m 755 ${S}/ipc/libdspboot.so ${D}${base_libdir} | ||
36 | install -d ${D}${includedir}/ipc | ||
37 | install -d ${D}${includedir}/ipc/ipc/include | ||
38 | install -d ${D}${includedir}/ipc/fsl_shm/lib | ||
39 | install ${S}/ipc/include/*.h ${D}${includedir}/ipc/ipc/include | ||
40 | install ${S}/dsp_boot/*.h ${D}${includedir}/ipc/ipc/include | ||
41 | install ${S}/kernel/fsl_ipc_types.h ${D}${includedir}/ipc/ipc/include | ||
42 | install ${S}/kernel/fsl_heterogeneous_common.h ${D}${includedir}/ipc/ipc/include | ||
43 | install ${S}/kernel/fsl_heterogeneous_l1_defense.h ${D}${includedir}/ipc/ipc/include | ||
44 | install ${S}/fsl_shm/include/*.h ${D}${includedir}/ipc/ipc/include | ||
45 | install ${S}/fsl_shm/lib/*.h ${D}${includedir}/ipc/fsl_shm/lib | ||
46 | } | ||
47 | |||
48 | FILES_${PN} += "/ipc/*" | ||
49 | FILES_${PN}-dbg += "/ipc/.debug" | ||
50 | |||
diff --git a/recipes-bsp/ipc/ipc.inc b/recipes-bsp/ipc/ipc.inc new file mode 100644 index 00000000..547771ae --- /dev/null +++ b/recipes-bsp/ipc/ipc.inc | |||
@@ -0,0 +1,7 @@ | |||
1 | DEPENDS = "virtual/kernel" | ||
2 | |||
3 | SRC_URI = "git://git.freescale.com/ppc/sdk/ipc.git;nobranch=1" | ||
4 | SRCREV = "c9c92ac6a7a31c9d878096eb7d135c22a38f20ff" | ||
5 | |||
6 | COMPATIBLE_MACHINE = "(bsc9132qds|bsc9131rdb|b4860qds|b4420qds)" | ||
7 | |||
diff --git a/recipes-bsp/pkc-firmware/pkc-firmware_git.bb b/recipes-bsp/pkc-firmware/pkc-firmware_git.bb new file mode 100644 index 00000000..3cc5d446 --- /dev/null +++ b/recipes-bsp/pkc-firmware/pkc-firmware_git.bb | |||
@@ -0,0 +1,41 @@ | |||
1 | DESCRIPTION = "U-boot firmware for c293pcie support " | ||
2 | HOMEPAGE = "http://u-boot.sf.net" | ||
3 | LICENSE = "GPLv2" | ||
4 | LIC_FILES_CHKSUM = "file://COPYING;md5=1707d6db1d42237583f50183a5651ecb" | ||
5 | |||
6 | INHIBIT_DEFAULT_DEPS = "1" | ||
7 | DEPENDS = "virtual/${TARGET_PREFIX}gcc libgcc" | ||
8 | |||
9 | inherit deploy | ||
10 | |||
11 | PACKAGE_ARCH = "${MACHINE_ARCH}" | ||
12 | |||
13 | SRC_URI = "git://git.freescale.com/ppc/sdk/pkc-firmware.git;nobranch=1" | ||
14 | SRCREV = "b891873c1eea7a7d53f9472ea601712897cb17b7" | ||
15 | |||
16 | S = "${WORKDIR}/git" | ||
17 | |||
18 | EXTRA_OEMAKE = 'CROSS_COMPILE=${TARGET_PREFIX} CC="${TARGET_PREFIX}gcc ${TOOLCHAIN_OPTIONS}"' | ||
19 | |||
20 | do_compile () { | ||
21 | unset LDFLAGS | ||
22 | unset CFLAGS | ||
23 | unset CPPFLAGS | ||
24 | oe_runmake C293QDS_36BIT_SDCARD | ||
25 | } | ||
26 | |||
27 | do_install(){ | ||
28 | install -d ${D}${sysconfdir}/crypto/ | ||
29 | install ${S}/u-boot.bin ${D}${sysconfdir}/crypto/pkc-firmware.bin | ||
30 | } | ||
31 | |||
32 | do_deploy(){ | ||
33 | install -d ${DEPLOYDIR}/pkc-firmware | ||
34 | install ${S}/u-boot.bin ${DEPLOYDIR}/pkc-firmware/pkc-firmware.bin | ||
35 | } | ||
36 | |||
37 | addtask deploy after do_install | ||
38 | |||
39 | FILES_{PN} += "/etc/crypto/pkc-firmware.bin" | ||
40 | COMPATIBLE_MACHINE = "(c293pcie)" | ||
41 | |||
diff --git a/recipes-bsp/qe-ucode/qe-ucode_git.bb b/recipes-bsp/qe-ucode/qe-ucode_git.bb index 28af4b65..395789d9 100644 --- a/recipes-bsp/qe-ucode/qe-ucode_git.bb +++ b/recipes-bsp/qe-ucode/qe-ucode_git.bb | |||
@@ -33,4 +33,4 @@ addtask deploy before do_build after do_install | |||
33 | PACKAGES += "${PN}-image" | 33 | PACKAGES += "${PN}-image" |
34 | FILES_${PN}-image += "/boot/*" | 34 | FILES_${PN}-image += "/boot/*" |
35 | ALLOW_EMPTY_${PN} = "1" | 35 | ALLOW_EMPTY_${PN} = "1" |
36 | COMPATIBLE_MACHINE = "(ls102xa)" | 36 | COMPATIBLE_MACHINE = "(ls102xa|p1021rdb|p1025twr|t1)" |
diff --git a/recipes-bsp/rcw/rcw_git.bb b/recipes-bsp/rcw/rcw_git.bb index 2a03309c..016ef820 100644 --- a/recipes-bsp/rcw/rcw_git.bb +++ b/recipes-bsp/rcw/rcw_git.bb | |||
@@ -33,4 +33,4 @@ FILES_${PN}-image += "/boot" | |||
33 | ALLOW_EMPTY_${PN} = "1" | 33 | ALLOW_EMPTY_${PN} = "1" |
34 | 34 | ||
35 | PACKAGE_ARCH = "${MACHINE_ARCH}" | 35 | PACKAGE_ARCH = "${MACHINE_ARCH}" |
36 | COMPATIBLE_MACHINE = "(ls102xa)" | 36 | COMPATIBLE_MACHINE = "(ls102xa|qoriq-ppc)" |
diff --git a/recipes-bsp/u-boot/files/0001-u-boot-mpc85xx-u-boot-.lds-remove-_GLOBAL_OFFSET_TAB.patch b/recipes-bsp/u-boot/files/0001-u-boot-mpc85xx-u-boot-.lds-remove-_GLOBAL_OFFSET_TAB.patch new file mode 100644 index 00000000..e6b8d2e5 --- /dev/null +++ b/recipes-bsp/u-boot/files/0001-u-boot-mpc85xx-u-boot-.lds-remove-_GLOBAL_OFFSET_TAB.patch | |||
@@ -0,0 +1,77 @@ | |||
1 | From 9ba002f1b1afc7af84a352f4ecab32a30d7ba353 Mon Sep 17 00:00:00 2001 | ||
2 | From: Zhenhua Luo <zhenhua.luo@freescale.com> | ||
3 | Date: Mon, 9 Feb 2015 18:33:56 +0800 | ||
4 | Subject: [PATCH] u-boot/mpc85xx/u-boot*.lds: remove _GLOBAL_OFFSET_TABLE_ | ||
5 | definition | ||
6 | |||
7 | In binutils-2.25, the _GLOBAL_OFFSET_TABLE_ symbols defined by PROVIDE in | ||
8 | u-boot.lds overrides the linker built-in symbols | ||
9 | (https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;a=commitdiff;h=b893397a4b1316610f49819344817715e4305de9), | ||
10 | so the linker is treating _GLOBAL_OFFSET_TABLE_ as a definition into the .reloc section. | ||
11 | |||
12 | To align with the change of binutils-2.25, the _GLOBAL_OFFSET_TABLE_ symbol | ||
13 | should not be defined in sections, and the symbols in linker generated .got | ||
14 | section should be used(https://sourceware.org/ml/binutils/2008-09/msg00122.html). | ||
15 | |||
16 | Fixed the following build errors with binutils-2.25: | ||
17 | | powerpc-poky-linux-gnuspe-ld.bfd: _GLOBAL_OFFSET_TABLE_ not defined in linker created .got | ||
18 | |||
19 | Signed-off-by: Zhenhua Luo <zhenhua.luo@freescale.com> | ||
20 | --- | ||
21 | arch/powerpc/cpu/mpc85xx/u-boot-nand.lds | 1 - | ||
22 | arch/powerpc/cpu/mpc85xx/u-boot-nand_spl.lds | 1 - | ||
23 | arch/powerpc/cpu/mpc85xx/u-boot-spl.lds | 1 - | ||
24 | arch/powerpc/cpu/mpc85xx/u-boot.lds | 1 - | ||
25 | 4 files changed, 4 deletions(-) | ||
26 | |||
27 | diff --git a/arch/powerpc/cpu/mpc85xx/u-boot-nand.lds b/arch/powerpc/cpu/mpc85xx/u-boot-nand.lds | ||
28 | index f933b21..0399f93 100644 | ||
29 | --- a/arch/powerpc/cpu/mpc85xx/u-boot-nand.lds | ||
30 | +++ b/arch/powerpc/cpu/mpc85xx/u-boot-nand.lds | ||
31 | @@ -44,7 +44,6 @@ SECTIONS | ||
32 | _GOT2_TABLE_ = .; | ||
33 | KEEP(*(.got2)) | ||
34 | KEEP(*(.got)) | ||
35 | - PROVIDE(_GLOBAL_OFFSET_TABLE_ = . + 4); | ||
36 | _FIXUP_TABLE_ = .; | ||
37 | KEEP(*(.fixup)) | ||
38 | } | ||
39 | diff --git a/arch/powerpc/cpu/mpc85xx/u-boot-nand_spl.lds b/arch/powerpc/cpu/mpc85xx/u-boot-nand_spl.lds | ||
40 | index b83c553..f044564 100644 | ||
41 | --- a/arch/powerpc/cpu/mpc85xx/u-boot-nand_spl.lds | ||
42 | +++ b/arch/powerpc/cpu/mpc85xx/u-boot-nand_spl.lds | ||
43 | @@ -22,7 +22,6 @@ SECTIONS | ||
44 | _GOT2_TABLE_ = .; | ||
45 | KEEP(*(.got2)) | ||
46 | KEEP(*(.got)) | ||
47 | - PROVIDE(_GLOBAL_OFFSET_TABLE_ = . + 4); | ||
48 | _FIXUP_TABLE_ = .; | ||
49 | KEEP(*(.fixup)) | ||
50 | } | ||
51 | diff --git a/arch/powerpc/cpu/mpc85xx/u-boot-spl.lds b/arch/powerpc/cpu/mpc85xx/u-boot-spl.lds | ||
52 | index 5ae7b3e..889a4c2 100644 | ||
53 | --- a/arch/powerpc/cpu/mpc85xx/u-boot-spl.lds | ||
54 | +++ b/arch/powerpc/cpu/mpc85xx/u-boot-spl.lds | ||
55 | @@ -29,7 +29,6 @@ SECTIONS | ||
56 | _GOT2_TABLE_ = .; | ||
57 | KEEP(*(.got2)) | ||
58 | KEEP(*(.got)) | ||
59 | - PROVIDE(_GLOBAL_OFFSET_TABLE_ = . + 4); | ||
60 | _FIXUP_TABLE_ = .; | ||
61 | KEEP(*(.fixup)) | ||
62 | } | ||
63 | diff --git a/arch/powerpc/cpu/mpc85xx/u-boot.lds b/arch/powerpc/cpu/mpc85xx/u-boot.lds | ||
64 | index 2cf0b25..f15eaf3 100644 | ||
65 | --- a/arch/powerpc/cpu/mpc85xx/u-boot.lds | ||
66 | +++ b/arch/powerpc/cpu/mpc85xx/u-boot.lds | ||
67 | @@ -50,7 +50,6 @@ SECTIONS | ||
68 | _GOT2_TABLE_ = .; | ||
69 | KEEP(*(.got2)) | ||
70 | KEEP(*(.got)) | ||
71 | - PROVIDE(_GLOBAL_OFFSET_TABLE_ = . + 4); | ||
72 | _FIXUP_TABLE_ = .; | ||
73 | KEEP(*(.fixup)) | ||
74 | } | ||
75 | -- | ||
76 | 2.1.0 | ||
77 | |||
diff --git a/recipes-bsp/u-boot/files/Fix-the-depend-race-issue.patch b/recipes-bsp/u-boot/files/Fix-the-depend-race-issue.patch new file mode 100644 index 00000000..1ddc6675 --- /dev/null +++ b/recipes-bsp/u-boot/files/Fix-the-depend-race-issue.patch | |||
@@ -0,0 +1,38 @@ | |||
1 | Upstream-Status: Pending | ||
2 | |||
3 | From 301832414369b749918e0d5db850eed19b81c0fc Mon Sep 17 00:00:00 2001 | ||
4 | From: Zhenhua Luo <zhenhua.luo@freescale.com> | ||
5 | Date: Tue, 24 Sep 2013 00:54:40 -0500 | ||
6 | Subject: [PATCH] Fix the depend race issue | ||
7 | |||
8 | | make[3]: Entering directory `/srv/home/pokybuild/yocto-autobuilder-new/yocto-slave/nightly-fsl-ppc/build/build/tmp/work/p1022ds-poky-linux-gnuspe/u-boot/git-r30/git/arch/powerpc/cpu/mpc85xx' | ||
9 | | /srv/home/pokybuild/yocto-autobuilder-new/yocto-slave/nightly-fsl-ppc/build/build/tmp/work/p1022ds-poky-linux-gnuspe/u-boot/git-r30/git/P1022DS_NAND/spl/arch/powerpc/cpu/mpc85xx/.depend:125: *** missing separator. Stop. | ||
10 | | make[3]: Leaving directory `/srv/home/pokybuild/yocto-autobuilder-new/yocto-slave/nightly-fsl-ppc/build/build/tmp/work/p1022ds-poky-linux-gnuspe/u-boot/git-r30/git/arch/powerpc/cpu/mpc85xx' | ||
11 | | make[2]: *** [/srv/home/pokybuild/yocto-autobuilder-new/yocto-slave/nightly-fsl-ppc/build/build/tmp/work/p1022ds-poky-linux-gnuspe/u-boot/git-r30/git/P1022DS_NAND/spl/arch/powerpc/cpu/mpc85xx/start.o] Error 2 | ||
12 | | make[2]: *** Waiting for unfinished jobs.... | ||
13 | |||
14 | Signed-off-by: Zhenhua Luo <zhenhua.luo@freescale.com> | ||
15 | --- | ||
16 | spl/Makefile | 6 +++++- | ||
17 | 1 file changed, 5 insertions(+), 1 deletion(-) | ||
18 | |||
19 | diff --git a/spl/Makefile b/spl/Makefile | ||
20 | index 6dbb105..3156d87 100644 | ||
21 | --- a/spl/Makefile | ||
22 | +++ b/spl/Makefile | ||
23 | @@ -185,7 +185,11 @@ $(eval $(call make_u_boot_list, $(obj)u-boot.lst, $(LIBS))) | ||
24 | $(obj)u-boot-spl.lds: $(LDSCRIPT) $(obj)u-boot.lst depend | ||
25 | $(CPP) $(CPPFLAGS) $(LDPPFLAGS) -I$(obj). -ansi -D__ASSEMBLY__ -P - < $< > $@ | ||
26 | |||
27 | -depend: $(obj).depend | ||
28 | +# Explicitly make _depend in subdirs containing multiple targets to prevent | ||
29 | +# parallel sub-makes creating .depend files simultaneously. | ||
30 | +depend dep: $(obj).depend | ||
31 | + for dir in $(SUBDIRS) $(CPUDIR) $(LDSCRIPT_MAKEFILE_DIR) ; do \ | ||
32 | + $(MAKE) -C $(SRCTREE)/$$dir _depend ; done | ||
33 | .PHONY: depend | ||
34 | |||
35 | # defines $(obj).depend target | ||
36 | -- | ||
37 | 1.8.2.1 | ||
38 | |||
diff --git a/recipes-bsp/u-boot/u-boot-qoriq_2015.01.bb b/recipes-bsp/u-boot/u-boot-qoriq_2015.01.bb new file mode 100644 index 00000000..17c470dc --- /dev/null +++ b/recipes-bsp/u-boot/u-boot-qoriq_2015.01.bb | |||
@@ -0,0 +1,189 @@ | |||
1 | DESCRIPTION = "U-boot bootloader" | ||
2 | HOMEPAGE = "http://u-boot.sf.net" | ||
3 | SECTION = "bootloaders" | ||
4 | PROVIDES = "virtual/bootloader u-boot" | ||
5 | LICENSE = "GPLv2 & BSD-3-Clause & BSD-2-Clause & LGPL-2.0 & LGPL-2.1" | ||
6 | LIC_FILES_CHKSUM = " \ | ||
7 | file://Licenses/gpl-2.0.txt;md5=b234ee4d69f5fce4486a80fdaf4a4263 \ | ||
8 | file://Licenses/bsd-2-clause.txt;md5=6a31f076f5773aabd8ff86191ad6fdd5 \ | ||
9 | file://Licenses/bsd-3-clause.txt;md5=4a1190eac56a9db675d58ebe86eaf50c \ | ||
10 | file://Licenses/lgpl-2.0.txt;md5=5f30f0716dfdd0d91eb439ebec522ec2 \ | ||
11 | file://Licenses/lgpl-2.1.txt;md5=4fbd65380cdd255951079008b364516c \ | ||
12 | " | ||
13 | |||
14 | PV = "2014.07+fslgit" | ||
15 | INHIBIT_DEFAULT_DEPS = "1" | ||
16 | DEPENDS = "boot-format-native libgcc ${@base_contains('TCMODE', 'external-fsl', '', 'virtual/${TARGET_PREFIX}gcc', d)}" | ||
17 | |||
18 | inherit deploy | ||
19 | |||
20 | SRC_URI = "git://git.freescale.com/ppc/sdk/u-boot.git;nobranch=1 \ | ||
21 | file://0001-u-boot-mpc85xx-u-boot-.lds-remove-_GLOBAL_OFFSET_TAB.patch" | ||
22 | SRCREV = "6ba8eedbcdc4b063f59a63e6288b938af739e8ad" | ||
23 | |||
24 | python () { | ||
25 | if d.getVar("TCMODE", True) == "external-fsl": | ||
26 | return | ||
27 | |||
28 | ml = d.getVar("MULTILIB_VARIANTS", True) | ||
29 | arch = d.getVar("OVERRIDES", True) | ||
30 | |||
31 | if "e5500-64b:" in arch or "e6500-64b:" in arch: | ||
32 | if not "lib32" in ml: | ||
33 | raise bb.parse.SkipPackage("Building the u-boot for this arch requires multilib to be enabled") | ||
34 | sys_multilib = 'powerpc' + d.getVar('TARGET_VENDOR') + 'mllib32-' + d.getVar('HOST_OS') | ||
35 | d.setVar('DEPENDS_append', ' lib32-gcc-cross-powerpc lib32-libgcc') | ||
36 | d.setVar('PATH_append', ':' + d.getVar('STAGING_BINDIR_NATIVE') + '/' + sys_multilib) | ||
37 | d.setVar('TOOLCHAIN_OPTIONS_append', '/../lib32-' + d.getVar("MACHINE")) | ||
38 | d.setVar("WRAP_TARGET_PREFIX", sys_multilib + '-') | ||
39 | } | ||
40 | |||
41 | WRAP_TARGET_PREFIX ?= "${TARGET_PREFIX}" | ||
42 | |||
43 | PACKAGE_ARCH = "${MACHINE_ARCH}" | ||
44 | |||
45 | UBOOT_LOCALVERSION = "${@d.getVar('SDK_VERSION', True).partition(' ')[0]}" | ||
46 | |||
47 | USRC ?= "" | ||
48 | S = '${@base_conditional("USRC", "", "${WORKDIR}/git", "${USRC}", d)}' | ||
49 | |||
50 | EXTRA_OEMAKE = 'CROSS_COMPILE=${WRAP_TARGET_PREFIX} CC="${WRAP_TARGET_PREFIX}gcc ${TOOLCHAIN_OPTIONS}"' | ||
51 | |||
52 | do_compile () { | ||
53 | unset LDFLAGS | ||
54 | unset CFLAGS | ||
55 | unset CPPFLAGS | ||
56 | |||
57 | if [ ! -e ${B}/.scmversion -a ! -e ${S}/.scmversion ] | ||
58 | then | ||
59 | head=`git rev-parse --verify --short HEAD 2> /dev/null` | ||
60 | printf "%s%s%s" ${UBOOT_LOCALVERSION} +g $head > ${B}/.scmversion | ||
61 | printf "%s%s%s" ${UBOOT_LOCALVERSION} +g $head > ${S}/.scmversion | ||
62 | fi | ||
63 | |||
64 | if [ "x${UBOOT_MACHINES}" = "x" ]; then | ||
65 | UBOOT_MACHINES=${UBOOT_MACHINE} | ||
66 | fi | ||
67 | |||
68 | python ./tools/genboardscfg.py | ||
69 | for board in ${UBOOT_MACHINES}; do | ||
70 | if ! grep -wq $board ${S}/boards.cfg;then | ||
71 | echo "WARNING: $board not supported in boards.cfg" | ||
72 | continue | ||
73 | fi | ||
74 | |||
75 | oe_runmake O=${board} distclean | ||
76 | oe_runmake O=${board} ${board}_config | ||
77 | oe_runmake O=${board} all | ||
78 | |||
79 | case "${board}" in | ||
80 | *SDCARD*) UBOOT_TARGET="u-boot-sd";; | ||
81 | *SPIFLASH*) UBOOT_TARGET="u-boot-spi";; | ||
82 | *NAND*) UBOOT_TARGET="u-boot-nand";; | ||
83 | *SRIO*) UBOOT_TARGET="u-boot-srio";; | ||
84 | *) UBOOT_TARGET="";; | ||
85 | esac | ||
86 | |||
87 | # deal with sd/spi/nand/srio image | ||
88 | UBOOT_SOURCE=u-boot.bin | ||
89 | if [ "x${UBOOT_TARGET}" != "x" ] && echo $board |egrep -qi "SECBOOT|SECURE"; then | ||
90 | cp ${S}/${board}/${UBOOT_SOURCE} ${S}/${board}/${UBOOT_TARGET}.bin | ||
91 | elif [ "x${UBOOT_TARGET}" != "x" ]; then | ||
92 | # some boards' final binary was not named as u-boot.bin | ||
93 | if [ "${UBOOT_TARGET}" = "u-boot-nand" ];then | ||
94 | if echo $board |egrep -q "^(BSC|C29|P10|P2020RDB)";then | ||
95 | UBOOT_SOURCE=u-boot-with-spl.bin | ||
96 | elif echo $board |egrep -q "^(B4|T1|T2|T4)";then | ||
97 | UBOOT_SOURCE=u-boot-with-spl-pbl.bin | ||
98 | elif echo $board |egrep -q "^(P2041|P3|P4|P5)";then | ||
99 | UBOOT_SOURCE=u-boot.pbl | ||
100 | fi | ||
101 | elif [ "${UBOOT_TARGET}" = "u-boot-spi" ];then | ||
102 | if echo $board |egrep -q "^(P10|P2020RDB)";then | ||
103 | UBOOT_SOURCE=u-boot-with-spl.bin | ||
104 | elif echo $board |egrep -q "^(T1|T2)";then | ||
105 | UBOOT_SOURCE=u-boot-with-spl-pbl.bin | ||
106 | elif echo $board |egrep -q "^(B4|P2041|P3|P4|P5|T4)";then | ||
107 | UBOOT_SOURCE=u-boot.pbl | ||
108 | fi | ||
109 | elif [ "${UBOOT_TARGET}" = "u-boot-sd" ];then | ||
110 | if echo $board |egrep -q "^(P10|P2020RDB)";then | ||
111 | UBOOT_SOURCE=u-boot-with-spl.bin | ||
112 | elif echo $board |egrep -q "^(B4|T1|T2|T4)";then | ||
113 | UBOOT_SOURCE=u-boot-with-spl-pbl.bin | ||
114 | elif echo $board |egrep -q "^(P2041|P3|P4|P5)";then | ||
115 | UBOOT_SOURCE=u-boot.pbl | ||
116 | fi | ||
117 | fi | ||
118 | cp ${S}/${board}/${UBOOT_SOURCE} ${S}/${board}/${UBOOT_TARGET}.bin | ||
119 | |||
120 | # use boot-format to regenerate spi image if BOOTFORMAT_CONFIG is not empty | ||
121 | if [ "${UBOOT_TARGET}" = "u-boot-spi" ] && [ -n "${BOOTFORMAT_CONFIG}" ];then | ||
122 | ${STAGING_BINDIR_NATIVE}/boot_format \ | ||
123 | ${STAGING_DATADIR_NATIVE}/boot_format/${BOOTFORMAT_CONFIG} \ | ||
124 | ${S}/${board}/${UBOOT_SOURCE} -spi ${S}/${board}/${UBOOT_TARGET}.bin | ||
125 | fi | ||
126 | fi | ||
127 | done | ||
128 | } | ||
129 | |||
130 | do_install(){ | ||
131 | if [ "x${UBOOT_MACHINES}" = "x" ]; then | ||
132 | UBOOT_MACHINES=${UBOOT_MACHINE} | ||
133 | fi | ||
134 | |||
135 | for board in ${UBOOT_MACHINES}; do | ||
136 | if ! grep -wq $board ${S}/boards.cfg;then | ||
137 | continue | ||
138 | fi | ||
139 | |||
140 | case "${board}" in | ||
141 | *SDCARD*) UBOOT_TARGET="u-boot-sd";; | ||
142 | *SPIFLASH*) UBOOT_TARGET="u-boot-spi";; | ||
143 | *NAND*) UBOOT_TARGET="u-boot-nand";; | ||
144 | *SRIO*) UBOOT_TARGET="u-boot-srio";; | ||
145 | *) UBOOT_TARGET="u-boot";; | ||
146 | esac | ||
147 | |||
148 | if [ -f ${S}/${board}/${UBOOT_TARGET}.bin ]; then | ||
149 | mkdir -p ${D}/boot/ | ||
150 | install ${S}/${board}/${UBOOT_TARGET}.bin ${D}/boot/${UBOOT_TARGET}-${board}-${PV}-${PR}.bin | ||
151 | ln -sf ${UBOOT_TARGET}-${board}-${PV}-${PR}.bin ${D}/boot/${UBOOT_TARGET}.bin | ||
152 | fi | ||
153 | done | ||
154 | } | ||
155 | |||
156 | do_deploy(){ | ||
157 | if [ "x${UBOOT_MACHINES}" = "x" ]; then | ||
158 | UBOOT_MACHINES=${UBOOT_MACHINE} | ||
159 | fi | ||
160 | |||
161 | for board in ${UBOOT_MACHINES}; do | ||
162 | if ! grep -wq $board ${S}/boards.cfg;then | ||
163 | continue | ||
164 | fi | ||
165 | |||
166 | case "${board}" in | ||
167 | *SDCARD*) UBOOT_TARGET="u-boot-sd";; | ||
168 | *SPIFLASH*) UBOOT_TARGET="u-boot-spi";; | ||
169 | *NAND*) UBOOT_TARGET="u-boot-nand";; | ||
170 | *SRIO*) UBOOT_TARGET="u-boot-srio";; | ||
171 | *) UBOOT_TARGET="u-boot";; | ||
172 | esac | ||
173 | |||
174 | if [ -f ${S}/${board}/${UBOOT_TARGET}.bin ]; then | ||
175 | mkdir -p ${DEPLOYDIR} | ||
176 | install ${S}/${board}/${UBOOT_TARGET}.bin ${DEPLOYDIR}/${UBOOT_TARGET}-${board}-${PV}-${PR}.bin | ||
177 | |||
178 | cd ${DEPLOYDIR} | ||
179 | rm -f ${UBOOT_TARGET}-${board}.bin | ||
180 | ln -sf ${UBOOT_TARGET}-${board}-${PV}-${PR}.bin ${UBOOT_TARGET}-${board}.bin | ||
181 | fi | ||
182 | done | ||
183 | } | ||
184 | addtask deploy after do_install | ||
185 | |||
186 | PACKAGES += "${PN}-images" | ||
187 | FILES_${PN}-images += "/boot" | ||
188 | |||
189 | ALLOW_EMPTY_${PN} = "1" | ||