You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
223 lines
6.5 KiB
223 lines
6.5 KiB
#!/bin/bash |
|
|
|
SCRIPTDIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd ) |
|
source $SCRIPTDIR/common.sh |
|
|
|
############################################################## |
|
# main |
|
############################################################## |
|
while getopts "flpu:" opt; do |
|
case $opt in |
|
f) |
|
echo "fastboot enabled" |
|
METHOD=fastboot |
|
;; |
|
l) |
|
echo "factory mode remain in u-boot after flashing" |
|
AFTER_FLASHING=loop |
|
;; |
|
u) |
|
BUILDROOT_OUTPUT_DIR="${OPTARG}" |
|
;; |
|
p) |
|
POCKET_CHIP=true |
|
;; |
|
\?) |
|
echo "Invalid option: -$OPTARG" >&2 |
|
exit 1 |
|
;; |
|
esac |
|
done |
|
|
|
echo "BUILDROOT_OUTPUT_DIR = $BUILDROOT_OUTPUT_DIR" |
|
|
|
FEL=fel |
|
|
|
METHOD=${METHOD:-fel} |
|
AFTER_FLASHING=${AFTER_FLASHING:-wait} |
|
|
|
|
|
NAND_ERASE_BB=false |
|
if [ "$1" == "erase-bb" ]; then |
|
NAND_ERASE_BB=true |
|
fi |
|
|
|
PATH=$PATH:$BUILDROOT_OUTPUT_DIR/host/usr/bin |
|
TMPDIR=`mktemp -d -t chipflashXXXXXX` |
|
PADDED_SPL="${BUILDROOT_OUTPUT_DIR}/images/sunxi-spl-with-ecc.bin" |
|
PADDED_SPL_SIZE=0 |
|
UBOOT_SCRIPT="$TMPDIR/uboot.scr" |
|
UBOOT_SCRIPT_MEM_ADDR=0x43100000 |
|
UBOOT_SCRIPT_SRC="$TMPDIR/uboot.cmds" |
|
SPL="$BUILDROOT_OUTPUT_DIR/images/sunxi-spl.bin" |
|
SPL_MEM_ADDR=0x43000000 |
|
UBOOT="$BUILDROOT_OUTPUT_DIR/images/u-boot-dtb.bin" |
|
PADDED_UBOOT="$TMPDIR/padded-uboot" |
|
PADDED_UBOOT_SIZE=0x400000 |
|
UBOOT_MEM_ADDR=0x4a000000 |
|
UBI="$BUILDROOT_OUTPUT_DIR/images/rootfs.ubi" |
|
SPARSE_UBI="${TMPDIR}/rootfs.ubi.sparse" |
|
UBI_MEM_ADDR=0x4b000000 |
|
|
|
UBI_SIZE=`filesize $UBI | xargs printf "0x%08x"` |
|
PAGE_SIZE=16384 |
|
OOB_SIZE=1664 |
|
|
|
prepare_images() { |
|
#PADDED_SPL_SIZE in pages |
|
if [[ ! -e "${PADDED_SPL}" ]]; then |
|
echo "ERROR: can not read ${PADDED_SPL}" |
|
exit 1 |
|
fi |
|
|
|
PADDED_SPL_SIZE=$(filesize "${PADDED_SPL}") |
|
PADDED_SPL_SIZE=$(($PADDED_SPL_SIZE / ($PAGE_SIZE + $OOB_SIZE))) |
|
PADDED_SPL_SIZE=$(echo $PADDED_SPL_SIZE | xargs printf "0x%08x") |
|
echo "PADDED_SPL_SIZE=$PADDED_SPL_SIZE" |
|
|
|
# Align the u-boot image on a page boundary |
|
dd if="$UBOOT" of="$PADDED_UBOOT" bs=4M conv=sync |
|
UBOOT_SIZE=`filesize "$PADDED_UBOOT" | xargs printf "0x%08x"` |
|
echo "UBOOT_SIZE=${UBOOT_SIZE}" |
|
echo "PADDED_UBOOT_SIZE=${PADDED_UBOOT_SIZE}" |
|
dd if=/dev/urandom of="$PADDED_UBOOT" seek=$((UBOOT_SIZE / 0x4000)) bs=16k count=$(((PADDED_UBOOT_SIZE - UBOOT_SIZE) / 0x4000)) |
|
} |
|
|
|
prepare_uboot_script() { |
|
if [ "$NAND_ERASE_BB" = true ] ; then |
|
echo "nand scrub -y 0x0 0x200000000" > "${UBOOT_SCRIPT_SRC}" |
|
else |
|
echo "nand erase 0x0 0x200000000" > "${UBOOT_SCRIPT_SRC}" |
|
fi |
|
|
|
echo "echo nand write.raw.noverify $SPL_MEM_ADDR 0x0 $PADDED_SPL_SIZE" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "nand write.raw.noverify $SPL_MEM_ADDR 0x0 $PADDED_SPL_SIZE" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "echo nand write.raw.noverify $SPL_MEM_ADDR 0x400000 $PADDED_SPL_SIZE" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "nand write.raw.noverify $SPL_MEM_ADDR 0x400000 $PADDED_SPL_SIZE" >> "${UBOOT_SCRIPT_SRC}" |
|
|
|
echo "nand write $UBOOT_MEM_ADDR 0x800000 $PADDED_UBOOT_SIZE" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "setenv bootargs root=ubi0:rootfs rootfstype=ubifs rw earlyprintk ubi.mtd=4" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "setenv bootcmd 'gpio set PB2; if test -n \${fel_booted} && test -n \${scriptaddr}; then echo '(FEL boot)'; source \${scriptaddr}; fi; mtdparts; ubi part UBI; ubifsmount ubi0:rootfs; ubifsload \$fdt_addr_r /boot/sun5i-r8-chip.dtb; ubifsload \$kernel_addr_r /boot/zImage; bootz \$kernel_addr_r - \$fdt_addr_r'" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "setenv fel_booted 0" >> "${UBOOT_SCRIPT_SRC}" |
|
|
|
echo "echo Enabling Splash" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "setenv stdout serial" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "setenv stderr serial" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "setenv splashpos m,m" >> "${UBOOT_SCRIPT_SRC}" |
|
|
|
echo "echo Configuring Video Mode" |
|
if [[ "${POCKET_CHIP}" == "true" ]]; then |
|
echo "setenv video-mode" >> "${UBOOT_SCRIPT_SRC}" |
|
else |
|
echo "setenv video-mode sunxi:640x480-24@60,monitor=composite-ntsc,overscan_x=40,overscan_y=20" >> "${UBOOT_SCRIPT_SRC}" |
|
fi |
|
|
|
echo "saveenv" >> "${UBOOT_SCRIPT_SRC}" |
|
|
|
if [[ "${METHOD}" == "fel" ]]; then |
|
echo "nand write.slc-mode.trimffs $UBI_MEM_ADDR 0x1000000 $UBI_SIZE" >> "${UBOOT_SCRIPT_SRC}" |
|
echo "mw \${scriptaddr} 0x0" >> "${UBOOT_SCRIPT_SRC}" |
|
else |
|
echo "echo going to fastboot mode" >>"${UBOOT_SCRIPT_SRC}" |
|
echo "fastboot 0" >>"${UBOOT_SCRIPT_SRC}" |
|
fi |
|
|
|
if [[ "${AFTER_FLASHING}" == "boot" ]]; then |
|
echo "echo " >>"${UBOOT_SCRIPT_SRC}" |
|
echo "echo *****************[ BOOT ]*****************" >>"${UBOOT_SCRIPT_SRC}" |
|
echo "echo " >>"${UBOOT_SCRIPT_SRC}" |
|
echo "boot" >> "${UBOOT_SCRIPT_SRC}" |
|
else |
|
echo "echo " >>"${UBOOT_SCRIPT_SRC}" |
|
echo "echo *****************[ FLASHING DONE ]*****************" >>"${UBOOT_SCRIPT_SRC}" |
|
echo "echo " >>"${UBOOT_SCRIPT_SRC}" |
|
if [[ "${METHOD}" == "fel" ]]; then |
|
echo "reset" |
|
else |
|
echo "while true; do; sleep 10; done;" >>"${UBOOT_SCRIPT_SRC}" |
|
fi |
|
fi |
|
|
|
mkimage -A arm -T script -C none -n "flash CHIP" -d "${UBOOT_SCRIPT_SRC}" "${UBOOT_SCRIPT}" |
|
} |
|
|
|
assert_error() { |
|
ERR=$? |
|
ERRCODE=$1 |
|
if [ "${ERR}" != "0" ]; then |
|
if [ -z "${ERR}" ]; then |
|
exit ${ERR} |
|
else |
|
exit ${ERRCODE} |
|
fi |
|
fi |
|
} |
|
|
|
echo == preparing images == |
|
prepare_images |
|
prepare_uboot_script |
|
|
|
echo == upload the SPL to SRAM and execute it == |
|
if ! wait_for_fel; then |
|
echo "ERROR: please make sure CHIP is connected and jumpered in FEL mode" |
|
fi |
|
${FEL} spl "${SPL}" |
|
assert_error 128 |
|
|
|
sleep 1 # wait for DRAM initialization to complete |
|
|
|
echo == upload spl == |
|
${FEL} write $SPL_MEM_ADDR "${PADDED_SPL}" || ( echo "ERROR: could not write ${PADDED_SPL}" && exit $? ) |
|
assert_error 129 |
|
|
|
echo == upload u-boot == |
|
${FEL} write $UBOOT_MEM_ADDR "${PADDED_UBOOT}" || ( echo "ERROR: could not write ${PADDED_UBOOT}" && exit $? ) |
|
assert_error 130 |
|
|
|
echo == upload u-boot script == |
|
${FEL} write $UBOOT_SCRIPT_MEM_ADDR "${UBOOT_SCRIPT}" || ( echo "ERROR: could not write ${UBOOT_SCRIPT}" && exit $? ) |
|
assert_error 131 |
|
|
|
if [[ "${METHOD}" == "fel" ]]; then |
|
echo == upload ubi == |
|
${FEL} --progress write $UBI_MEM_ADDR "${UBI}" |
|
|
|
echo == execute the main u-boot binary == |
|
${FEL} exe $UBOOT_MEM_ADDR |
|
|
|
echo == write ubi == |
|
else |
|
echo == execute the main u-boot binary == |
|
${FEL} exe $UBOOT_MEM_ADDR |
|
assert_error 132 |
|
|
|
echo == creating sparse image == |
|
img2simg ${UBI} ${SPARSE_UBI} $((2*1024*1024)) |
|
assert_error 133 |
|
|
|
echo == waiting for fastboot == |
|
if wait_for_fastboot; then |
|
fastboot -i 0x1f3a -u flash UBI ${SPARSE_UBI} |
|
assert_error 134 |
|
|
|
fastboot -i 0x1f3a continue |
|
assert_error 135 |
|
else |
|
rm -rf "${TMPDIR}" |
|
exit 1 |
|
fi |
|
fi |
|
|
|
if [[ "${METHOD}" == "fel" ]]; then |
|
if ! wait_for_linuxboot; then |
|
echo "ERROR: could not flash": |
|
rm -rf ${TMPDIR} |
|
exit 1 |
|
else |
|
${SCRIPTDIR}/verify.sh |
|
fi |
|
fi |
|
rm -rf "${TMPDIR}" |
|
|
|
ready_to_roll |
|
|
|
|