summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKhem Raj <raj.khem@gmail.com>2016-04-18 20:40:24 -0700
committerKhem Raj <raj.khem@gmail.com>2016-04-18 20:40:24 -0700
commit582a5683a4bde998fafbe6bba5e20474b78a01e3 (patch)
tree3e5eb125620ae237cb24fd6fae5e5662c12641d3
parentb990abff205f081241947f263c674b9529c50851 (diff)
parentbfdb9464380d36330ded10a10ac8339d818d43b5 (diff)
downloadmeta-altera-582a5683a4bde998fafbe6bba5e20474b78a01e3.tar.gz
Merge pull request #24 from dwesterg/master
Clean up variables for uboot build
-rw-r--r--classes/image_types_socfpga.bbclass123
-rw-r--r--conf/machine/arria5.conf11
-rw-r--r--conf/machine/cyclone5.conf17
-rw-r--r--conf/machine/include/socfpga.inc9
-rw-r--r--recipes-bsp/u-boot/u-boot-socfpga_2016.03.bb15
5 files changed, 157 insertions, 18 deletions
diff --git a/classes/image_types_socfpga.bbclass b/classes/image_types_socfpga.bbclass
new file mode 100644
index 0000000..579bc5a
--- /dev/null
+++ b/classes/image_types_socfpga.bbclass
@@ -0,0 +1,123 @@
1inherit image_types
2
3IMAGE_BOOTLOADER ?= "u-boot-socfpga"
4SDCARD_ROOTFS ?= "${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.rootfs.ext3"
5
6# Boot partition size [in KiB]
7IMAGE_ROOTFS_ALIGNMENT_cyclone5 ?= "2048"
8IMAGE_ROOTFS_ALIGNMENT_arria5 ?= "2048"
9IMAGE_ROOTFS_ALIGNMENT_arria10 ?= "10240"
10
11BOOT_SPACE ?= "102400"
12
13IMAGE_DEPENDS_sdcard = "parted-native:do_populate_sysroot \
14 dosfstools-native:do_populate_sysroot \
15 mtools-native:do_populate_sysroot \
16 virtual/kernel:do_deploy \
17 ${@d.getVar('IMAGE_BOOTLOADER', True) and d.getVar('IMAGE_BOOTLOADER', True) + ':do_deploy' or ''}"
18
19SDCARD_GENERATION_COMMAND_cyclone5 = "generate_28nm_sdcard"
20SDCARD_GENERATION_COMMAND_arria5 = "generate_28nm_sdcard"
21
22#
23# Generate the boot image with the boot scripts and required Device Tree
24# files
25_generate_boot_image() {
26 local boot_part=$1
27
28 # Create boot partition image
29 BOOT_BLOCKS=$(LC_ALL=C parted -s ${SDCARD} unit b print \
30 | awk "/ $boot_part / { print substr(\$4, 1, length(\$4 -1)) / 1024 }")
31
32 # mkdosfs will sometimes use FAT16 when it is not appropriate,
33 # resulting in a boot failure from SYSLINUX. Use FAT32 for
34 # images larger than 512MB, otherwise let mkdosfs decide.
35 if [ $(expr $BOOT_BLOCKS / 1024) -gt 512 ]; then
36 FATSIZE="-F 32"
37 fi
38
39 rm -f ${WORKDIR}/boot.img
40 mkfs.vfat -n "${BOOTDD_VOLUME_ID}" -S 512 ${FATSIZE} -C ${WORKDIR}/boot.img $BOOT_BLOCKS
41
42 mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}-${MACHINE}.bin ::/${KERNEL_IMAGETYPE}
43
44 # Copy boot scripts
45 for item in ${BOOT_SCRIPTS}; do
46 src=`echo $item | awk -F':' '{ print $1 }'`
47 dst=`echo $item | awk -F':' '{ print $2 }'`
48
49 mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/$src ::/$dst
50 done
51
52 # Copy device tree file
53 if test -n "${KERNEL_DEVICETREE}"; then
54 for DTS_FILE in ${KERNEL_DEVICETREE}; do
55 DTS_BASE_NAME=`basename ${DTS_FILE} | awk -F "." '{print $1}'`
56 if [ -e "${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}-${DTS_BASE_NAME}.dtb" ]; then
57 kernel_bin="`readlink ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}-${MACHINE}.bin`"
58 kernel_bin_for_dtb="`readlink ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}-${DTS_BASE_NAME}.dtb | sed "s,$DTS_BASE_NAME,${MACHINE},g;s,\.dtb$,.bin,g"`"
59 if [ $kernel_bin = $kernel_bin_for_dtb ]; then
60 mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}-${DTS_BASE_NAME}.dtb ::/${DTS_BASE_NAME}.dtb
61 fi
62 else
63 bbfatal "${DTS_FILE} does not exist."
64 fi
65 done
66 fi
67}
68
69generate_28nm_sdcard () {
70 # Create partition table
71 parted -s ${SDCARD} mklabel msdos
72 parted -s ${SDCARD} unit KiB mkpart primary fat32 ${IMAGE_ROOTFS_ALIGNMENT} $(expr ${IMAGE_ROOTFS_ALIGNMENT} \+ ${BOOT_SPACE_ALIGNED})
73 parted -s ${SDCARD} unit KiB mkpart primary $(expr ${IMAGE_ROOTFS_ALIGNMENT} \+ ${BOOT_SPACE_ALIGNED}) $(expr ${IMAGE_ROOTFS_ALIGNMENT} \+ ${BOOT_SPACE_ALIGNED} \+ $ROOTFS_SIZE)
74 parted -s ${SDCARD} unit KiB mkpart primary 1024 2048
75
76 #set part 3 to type a2 for spl / uboot image
77 echo -ne "\xa2" | dd of=${SDCARD} bs=1 count=1 seek=482 conv=notrunc
78
79
80 if [ -e "${DEPLOY_DIR_IMAGE}/${SPL_BINARY}-${UBOOT_CONFIG}" ]
81 then
82 dd if=${DEPLOY_DIR_IMAGE}/${SPL_BINARY}-${UBOOT_CONFIG} of=${SDCARD} conv=notrunc seek=1 bs=$(expr 1024 \* 1024)
83 elsif [ -e "${DEPLOY_DIR_IMAGE}/${SPL_BINARY}-${UBOOT_CONFIG}" ]
84 then
85 dd if=${DEPLOY_DIR_IMAGE}/${SPL_BINARY} of=${SDCARD} conv=notrunc seek=1 bs=$(expr 1024 \* 1024)
86 else
87 bbfatal "${SPL_BINARY} does not exist."
88 fi
89
90 parted ${SDCARD} print
91
92 _generate_boot_image 1
93 # Burn Partition
94 dd if=${WORKDIR}/boot.img of=${SDCARD} conv=notrunc,fsync seek=1 bs=$(expr ${IMAGE_ROOTFS_ALIGNMENT} \* 1024)
95 dd if=${SDCARD_ROOTFS} of=${SDCARD} conv=notrunc,fsync seek=1 bs=$(expr ${BOOT_SPACE_ALIGNED} \* 1024 + ${IMAGE_ROOTFS_ALIGNMENT} \* 1024)
96}
97
98IMAGE_CMD_sdcard () {
99 if [ -z "${SDCARD_ROOTFS}" ]; then
100 bberror "SDCARD_ROOTFS is undefined. To use sdcard image from Freescale's BSP it needs to be defined."
101 exit 1
102 fi
103
104 # Align boot partition and calculate total SD card image size
105 BOOT_SPACE_ALIGNED=$(expr ${BOOT_SPACE} + ${IMAGE_ROOTFS_ALIGNMENT} - 1)
106 BOOT_SPACE_ALIGNED=$(expr ${BOOT_SPACE_ALIGNED} - ${BOOT_SPACE_ALIGNED} % ${IMAGE_ROOTFS_ALIGNMENT})
107 SDCARD_SIZE=$(expr ${IMAGE_ROOTFS_ALIGNMENT} + ${BOOT_SPACE_ALIGNED} + $ROOTFS_SIZE + ${IMAGE_ROOTFS_ALIGNMENT})
108
109 # Initialize a sparse file
110 if [ "x${UBOOT_CONFIG}" != "x" ]
111 then
112 SDCARD="${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}-${UBOOT_CONFIG}.rootfs.sdcard"
113 else
114 SDCARD="${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.rootfs.sdcard"
115 fi
116 dd if=/dev/zero of=${SDCARD} bs=1 count=0 seek=$(expr 1024 \* ${SDCARD_SIZE})
117
118 ${SDCARD_GENERATION_COMMAND}
119}
120
121# The sdcard requires the rootfs filesystem to be built before using
122# it so we must make this dependency explicit.
123IMAGE_TYPEDEP_sdcard = "${@d.getVar('SDCARD_ROOTFS', 1).split('.')[-1]}" \ No newline at end of file
diff --git a/conf/machine/arria5.conf b/conf/machine/arria5.conf
index 193403c..f3a0a34 100644
--- a/conf/machine/arria5.conf
+++ b/conf/machine/arria5.conf
@@ -4,9 +4,16 @@
4 4
5require conf/machine/include/socfpga.inc 5require conf/machine/include/socfpga.inc
6 6
7PREFERRED_VERSION_u-boot-socfpga ?= "2016.03" 7PREFERRED_VERSION_u-boot-socfpga ?= "2016.03%"
8 8
9UBOOT_CONFIG ?= "arria5-socdk" 9UBOOT_CONFIG ??= "arria5-socdk"
10
11UBOOT_CONFIG[arria5-socdk] = "socfpga_arria5_defconfig,sdcard"
10 12
11KMACHINE = "arria5" 13KMACHINE = "arria5"
12 14
15# Default kernel devicetrees
16KERNEL_DEVICETREE_arria5 ?= "socfpga_arria5_socdk.dtb"
17
18# Add support for SDCARD creation
19IMAGE_CLASSES += "image_types_socfpga
diff --git a/conf/machine/cyclone5.conf b/conf/machine/cyclone5.conf
index 7d0aab0..941005b 100644
--- a/conf/machine/cyclone5.conf
+++ b/conf/machine/cyclone5.conf
@@ -4,9 +4,22 @@
4 4
5require conf/machine/include/socfpga.inc 5require conf/machine/include/socfpga.inc
6 6
7PREFERRED_VERSION_u-boot-socfpga ?= "2016.03" 7PREFERRED_VERSION_u-boot-socfpga ?= "2016.03%"
8 8
9UBOOT_CONFIG ?= "cyclone5-socdk" 9UBOOT_CONFIG ??= "cyclone5-socdk"
10
11UBOOT_CONFIG[cyclone5-socdk] = "socfpga_cyclone5_defconfig,sdcard"
12UBOOT_CONFIG[de0-nano-soc] = "socfpga_de0_nano_soc_defconfig,sdcard"
13UBOOT_CONFIG[mcvevk] = "socfpga_mcvevk_defconfig"
14UBOOT_CONFIG[sockit] = "socfpga_sockit_defconfig"
15UBOOT_CONFIG[socrates] = "socfpga_socrates_defconfig"
16UBOOT_CONFIG[sr1500] = "socfpga_sr1500_defconfig"
10 17
11KMACHINE = "cyclone5" 18KMACHINE = "cyclone5"
12 19
20# Default kernel devicetrees
21KERNEL_DEVICETREE ?= "socfpga_cyclone5_socdk.dtb socfpga_cyclone5_sockit.dtb socfpga_cyclone5_socrates.dtb socfpga_cyclone5_de0_sockit.dtb"
22
23# Add support for SDCARD creation
24IMAGE_CLASSES += "image_types_socfpga"
25
diff --git a/conf/machine/include/socfpga.inc b/conf/machine/include/socfpga.inc
index 6932620..19106a1 100644
--- a/conf/machine/include/socfpga.inc
+++ b/conf/machine/include/socfpga.inc
@@ -25,3 +25,12 @@ MACHINE_FEATURES = "kernel26"
25# file system images required 25# file system images required
26IMAGE_FSTYPES ?= "cpio ext3 tar.gz" 26IMAGE_FSTYPES ?= "cpio ext3 tar.gz"
27 27
28# u-boot setup
29UBOOT_SUFFIX = "img"
30
31# AV and CV uBoot + SPL mkpimage type binary
32SPL_BINARY_cyclone5 = "u-boot-with-spl.sfp"
33SPL_BINARY_arria5 = "u-boot-with-spl.sfp"
34
35
36
diff --git a/recipes-bsp/u-boot/u-boot-socfpga_2016.03.bb b/recipes-bsp/u-boot/u-boot-socfpga_2016.03.bb
index 1d0376e..9189715 100644
--- a/recipes-bsp/u-boot/u-boot-socfpga_2016.03.bb
+++ b/recipes-bsp/u-boot/u-boot-socfpga_2016.03.bb
@@ -6,23 +6,10 @@ SRCREV = "df61a74e6845ec9bdcdd48d2aff5e9c2c6debeaa"
6LICENSE = "GPLv2+" 6LICENSE = "GPLv2+"
7LIC_FILES_CHKSUM = "file://Licenses/README;md5=a2c678cfd4a4d97135585cad908541c6" 7LIC_FILES_CHKSUM = "file://Licenses/README;md5=a2c678cfd4a4d97135585cad908541c6"
8 8
9PV = "v2016.03" 9PV = "2016.03"
10PV_append = "+git${SRCPV}" 10PV_append = "+git${SRCPV}"
11 11
12DEPENDS += "dtc-native" 12DEPENDS += "dtc-native"
13 13
14UBOOT_CONFIG ??= "cyclone5-socdk arria5-socdk de0-nano-soc sockit socrates"
15UBOOT_CONFIG[cyclone5-socdk] = "socfpga_cyclone5_defconfig"
16UBOOT_CONFIG[arria5-socdk] = "socfpga_arria5_defconfig"
17UBOOT_CONFIG[de0-nano-soc] = "socfpga_de0_nano_soc_defconfig"
18UBOOT_CONFIG[mcvevk] = "socfpga_mcvevk_defconfig"
19UBOOT_CONFIG[sockit] = "socfpga_sockit_defconfig"
20UBOOT_CONFIG[socrates] = "socfpga_socrates_defconfig"
21UBOOT_CONFIG[sr1500] = "socfpga_sr1500_defconfig"
22
23UBOOT_SUFFIX = "img"
24
25SPL_BINARY_cyclone5 = "u-boot-with-spl.sfp"
26SPL_BINARY_arria5 = "u-boot-with-spl.sfp"
27 14
28 15