added sunxi-spl-with-ecc
Signed-off-by: Alex Kaplan <kaplan2539@gmail.com>
This commit is contained in:
parent
210f269ed8
commit
34f162379c
|
@ -3,12 +3,36 @@
|
||||||
SCRIPTDIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
SCRIPTDIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
||||||
source $SCRIPTDIR/common.sh
|
source $SCRIPTDIR/common.sh
|
||||||
|
|
||||||
|
##############################################################
|
||||||
|
# main
|
||||||
|
##############################################################
|
||||||
|
while getopts "flu:" 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}"
|
||||||
|
;;
|
||||||
|
\?)
|
||||||
|
echo "Invalid option: -$OPTARG" >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "BUILDROOT_OUTPUT_DIR = $BUILDROOT_OUTPUT_DIR"
|
||||||
|
|
||||||
FEL=fel
|
FEL=fel
|
||||||
|
|
||||||
METHOD=${METHOD:-fel}
|
METHOD=${METHOD:-fel}
|
||||||
AFTER_FLASHING=${AFTER_FLASHING:-boot}
|
AFTER_FLASHING=${AFTER_FLASHING:-wait}
|
||||||
|
|
||||||
echo "BUILDROOT_OUTPUT_DIR = $BUILDROOT_OUTPUT_DIR"
|
|
||||||
|
|
||||||
NAND_ERASE_BB=false
|
NAND_ERASE_BB=false
|
||||||
if [ "$1" == "erase-bb" ]; then
|
if [ "$1" == "erase-bb" ]; then
|
||||||
|
@ -17,7 +41,7 @@ fi
|
||||||
|
|
||||||
PATH=$PATH:$BUILDROOT_OUTPUT_DIR/host/usr/bin
|
PATH=$PATH:$BUILDROOT_OUTPUT_DIR/host/usr/bin
|
||||||
TMPDIR=`mktemp -d -t chipflashXXXXXX`
|
TMPDIR=`mktemp -d -t chipflashXXXXXX`
|
||||||
PADDED_SPL="$TMPDIR/sunxi-padded-spl"
|
PADDED_SPL="${BUILDROOT_OUTPUT_DIR}/images/sunxi-spl-with-ecc.bin"
|
||||||
PADDED_SPL_SIZE=0
|
PADDED_SPL_SIZE=0
|
||||||
UBOOT_SCRIPT="$TMPDIR/uboot.scr"
|
UBOOT_SCRIPT="$TMPDIR/uboot.scr"
|
||||||
UBOOT_SCRIPT_MEM_ADDR=0x43100000
|
UBOOT_SCRIPT_MEM_ADDR=0x43100000
|
||||||
|
@ -36,31 +60,22 @@ PAGE_SIZE=16384
|
||||||
OOB_SIZE=1664
|
OOB_SIZE=1664
|
||||||
|
|
||||||
prepare_images() {
|
prepare_images() {
|
||||||
local in=$SPL
|
#PADDED_SPL_SIZE in pages
|
||||||
local out=$PADDED_SPL
|
if [[ ! -e "${PADDED_SPL}" ]]; then
|
||||||
|
echo "ERROR: can not read ${PADDED_SPL}"
|
||||||
if [ -e $out ]; then
|
exit 1
|
||||||
rm $out
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ ! -e "${SCRIPTDIR}/spl-image-builder" ]]; then
|
|
||||||
pushd "${SCRIPTDIR}"
|
|
||||||
make
|
|
||||||
popd
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
"${SCRIPTDIR}/spl-image-builder" -d -r 3 -u 4096 -o 1664 -p 16384 -c 1024 -s 64 "$in" "$out"
|
PADDED_SPL_SIZE=$(filesize "${PADDED_SPL}")
|
||||||
|
|
||||||
#PADDED_SPL_SIZE in pages
|
|
||||||
PADDED_SPL_SIZE=$(filesize "$out")
|
|
||||||
PADDED_SPL_SIZE=$(($PADDED_SPL_SIZE / ($PAGE_SIZE + $OOB_SIZE)))
|
PADDED_SPL_SIZE=$(($PADDED_SPL_SIZE / ($PAGE_SIZE + $OOB_SIZE)))
|
||||||
PADDED_SPL_SIZE=$(echo $PADDED_SPL_SIZE | xargs printf "0x%08x")
|
PADDED_SPL_SIZE=$(echo $PADDED_SPL_SIZE | xargs printf "0x%08x")
|
||||||
echo "filesize= $(filesize "$out")"
|
|
||||||
echo "PADDED_SPL_SIZE=$PADDED_SPL_SIZE"
|
echo "PADDED_SPL_SIZE=$PADDED_SPL_SIZE"
|
||||||
|
|
||||||
# Align the u-boot image on a page boundary
|
# Align the u-boot image on a page boundary
|
||||||
dd if="$UBOOT" of="$PADDED_UBOOT" bs=16k conv=sync
|
dd if="$UBOOT" of="$PADDED_UBOOT" bs=16k conv=sync
|
||||||
UBOOT_SIZE=`filesize "$PADDED_UBOOT" | xargs printf "0x%08x"`
|
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))
|
dd if=/dev/urandom of="$PADDED_UBOOT" seek=$((UBOOT_SIZE / 0x4000)) bs=16k count=$(((PADDED_UBOOT_SIZE - UBOOT_SIZE) / 0x4000))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -107,26 +122,6 @@ prepare_uboot_script() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
##############################################################
|
|
||||||
# main
|
|
||||||
##############################################################
|
|
||||||
while getopts "fl" opt; do
|
|
||||||
case $opt in
|
|
||||||
f)
|
|
||||||
echo "fastboot enabled"
|
|
||||||
METHOD=fastboot
|
|
||||||
;;
|
|
||||||
l)
|
|
||||||
echo "factory mode remain in u-boot after flashing"
|
|
||||||
AFTER_FLASHING=loop
|
|
||||||
;;
|
|
||||||
\?)
|
|
||||||
echo "Invalid option: -$OPTARG" >&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
|
|
||||||
echo == preparing images ==
|
echo == preparing images ==
|
||||||
prepare_images
|
prepare_images
|
||||||
|
@ -141,13 +136,13 @@ ${FEL} spl "${SPL}"
|
||||||
sleep 1 # wait for DRAM initialization to complete
|
sleep 1 # wait for DRAM initialization to complete
|
||||||
|
|
||||||
echo == upload spl ==
|
echo == upload spl ==
|
||||||
${FEL} write $SPL_MEM_ADDR "${PADDED_SPL}"
|
${FEL} write $SPL_MEM_ADDR "${PADDED_SPL}" || ( echo "ERROR: could not write ${PADDED_SPL}" && exit $? )
|
||||||
|
|
||||||
echo == upload u-boot ==
|
echo == upload u-boot ==
|
||||||
${FEL} write $UBOOT_MEM_ADDR "${PADDED_UBOOT}"
|
${FEL} write $UBOOT_MEM_ADDR "${PADDED_UBOOT}" || ( echo "ERROR: could not write ${PADDED_UBOOT}" && exit $? )
|
||||||
|
|
||||||
echo == upload u-boot script ==
|
echo == upload u-boot script ==
|
||||||
${FEL} write $UBOOT_SCRIPT_MEM_ADDR "${UBOOT_SCRIPT}"
|
${FEL} write $UBOOT_SCRIPT_MEM_ADDR "${UBOOT_SCRIPT}" || ( echo "ERROR: could not write ${UBOOT_SCRIPT}" && exit $? )
|
||||||
|
|
||||||
if [[ "${METHOD}" == "fel" ]]; then
|
if [[ "${METHOD}" == "fel" ]]; then
|
||||||
echo == upload ubi ==
|
echo == upload ubi ==
|
||||||
|
|
|
@ -32,17 +32,23 @@ function cache_download {
|
||||||
if [[ "${S3_MD5}" != "${MD5}" ]]; then
|
if [[ "${S3_MD5}" != "${MD5}" ]]; then
|
||||||
echo "md5sum differs"
|
echo "md5sum differs"
|
||||||
rm ${DEST_DIR}/${FILE}
|
rm ${DEST_DIR}/${FILE}
|
||||||
wget -P "${FW_IMAGE_DIR}" "${SRC_URL}/${FILE}"
|
if ! wget -P "${FW_IMAGE_DIR}" "${SRC_URL}/${FILE}"; then
|
||||||
|
echo "download of ${SRC_URL}/${FILE} failed!"
|
||||||
|
exit $?
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
echo "file already downloaded"
|
echo "file already downloaded"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
wget -P "${FW_IMAGE_DIR}" "${SRC_URL}/${FILE}"
|
if ! wget -P "${FW_IMAGE_DIR}" "${SRC_URL}/${FILE}"; then
|
||||||
|
echo "download of ${SRC_URL}/${FILE} failed!"
|
||||||
|
exit $?
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
while getopts "ufd" opt; do
|
while getopts "ufdb:w:" opt; do
|
||||||
case $opt in
|
case $opt in
|
||||||
u)
|
u)
|
||||||
echo "updating cache"
|
echo "updating cache"
|
||||||
|
@ -54,6 +60,14 @@ while getopts "ufd" opt; do
|
||||||
echo "fastboot enabled"
|
echo "fastboot enabled"
|
||||||
FLASH_SCRIPT_OPTION="-f"
|
FLASH_SCRIPT_OPTION="-f"
|
||||||
;;
|
;;
|
||||||
|
b)
|
||||||
|
BRANCH="$OPTARG"
|
||||||
|
echo "BRANCH = ${BRANCH}"
|
||||||
|
;;
|
||||||
|
w)
|
||||||
|
WHAT="$OPTARG"
|
||||||
|
echo "WHAT = ${BRANCH}"
|
||||||
|
;;
|
||||||
d)
|
d)
|
||||||
echo "debian selected"
|
echo "debian selected"
|
||||||
WHAT="debian"
|
WHAT="debian"
|
||||||
|
@ -97,11 +111,12 @@ require_directory "${FW_IMAGE_DIR}"
|
||||||
cache_download "${FW_IMAGE_DIR}" ${ROOTFS_URL} rootfs.ubi
|
cache_download "${FW_IMAGE_DIR}" ${ROOTFS_URL} rootfs.ubi
|
||||||
cache_download "${FW_IMAGE_DIR}" ${BR_URL} sun5i-r8-chip.dtb
|
cache_download "${FW_IMAGE_DIR}" ${BR_URL} sun5i-r8-chip.dtb
|
||||||
cache_download "${FW_IMAGE_DIR}" ${BR_URL} sunxi-spl.bin
|
cache_download "${FW_IMAGE_DIR}" ${BR_URL} sunxi-spl.bin
|
||||||
|
cache_download "${FW_IMAGE_DIR}" ${BR_URL} sunxi-spl-with-ecc.bin
|
||||||
cache_download "${FW_IMAGE_DIR}" ${BR_URL} uboot-env.bin
|
cache_download "${FW_IMAGE_DIR}" ${BR_URL} uboot-env.bin
|
||||||
cache_download "${FW_IMAGE_DIR}" ${BR_URL} zImage
|
cache_download "${FW_IMAGE_DIR}" ${BR_URL} zImage
|
||||||
cache_download "${FW_IMAGE_DIR}" ${BR_URL} u-boot-dtb.bin
|
cache_download "${FW_IMAGE_DIR}" ${BR_URL} u-boot-dtb.bin
|
||||||
|
|
||||||
BUILDROOT_OUTPUT_DIR="${FW_DIR}" ${FLASH_SCRIPT} ${FLASH_SCRIPT_OPTION}
|
BUILDROOT_OUTPUT_DIR="${FW_DIR}" ${FLASH_SCRIPT} ${FLASH_SCRIPT_OPTION} || echo "ERROR: could not flash" && exit 1
|
||||||
|
|
||||||
if ! wait_for_linuxboot; then
|
if ! wait_for_linuxboot; then
|
||||||
echo "ERROR: could not flash"
|
echo "ERROR: could not flash"
|
||||||
|
|
Loading…
Reference in New Issue