mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-10 11:09:57 +08:00
uboot-imx6: Add support for Toradex Apalis board family
This patch is needed in order to properly boot OpenWrt bootscript. Signed-off-by: Petr Štetiar <ynezz@true.cz>
This commit is contained in:
parent
8f1cbef12e
commit
136001675e
@ -20,6 +20,12 @@ define U-Boot/Default
|
|||||||
UBOOT_IMAGE:=u-boot.imx
|
UBOOT_IMAGE:=u-boot.imx
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
define U-Boot/apalis_imx6
|
||||||
|
NAME:=Toradex Apalis
|
||||||
|
UBOOT_IMAGE:=SPL u-boot.img u-boot-with-spl.imx
|
||||||
|
UBOOT_MAKE_FLAGS:=SPL u-boot.img u-boot-with-spl.imx
|
||||||
|
endef
|
||||||
|
|
||||||
define U-Boot/mx6cuboxi
|
define U-Boot/mx6cuboxi
|
||||||
NAME:=SolidRun Cubox-i boards
|
NAME:=SolidRun Cubox-i boards
|
||||||
UBOOT_IMAGE:=SPL u-boot.img
|
UBOOT_IMAGE:=SPL u-boot.img
|
||||||
@ -62,6 +68,7 @@ define U-Boot/wandboard
|
|||||||
endef
|
endef
|
||||||
|
|
||||||
UBOOT_TARGETS := \
|
UBOOT_TARGETS := \
|
||||||
|
apalis_imx6 \
|
||||||
mx6cuboxi \
|
mx6cuboxi \
|
||||||
mx6sabresd \
|
mx6sabresd \
|
||||||
nitrogen6dl \
|
nitrogen6dl \
|
||||||
|
@ -0,0 +1,127 @@
|
|||||||
|
From 42cc2cffb6d550fbb21dad033d2564d4da571015 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Petr=20=C5=A0tetiar?= <ynezz@true.cz>
|
||||||
|
Date: Sat, 1 Dec 2018 12:46:37 +0100
|
||||||
|
Subject: [PATCH] imx6: apalis: Make the boot process more generic
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
I'm preparing support for Apalis imx6 boards in OpenWrt and I've ended
|
||||||
|
up with quite huge patchset against upstream U-Boot 2018.03, so I'm
|
||||||
|
trying to propose more generic way of boot process handling.
|
||||||
|
|
||||||
|
In OpenWrt we usually have kernel, dtbs and U-Boot boot script in boot
|
||||||
|
partition with ext4fs, so for some use cases it would be handy to be
|
||||||
|
able to replace some of the files in the boot partion, that's why I've
|
||||||
|
added write support to the ext4.
|
||||||
|
|
||||||
|
I've added `set_blkcnt` environment variable which is needed for every
|
||||||
|
`mmc write` command as we need to always specify size in block count.
|
||||||
|
This is copy&pasted from official Toradex's flashing scripts, so all the
|
||||||
|
credits for this work belongs to them.
|
||||||
|
|
||||||
|
Currently the rootfs location is passed via mmcblk number and the
|
||||||
|
problem with this approach is that the mmcblk number for the boot device
|
||||||
|
changes depending on the kernel version and imx6 SoC type. In order to
|
||||||
|
avoid such issues, use the UUID method to specify the rootfs location.
|
||||||
|
|
||||||
|
I've added new boot sequence, where we first try to load and run boot
|
||||||
|
script defined in the new `script` variable, so the boot process could
|
||||||
|
be more generic and overridden by the distro. When the boot script isn't
|
||||||
|
loaded, it will use the previous boot sequence so it should be backward
|
||||||
|
compatible.
|
||||||
|
|
||||||
|
For the recovery purposes and better end user experience I've added boot
|
||||||
|
from SDP as the last boot command if every other boot option fails. I
|
||||||
|
plan to use SDP as official flashing/recovery procedure in OpenWrt for
|
||||||
|
Apalis imx6 boards.
|
||||||
|
|
||||||
|
I've copy&pasted almost everything from the `f086812a mx6sxsabresd: Use
|
||||||
|
PARTUUID to specify the rootfs location` commit, so credits for the rest
|
||||||
|
of this patch belongs to Fabio.
|
||||||
|
|
||||||
|
Cc: Stefan Agner <stefan.agner@toradex.com>
|
||||||
|
Cc: Max Krummenacher <max.krummenacher@toradex.com>
|
||||||
|
Signed-off-by: Petr Štetiar <ynezz@true.cz>
|
||||||
|
---
|
||||||
|
configs/apalis_imx6_defconfig | 2 ++
|
||||||
|
include/configs/apalis_imx6.h | 26 +++++++++++++++++++++-----
|
||||||
|
2 files changed, 23 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/configs/apalis_imx6_defconfig b/configs/apalis_imx6_defconfig
|
||||||
|
index 133fc1a..279d39f 100644
|
||||||
|
--- a/configs/apalis_imx6_defconfig
|
||||||
|
+++ b/configs/apalis_imx6_defconfig
|
||||||
|
@@ -39,6 +39,7 @@ CONFIG_CMD_DFU=y
|
||||||
|
CONFIG_CMD_GPIO=y
|
||||||
|
CONFIG_CMD_I2C=y
|
||||||
|
CONFIG_CMD_MMC=y
|
||||||
|
+CONFIG_CMD_PART=y
|
||||||
|
CONFIG_CMD_USB=y
|
||||||
|
CONFIG_CMD_USB_SDP=y
|
||||||
|
CONFIG_CMD_USB_MASS_STORAGE=y
|
||||||
|
@@ -48,6 +49,7 @@ CONFIG_CMD_PING=y
|
||||||
|
CONFIG_CMD_BMP=y
|
||||||
|
CONFIG_CMD_CACHE=y
|
||||||
|
CONFIG_CMD_EXT4=y
|
||||||
|
+CONFIG_CMD_EXT4_WRITE=y
|
||||||
|
CONFIG_CMD_FAT=y
|
||||||
|
CONFIG_CMD_FS_GENERIC=y
|
||||||
|
CONFIG_ENV_IS_IN_MMC=y
|
||||||
|
diff --git a/include/configs/apalis_imx6.h b/include/configs/apalis_imx6.h
|
||||||
|
index 135b3c9..3601891 100644
|
||||||
|
--- a/include/configs/apalis_imx6.h
|
||||||
|
+++ b/include/configs/apalis_imx6.h
|
||||||
|
@@ -142,9 +142,9 @@
|
||||||
|
"imx6q-colibri-cam-eval-v3.dtb fat 0 1"
|
||||||
|
|
||||||
|
#define EMMC_BOOTCMD \
|
||||||
|
- "emmcargs=ip=off root=/dev/mmcblk0p2 rw,noatime rootfstype=ext3 " \
|
||||||
|
+ "emmcargs=ip=off root=PARTUUID=${uuid} rw,noatime rootfstype=ext3 " \
|
||||||
|
"rootwait\0" \
|
||||||
|
- "emmcboot=run setup; " \
|
||||||
|
+ "emmcboot=run setup; run finduuid;" \
|
||||||
|
"setenv bootargs ${defargs} ${emmcargs} ${setupargs} " \
|
||||||
|
"${vidargs}; echo Booting from internal eMMC chip...; " \
|
||||||
|
"run emmcdtbload; load mmc 0:1 ${kernel_addr_r} " \
|
||||||
|
@@ -201,10 +201,17 @@
|
||||||
|
#define FDT_FILE "imx6q-apalis_v1_0-eval.dtb"
|
||||||
|
#endif
|
||||||
|
#define CONFIG_EXTRA_ENV_SETTINGS \
|
||||||
|
- "bootcmd=run emmcboot ; echo ; echo emmcboot failed ; " \
|
||||||
|
+ "script=boot.scr\0" \
|
||||||
|
+ "finduuid=part uuid mmc 0:2 uuid\0" \
|
||||||
|
+ "loadbootscript=" \
|
||||||
|
+ "load mmc 0:1 ${loadaddr} ${script};\0" \
|
||||||
|
+ "bootscript=echo Running bootscript from mmc ...; " \
|
||||||
|
+ "source\0" \
|
||||||
|
+ "bootcmd_default=run emmcboot ; echo ; echo emmcboot failed ; " \
|
||||||
|
"run nfsboot ; echo ; echo nfsboot failed ; " \
|
||||||
|
"usb start ;" \
|
||||||
|
- "setenv stdout serial,vga ; setenv stdin serial,usbkbd\0" \
|
||||||
|
+ "setenv stdout serial,vga ; setenv stdin serial,usbkbd;" \
|
||||||
|
+ "sdp 0\0" \
|
||||||
|
"boot_file=uImage\0" \
|
||||||
|
"console=ttymxc0\0" \
|
||||||
|
"defargs=enable_wait_mode=off vmalloc=400M\0" \
|
||||||
|
@@ -232,7 +239,16 @@
|
||||||
|
"vidargs=mxc_hdmi.only_cea=1 " \
|
||||||
|
"video=mxcfb0:dev=hdmi,1920x1080M@60,if=RGB24 " \
|
||||||
|
"video=mxcfb1:off video=mxcfb2:off video=mxcfb3:off " \
|
||||||
|
- "fbmem=32M\0 "
|
||||||
|
+ "fbmem=32M\0 " \
|
||||||
|
+ "set_blkcnt=setexpr blkcnt ${filesize} + 0x1ff && setexpr blkcnt ${blkcnt} / 0x200\0"
|
||||||
|
+
|
||||||
|
+#define CONFIG_BOOTCOMMAND \
|
||||||
|
+ "mmc dev 0;" \
|
||||||
|
+ "if run loadbootscript; then " \
|
||||||
|
+ "run bootscript; " \
|
||||||
|
+ "else " \
|
||||||
|
+ "run bootcmd_default; " \
|
||||||
|
+ "fi; "
|
||||||
|
|
||||||
|
/* Miscellaneous configurable options */
|
||||||
|
#undef CONFIG_SYS_CBSIZE
|
||||||
|
--
|
||||||
|
1.9.1
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user