board/boundarydevices: rework and update u-boot scripts
authorGary Bisson <gary.bisson@boundarydevices.com>
Tue, 26 May 2015 08:19:40 +0000 (10:19 +0200)
committerThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Sat, 11 Jul 2015 11:04:48 +0000 (13:04 +0200)
Those scripts are executed by u-boot in order to detect the hardware
configuration (board, displays etc...), configure the bootargs and
device tree accordingly or update the bootloader located in NOR flash.

This update is necessary due to the kernel bump to version 3.10.53.

The rework consists of replacing the binaries by their text file
equivalent and generate the binaries from the post-build.sh script.

Signed-off-by: Gary Bisson <gary.bisson@boundarydevices.com>
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
board/boundarydevices/nitrogen6x/6x_bootscript [deleted file]
board/boundarydevices/nitrogen6x/6x_bootscript.txt [new file with mode: 0644]
board/boundarydevices/nitrogen6x/6x_upgrade [deleted file]
board/boundarydevices/nitrogen6x/6x_upgrade.txt [new file with mode: 0644]
board/boundarydevices/nitrogen6x/post-build.sh
configs/nitrogen6x_defconfig

diff --git a/board/boundarydevices/nitrogen6x/6x_bootscript b/board/boundarydevices/nitrogen6x/6x_bootscript
deleted file mode 100644 (file)
index 05442a6..0000000
Binary files a/board/boundarydevices/nitrogen6x/6x_bootscript and /dev/null differ
diff --git a/board/boundarydevices/nitrogen6x/6x_bootscript.txt b/board/boundarydevices/nitrogen6x/6x_bootscript.txt
new file mode 100644 (file)
index 0000000..ac86fe5
--- /dev/null
@@ -0,0 +1,186 @@
+setenv bootargs ''
+
+if ${fs}load ${dtype} ${disk}:1 10800000 uEnv.txt ; then
+    env import -t 10800000 $filesize
+fi
+
+if itest.s "x" == "x$dtbname" ; then
+       dtbname="imx6";
+       if itest.s x6SOLO == "x$cpu" ; then
+               dtbname=${dtbname}dl-;
+       elif itest.s x6DL == "x$cpu" ; then
+               dtbname=${dtbname}dl-;
+       else
+               dtbname=${dtbname}q-;
+       fi
+       if itest.s x == "x$board" ; then
+               board=sabrelite
+       fi
+       dtbname=${dtbname}${board}.dtb;
+fi
+
+if itest.s x == x${bootdir} ; then
+       bootdir=/boot/
+fi
+
+setenv fdt_addr 0x12000000
+if ${fs}load ${dtype} ${disk}:1 $fdt_addr ${bootdir}$dtbname ; then
+       fdt addr $fdt_addr
+       setenv fdt_high 0xffffffff
+else
+       echo "!!!! Error loading ${bootdir}$dtbname";
+       exit;
+fi
+
+# ------------------- HDMI detection
+i2c dev 1 ;
+if i2c probe 0x50 ; then
+       echo "------ have HDMI monitor";
+       if itest.s x == x$allow_noncea ; then
+               setenv bootargs $bootargs mxc_hdmi.only_cea=1;
+               echo "only CEA modes allowed on HDMI port";
+       else
+               setenv bootargs $bootargs mxc_hdmi.only_cea=0;
+               echo "non-CEA modes allowed on HDMI, audio may be affected";
+       fi
+else
+       fdt rm hdmi_display
+       echo "------ no HDMI monitor";
+fi
+
+# ------------------- LVDS detection
+if itest.s "x" != "x$lvds_1080p" ; then
+       echo "----- 1080P dual channel LVDS";
+       fdt rm okaya1024x600
+       fdt rm lg1280x800
+       fdt rm hannstar;
+       fdt set ldb split-mode 1
+       fdt set lvds_display interface_pix_fmt "RGB24"
+       fdt set ldb/lvds-channel@0 fsl,data-width <24>
+else
+       fdt rm ldb split-mode
+       fdt rm lvds1080p
+
+       # -------- LVDS0 (bottom on Nitrogen6_Max)
+       setenv have_lvds
+       i2c dev 2
+       if i2c probe 0x04 ; then
+               echo "------ have Freescale display";
+               setenv have_lvds 1
+       else
+               echo "------ no Freescale display";
+               fdt rm hannstar;
+       fi
+
+       if i2c probe 0x38 ; then
+               if itest.s "xLDB-WXGA" == "x$panel"; then
+                       screenres=1280,800
+                       fdt rm okaya1024x600
+               else
+                       screenres=1024,600
+                       fdt rm lg1280x800
+               fi
+               setenv have_lvds 1
+               setenv bootargs $bootargs ft5x06_ts.screenres=$screenres
+               if itest.s "x" -ne "x$calibration" ; then
+                       setenv bootargs $bootargs ft5x06_ts.calibration=$calibration
+               fi
+       else
+               echo "------ no ft5x06 touch controller";
+               fdt rm okaya1024x600
+               fdt rm lg1280x800
+       fi
+
+       if itest.s "x" == "x$have_lvds"; then
+               fdt rm lvds_display;
+       fi
+
+       # -------- LVDS1 (top on Nitrogen6_Max)
+       if itest.s "xhannstar" == "x$lvds1_panel" ; then
+               echo "configure LVDS1 for Hannstar panel"
+               fdt rm okaya1024x600_2;
+               fdt rm lg1280x800_2;
+               fdt set lvds_display_2 status okay
+       elif itest.s "xokaya1024x600" == "x$lvds1_panel" ; then
+               echo "configure LVDS1 for 1024x600 panel"
+               fdt rm hannstar_2;
+               fdt rm lg1280x800_2;
+               fdt set lvds_display_2 status okay
+       elif itest.s "xlg1280x800" == "x$lvds1_panel" ; then
+               echo "configure LVDS1 for 1280x800 panel"
+               fdt rm hannstar_2;
+               fdt rm okaya1024x600_2;
+               fdt set lvds_display_2 status okay
+       else
+               fdt rm lvds_display_2 ; # ignore errors on boards != 6_max
+       fi
+fi
+
+# ------------------- LCD detection
+setenv have_lcd '';
+if i2c probe 0x48 ; then
+       setenv have_lcd 1;
+       echo "------- found TSC2004 touch controller";
+       if itest.s "x" -eq "x$tsc_calibration" ; then
+               setenv bootargs $bootargs tsc2004.calibration=-67247,-764,272499173,324,69283,-8653010,65536
+       else
+               setenv bootargs $bootargs tsc2004.calibration=$tsc_calibration
+       fi
+elif i2c probe 0x4d ; then
+       setenv have_lcd 1;
+       echo "------- found AR1020 touch controller";
+fi
+
+if itest.s "x" != "x$ignore_lcd" ; then
+       echo "------ ignoring LCD display";
+       setenv have_lcd '';
+fi
+
+if itest.s "x" != "x$have_lcd" ; then
+       echo "----- found LCD display";
+else
+       fdt rm lcd_display;
+fi
+
+setenv bootargs "$bootargs console=ttymxc1,115200 vmalloc=400M consoleblank=0 rootwait"
+
+if itest.s x$bootpart == x ; then
+       bootpart=1
+fi
+
+if test "sata" = "${dtype}" ; then
+       setenv bootargs "$bootargs root=/dev/sda$bootpart" ;
+else
+        if test "usb" = "${dtype}" ; then
+                setenv bootargs "$bootargs root=/dev/sda$bootpart" ;
+        elif itest 0 -eq ${disk}; then
+                setenv bootargs "$bootargs root=/dev/mmcblk2p$bootpart" ;
+        else
+                setenv bootargs "$bootargs root=/dev/mmcblk3p$bootpart" ;
+        fi
+fi
+
+if itest.s "x" != "x${disable_giga}" ; then
+       setenv bootargs $bootargs fec.disable_giga=1
+fi
+
+if itest.s "x" != "x$wlmac" ; then
+       setenv bootargs $bootargs wlcore.mac=$wlmac
+fi
+
+if itest.s "x" != "x$gpumem" ; then
+       setenv bootargs $bootargs galcore.contiguousSize=$gpumem
+fi
+
+if itest.s "x" != "x$show_fdt" ; then
+       fdt print /
+fi
+
+if itest.s "x" != "x$show_env" ; then
+       printenv
+fi
+
+if ${fs}load ${dtype} ${disk}:1 10800000 ${bootdir}uImage ; then
+       bootm 10800000 - $fdt_addr
+fi
+echo "Error loading kernel image"
diff --git a/board/boundarydevices/nitrogen6x/6x_upgrade b/board/boundarydevices/nitrogen6x/6x_upgrade
deleted file mode 100644 (file)
index 395f13f..0000000
Binary files a/board/boundarydevices/nitrogen6x/6x_upgrade and /dev/null differ
diff --git a/board/boundarydevices/nitrogen6x/6x_upgrade.txt b/board/boundarydevices/nitrogen6x/6x_upgrade.txt
new file mode 100644 (file)
index 0000000..3f1b96f
--- /dev/null
@@ -0,0 +1,49 @@
+if itest.s a$bootfile == a; then
+        bootfile=u-boot.imx
+fi
+
+setenv stdout serial,vga
+echo "check U-Boot" ;
+setenv offset 0x400
+if ${fs}load ${dtype} ${disk}:1 12000000 $bootfile || ${fs}load ${dtype} ${disk}:1 12000000 u-boot.nopadding ; then
+      echo "read $filesize bytes from SD card" ;
+      if sf probe || sf probe || \
+        sf probe 1 27000000 || sf probe 1 27000000 ; then
+          echo "probed SPI ROM" ;
+          if sf read 0x12400000 $offset $filesize ; then
+              if cmp.b 0x12000000 0x12400000 $filesize ; then
+                  echo "------- U-Boot versions match" ;
+              else
+                  echo "Need U-Boot upgrade" ;
+                  echo "Program in 5 seconds" ;
+                  for n in 5 4 3 2 1 ; do
+                       echo $n ;
+                       sleep 1 ;
+                  done
+                  echo "erasing" ;
+                  sf erase 0 0xC0000 ;
+                  # two steps to prevent bricking
+                  echo "programming" ;
+                  sf write 0x12000000 $offset $filesize ;
+                  echo "verifying" ;
+                  if sf read 0x12400000 $offset $filesize ; then
+                      if cmp.b 0x12000000 0x12400000 $filesize ; then
+                          while echo "---- U-Boot upgraded. reset" ; do
+                               sleep 120
+                          done
+                      else
+                          echo "Read verification error" ;
+                      fi
+                  else
+                       echo "Error re-reading EEPROM" ;
+                  fi
+              fi
+          else
+              echo "Error reading boot loader from EEPROM" ;
+          fi
+      else
+          echo "Error initializing EEPROM" ;
+      fi ;
+else
+     echo "No U-Boot image found on SD card" ;
+fi
index 2b43aa3227b7e431c570963afc7758d4cc104bf2..f68fa0e61bfec161c342fc6364a00f8e35c693d7 100755 (executable)
@@ -8,11 +8,13 @@
 BOARD_DIR="$(dirname $0)"
 
 # bd u-boot looks for bootscript here
