Module Name:    src
Committed By:   jmcneill
Date:           Thu Apr  9 10:55:23 UTC 2015

Modified Files:
        src/etc/etc.evbarm: Makefile.inc
Added Files:
        src/distrib/utils/embedded/conf: armv7.conf
Removed Files:
        src/distrib/utils/embedded/conf: beagleboard.conf

Log Message:
Rename beagleboard.img to armv7.img. The new image includes the same
kernels as beagleboard.img plus support for Raspberry Pi 2, ODROID-C1,
Cubieboard2, Cubietruck, Hummingbird A31, and Banana Pi.


To generate a diff of this commit:
cvs rdiff -u -r0 -r1.1 src/distrib/utils/embedded/conf/armv7.conf
cvs rdiff -u -r1.18 -r0 src/distrib/utils/embedded/conf/beagleboard.conf
cvs rdiff -u -r1.71 -r1.72 src/etc/etc.evbarm/Makefile.inc

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/etc/etc.evbarm/Makefile.inc
diff -u src/etc/etc.evbarm/Makefile.inc:1.71 src/etc/etc.evbarm/Makefile.inc:1.72
--- src/etc/etc.evbarm/Makefile.inc:1.71	Mon Mar 16 22:18:14 2015
+++ src/etc/etc.evbarm/Makefile.inc	Thu Apr  9 10:55:23 2015
@@ -1,4 +1,4 @@
-#	$NetBSD: Makefile.inc,v 1.71 2015/03/16 22:18:14 jmcneill Exp $
+#	$NetBSD: Makefile.inc,v 1.72 2015/04/09 10:55:23 jmcneill Exp $
 #
 #	etc.evbarm/Makefile.inc -- evbarm-specific etc Makefile targets
 #
