aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/mvebu/image/espressobin.bootscript
diff options
context:
space:
mode:
authorAndre Heider <a.heider@gmail.com>2020-09-12 09:32:41 +0200
committerHauke Mehrtens <hauke@hauke-m.de>2020-10-11 16:53:20 +0200
commitc43b45863e38fb18a486601c1601f1485d649c0b (patch)
treec032b27614f3285d31e4045ed0594a4617eca9df /target/linux/mvebu/image/espressobin.bootscript
parent7c0496f29bed87326f1bf591ca25ace82373cfc7 (diff)
downloadupstream-c43b45863e38fb18a486601c1601f1485d649c0b.tar.gz
upstream-c43b45863e38fb18a486601c1601f1485d649c0b.tar.bz2
upstream-c43b45863e38fb18a486601c1601f1485d649c0b.zip
mvebu: Add bootscript for espressobin to support mainline firmware
The generic bootscript is tailored around a downstream firmware and doesn't work on a firmware built from mainline components. Add a bootscript which: * sets $console since mainline u-boot doesn't do that * uses distro boot variables, so OpenWRT can be booted off any supported device when using a mainline firmware * sets missing distro boot variables for the downstream firmware Booting with a downstream firmware is unchanged. Booting with a mainline firmware now works. Signed-off-by: Andre Heider <a.heider@gmail.com>
Diffstat (limited to 'target/linux/mvebu/image/espressobin.bootscript')
-rw-r--r--target/linux/mvebu/image/espressobin.bootscript34
1 files changed, 34 insertions, 0 deletions
diff --git a/target/linux/mvebu/image/espressobin.bootscript b/target/linux/mvebu/image/espressobin.bootscript
new file mode 100644
index 0000000000..07765df979
--- /dev/null
+++ b/target/linux/mvebu/image/espressobin.bootscript
@@ -0,0 +1,34 @@
+# Bootscript for Globalscale ESPRESSOBin Board
+
+# Set distro variables if necessary for compability with downstream firmware
+if test -z "${kernel_addr_r}"; then
+ setenv kernel_addr_r 0x7000000
+fi
+
+if test -z "${fdt_add_r}"; then
+ setenv fdt_addr_r 0x6f00000
+fi
+
+if test -z "${devtype}"; then
+ setenv devtype mmc
+fi
+
+if test -z "${devnum}"; then
+ if mmc dev 0; then
+ setenv devnum 0
+ elif mmc dev 1; then
+ setenv devnum 1
+ fi
+fi
+
+# figure out partition uuid to pass to the kernel as root=
+part uuid ${devtype} ${devnum}:2 uuid
+
+setenv console "console=ttyMV0,115200 earlycon=ar3700_uart,0xd0012000"
+setenv bootargs "root=PARTUUID=${uuid} rw rootwait ${console}"
+
+echo "Booting Linux from ${devtype} ${devnum} with args: ${bootargs}"
+load ${devtype} ${devnum}:1 ${fdt_addr_r} @DTB@.dtb
+load ${devtype} ${devnum}:1 ${kernel_addr_r} Image
+
+booti ${kernel_addr_r} - ${fdt_addr_r}