-install -D -m 0644 $BOARD_DIR/6x_bootscript $TARGET_DIR/6x_bootscript
+$HOST_DIR/usr/bin/mkimage -A arm -O linux -T script -C none -a 0 -e 0 \
+-n "boot script" -d $BOARD_DIR/6x_bootscript.txt $TARGET_DIR/6x_bootscript
 
 # u-boot / update script for bd upgradeu command
 if [ -e $BINARIES_DIR/u-boot.imx ];
 then
     install -D -m 0644 $BINARIES_DIR/u-boot.imx $TARGET_DIR/u-boot.imx
-    install -D -m 0644 $BOARD_DIR/6x_upgrade $TARGET_DIR/6x_upgrade
+    $HOST_DIR/usr/bin/mkimage -A arm -O linux -T script -C none -a 0 -e 0 \
+    -n "upgrade script" -d $BOARD_DIR/6x_upgrade.txt $TARGET_DIR/6x_upgrade
 fi
index d04745d1250ea70ba46cfbd92d47f4f868b9d6d0..71b01f0cededc3a69b69a5fc9a9242c90d19d266 100644 (file)
@@ -6,6 +6,7 @@ BR2_cortex_a9=y
 BR2_TARGET_GENERIC_GETTY=y
 BR2_TARGET_GENERIC_GETTY_PORT="ttymxc1"
 BR2_ROOTFS_POST_BUILD_SCRIPT="board/boundarydevices/nitrogen6x/post-build.sh"
+BR2_PACKAGE_HOST_UBOOT_TOOLS=y
 
 # filesystem
 BR2_TARGET_ROOTFS_EXT2=y