@@ -133,7 +133,7 @@ __mkimage: .USE
 	TOOL_MTREE=${TOOL_MTREE} \
 	HOST_SH=${HOST_SH} \
 	${HOST_SH} ${MKIMAGE} -x -h ${.TARGET:S/smp_//} -D ${DESTDIR} \
-	    -K ${.ALLSRC} -S ${NETBSDSRCDIR} ${MKI_OPTS.${.TARGET}} \
+	    -S ${NETBSDSRCDIR} ${MKI_OPTS.${.TARGET}} \
 	    ${IMAGE.dir}/${.TARGET:S/smp_//}.img.gz
 
 ARCHES.arm=		armv4 xscale armv5t armv6 armv7
@@ -162,23 +162,21 @@ BUILD_KERNELS+=		${board}_INSTALL
 KERNEL_SETS+=		${KERNEL_SETS.${arch}}
 .endfor
 
-.if !empty(KERNEL_SETS:MBEAGLEBOARD) && !empty(KERNEL_SETS:MBEAGLEBONE)
-smp_beagleboard: ${IMAGE.kern}/netbsd-BEAGLEBOARD.ub.gz __mkimage
-#            XXX ${IMAGE.kern}/netbsd-BEAGLEBONE.ub.gz
-.if empty(ALL_KERNELS) || (!empty(ALL_KERNELS:MBEAGLEBOARD) && !empty(ALL_KERNELS:MBEAGLEBONE))
-SNAP_MD_POST_DEPS+=	smp_beagleboard
-.endif
+.if !empty(MACHINE_ARCH:M*armv7*) && empty(ALL_KERNELS)
+smp_armv7: __mkimage
+MKI_OPTS.smp_armv7=	-K ${IMAGE.kern}
+SNAP_MD_POST_DEPS+=	smp_armv7
 .endif
 
 .if !empty(KERNEL_SETS:MRPI)
-smp_rpi: ${IMAGE.kern}/netbsd-RPI.bin.gz __mkimage
-#            XXX ${IMAGE.kern}/netbsd-RPI2.bin.gz
+smp_rpi: __mkimage
 .if empty(ALL_KERNELS) || !empty(ALL_KERNELS:MRPI)
+MKI_OPTS.smp_rpi=	-K ${IMAGE.kern}/netbsd-RPI.bin.gz
 SNAP_MD_POST_DEPS+=	smp_rpi
 .endif
-MKI_OPTS.smp_rpi_inst="-b"
 smp_rpi_inst: ${IMAGE.instk}/netbsd-RPI_INSTALL.bin.gz __mkimage
 .if empty(ALL_KERNELS) || !empty(ALL_KERNELS:MRPI_INSTALL)
+MKI_OPTS.smp_rpi_inst=	-b -K ${IMAGE.instk}/netbsd-RPI_INSTALL.bin.gz
 SNAP_MD_POST_DEPS+=	smp_rpi_inst
 .endif
 .endif

Added files:

Index: src/distrib/utils/embedded/conf/armv7.conf
diff -u /dev/null src/distrib/utils/embedded/conf/armv7.conf:1.1
--- /dev/null	Thu Apr  9 10:55:23 2015
+++ src/distrib/utils/embedded/conf/armv7.conf	Thu Apr  9 10:55:23 2015
@@ -0,0 +1,126 @@
+# $NetBSD: armv7.conf,v 1.1 2015/04/09 10:55:23 jmcneill Exp $
+# ARMv7 customization script used by mkimage
+#
+board=armv7
+console=fb
+
+. ${DIR}/conf/evbarm.conf
+
+kernels_beagle="BEAGLEBOARD BEAGLEBONE"
+kernels_awin="BPI CUBIEBOARD CUBIETRUCK HUMMINGBIRD_A31"
+kernels_rpi="RPI2"
+kernels_amlogic="ODROID-C1"
+
+make_filesystems() {
+	make_filesystems_evbarm
+}
+
+make_label() {
+	make_label_evbarm
+}
+
+make_fstab() {
+	make_fstab_evbarm
+}
+
+customize() {
+	customize_evbarm
+	cat >> ${mnt}/etc/rc.conf << EOF
+mdnsd=YES
+wscons=YES
+devpubd=YES
+EOF
+}
+
+populate_beagle() {
+	bboard_kernelimg=netbsd-BEAGLEBOARD.ub
+	bboard_loadaddr=81000000
+	bbone_kernelimg=netbsd-BEAGLEBONE.ub
+	bbone_loadaddr=82000000
+
+	# Create a uEnv.txt to auto boot the correct kernel
+	cat >> ${mnt}/boot/uEnv.txt << EOF
+loaduimage=if test \$board = am335x; then fatload mmc 0 ${bbone_loadaddr} ${bbone_kernelimg}; bootm ${bbone_loadaddr} root=ld0a; else fatload mmc 0 ${bboard_loadaddr} ${bboard_kernelimg}; bootm ${bboard_loadaddr} root=ld0a; fi
+EOF
+}
+
+populate_awin() {
+	cat >> ${mnt}/boot/uEnv.txt << EOF
+bootargs=root=ld0a console=${console}
+uenvcmd=mmc dev 0; mmc rescan; if test \$fdtfile = sun7i-a20-cubieboard2.dtb; then setenv kernel netbsd-CUBIEBOARD2.ub; elif test \$fdtfile = sun7i-a20-cubietruck.dtb; then setenv kernel netbsd-CUBIETRUCK.ub; elif test \$fdtfile = sun6i-a31-hummingbird.dtb; then setenv kernel netbsd-HUMMINGBIRD_A31.ub; elif test \$fdtfile = sun7i-a20-bananapi.dtb; then setenv kernel netbsd-BPI.ub; fi; fatload mmc 0:1 82000000 ${kernel}; bootm 82000000
+EOF
+}
+
+populate_rpi() {
+	firmwaredir=${src}/external/broadcom/rpi-firmware/dist
+	firmwarefiles="LICENCE.broadcom bootcode.bin fixup.dat fixup_cd.dat start.elf start_cd.elf"
+
+	# RPI2 kernel needs to be installed as kernel7.img
+	if [ -f "${mnt}/boot/netbsd-RPI2.bin" ]; then
+		echo "${bar} renaming netbsd-RPI2.bin to kernel7.img ${bar}"
+		mv "${mnt}/boot/netbsd-RPI2.bin" "${mnt}/boot/kernel7.img"
+
+		cat > ${mnt}/boot/cmdline.txt << EOF
+root=ld0a console=${console}
+#fb=1280x1024		# to select a mode, otherwise try EDID
+#fb=disable		# to disable fb completely
+EOF
+
+	        echo "${bar} installing firmware files ${bar}"
+		(cd ${mnt}/boot &&
+			for f in ${firmwarefiles}; do
+				echo " $f"
+				cp ${firmwaredir}/${f} .
+			done
+        	)
+
+	fi
+}
+
+populate_amlogic() {
+	odroidc1_kernelimg=netbsd-ODROID-C1.ub
+
+	# Create a boot.ini for Amlogic U-Boot
+	cat >> ${mnt}/boot/boot.ini << EOF
+ODROIDC-UBOOT-CONFIG
+
+setenv bootargs "root=ld0f awge0.mac-address=\${ethaddr} console=${console}"
+setenv bootcmd "fatload mmc 0:1 0x21000000 ${odroidc1_kernelimg}; bootm 0x21000000"
+run bootcmd
+EOF
+}
+
+populate() {
+	echo "${bar} looking for kernels in ${kernel} ${bar}"
+	kernels=""
+	# .ub kernels
+	for k in $kernels_beagle $kernels_awin $kernels_amlogic; do
+		f="${kernel}/netbsd-${k}.ub.gz"
+		test -f "${f}" && kernels="${kernels} ${f}"
+	done
+	# .bin kernels
+	for k in $kernels_rpi; do
+		f="${kernel}/netbsd-${k}.bin.gz"
+		test -f "${f}" && kernels="${kernels} ${f}"
+	done
+
+	# install kernels to /boot partition
+	for k in ${kernels}; do
+		tgt="$(basename ${k} | sed 's/\.gz$//')"
+		echo "${bar} installing ${k} to /boot/${tgt} ${bar}"
+		case "${k}" in
+		*.gz)
+			${GZIP_CMD} -dc "${k}" > "${mnt}/boot/${tgt}"
+			;;
+		*)
+			cp "${k}" "${mnt}/boot/${tgt}"
+			;;
+		esac
+	done
+
+	# board specific configuration
+	populate_beagle
+	populate_awin
+	populate_rpi
+	populate_amlogic
+}

Reply via email to