#!/bin/sh #### This is update.sh.txt as posted on oesf.org/forums in Feb06 #### Probably from OpenZaurus 3.5.3 #### I'm trying to interpret it by guessing. DO DOUBLE CHECK! #### All my commets have four leading hash signs. jan #### DATAPATH is where this script assumes files such as kernel and rootfs images DATAPATH=$1 #### TMP???? are used while flashing TMPPATH=/tmp/update TMPDATA=$TMPPATH/tmpdata.bin TMPHEAD=$TMPPATH/tmphead.bin #### won't flash kernel if true WFLG_KERNEL=0 #### dito for root fs image WFLG_INITRD=0 WFLG_MVERSION=0 #### parse /proc/mtd for partitions #### ENVVAR "Filesystem" #### RO root #### RW home #### ??_MTD=/mnt/mtd? no '/' after 'mtd'? #### ??_MTD_MTDBLK=/mnt/mtdblock? mount device #### ??_MTD_SIZE in kibi(bytes) RO_MTD_LINE=`cat /proc/mtd | grep "root" | tail -n 1` if [ "$RO_MTD_LINE" = "" ]; then RO_MTD_LINE=`cat /proc/mtd | grep "\.*\<2\>" | tail -n 1` fi #### from RO_MTD_LINE take anything between first 'd' and first ':' #### RO_MTD_LINE is from/proc/mtd, so RO_MTD_NO will be single numerical char RO_MTD_NO=`echo $RO_MTD_LINE | cut -d: -f1 | cut -dd -f2` RO_MTD_SIZE_HEX=`echo $RO_MTD_LINE | cut -d" " -f2` RO_MTD=/dev/mtd$RO_MTD_NO RO_MTDBLK=/dev/mtdblock$RO_MTD_NO RO_MTD_SIZE=`dc 0x$RO_MTD_SIZE_HEX 1024 /` RW_MTD_LINE=`cat /proc/mtd | grep "home" | tail -n 1` if [ "$RW_MTD_LINE" = "" ]; then RW_MTD_LINE=`cat /proc/mtd | grep "\.*\<2\>" | tail -n 1` fi RW_MTD_NO=`echo $RW_MTD_LINE | cut -d: -f1 | cut -dd -f2` RW_MTD_SIZE_HEX=`echo $RW_MTD_LINE | cut -d" " -f2` RW_MTD=/dev/mtd$RW_MTD_NO RW_MTDBLK=/dev/mtdblock$RW_MTD_NO RW_MTD_SIZE=`dc 0x$RW_MTD_SIZE_HEX 1024 /` #### LOGOCAL_MTD=/dev/mtd1 VERBLOCK=0x48000 MVRBLOCK=0x70000 RESULT=0 #### clean up and exit on SIGHUP and SIGTERM #### ignore SIGINT and SIGQUIT Cleanup(){ rm -f $VTMPNAME > /dev/null 2>&1 rm -f $MTMPNAME > /dev/null 2>&1 rm $CTRLPATH/* > /dev/null 2>&1 rm $DATAPATH/* > /dev/null 2>&1 exit $1 } trap 'Cleanup 1' 1 15 trap '' 2 3 #### ### Check model ### /sbin/writerominfo MODEL=`cat /proc/deviceinfo/product` echo 'MODEL:'$MODEL case "$MODEL" in SL-C700) ;; SL-C750) ;; SL-C760) ;; SL-C860) ;; SL-B500) ;; SL-5600) ;; *) echo 'ERROR:Invalid model!' echo 'Please reset' while true do done ;; esac mkdir -p $TMPPATH > /dev/null 2>&1 cd $DATAPATH/ #### Below is the actual flashing procedure #### Loops over existing files in $DATAPATH with special filenames: #### $TARGETFILE $TARGETTYPE #### zImage.bin Kernel #### zimage.bin Kernel #### ZIMAGE.BIN Kernel #### initrd.bin RoFs #### INITRD.BIN RoFs #### mversion.bin MasterVer #### MVERSION.BIN MasterVer #### TARGETTYPE=Invalid is impossible #### TARGETTYPE=MasterVer will not occur during OZ installations as described #### at openzaurus.org for TARGETFILE in zImage.bin zimage.bin ZIMAGE.BIN initrd.bin INITRD.BIN mversion.bin MVERSION.BIN do if [ -e $TARGETFILE ] then rm -f $TMPPATH/*.bin > /dev/null 2>&1 #### size of image in Bytes DATASIZE=`wc -c $TARGETFILE` DATASIZE=`echo $DATASIZE | cut -d' ' -f1` #echo $TARGETFILE':'$DATASIZE'bytes' TARGETTYPE=Invalid case "$TARGETFILE" in zImage.bin) TARGETTYPE=Kernel;; zimage.bin) TARGETTYPE=Kernel;; ZIMAGE.BIN) TARGETTYPE=Kernel;; initrd.bin) TARGETTYPE=RoFs;; INITRD.BIN) TARGETTYPE=RoFs;; mversion.bin) TARGETTYPE=MasterVer;; MVERSION.BIN) TARGETTYPE=MasterVer;; *) continue ;; esac case "$TARGETTYPE" in Kernel) #### will flash kernel only once if [ $WFLG_KERNEL != 0 ] then continue fi WFLG_KERNEL=1 #### echo 'kernel' ISLOGICAL=1 MODULEID=5 MODULESIZE=0x13C000 ADDR=`dc 0xE0000` #### doesn't need formatting below ISFORMATTED=1 DATAPOS=0 ONESIZE=524288 #### WTF? HDTOP=`expr $DATASIZE - 16` /sbin/bcut -a $HDTOP -s 16 -o $TMPHEAD $TARGETFILE #### ;; RoFs) if [ $WFLG_INITRD != 0 ] then continue fi WFLG_INITRD=1 echo 'RO file system' ISLOGICAL=0 MODULEID=6 MODULESIZE=0x1900000 ADDR=0 #### partition RO=/home will be formatted below ISFORMATTED=0 TARGET_MTD=$RO_MTD #### DATAPOS=16 ONESIZE=1048576 /sbin/bcut -s 16 -o $TMPHEAD $TARGETFILE ;; MasterVer) if [ $WFLG_MVERSION != 0 ] then continue fi WFLG_MVERSION=1 echo 'Master version' MTMPNAME=$TMPPATH'/mtmp'`date '+%s'`'.tmp' /sbin/nandlogical $LOGOCAL_MTD READ $MVRBLOCK 0x4000 $MTMPNAME > /dev/null 2>&1 /sbin/verchg -m $MTMPNAME $TARGETFILE 0 0 > /dev/null 2>&1 /sbin/nandlogical $LOGOCAL_MTD WRITE $MVRBLOCK 0x4000 $MTMPNAME > /dev/null 2>&1 rm -f $MTMPNAME > /dev/null 2>&1 echo 'Success!' continue ;; *) continue ;; esac #### format/erase partition unless $ISFORMATTED #### (will erase root partition before flashing) #format? if [ $ISFORMATTED = 0 ] then echo -n 'Flash erasing...' /sbin/eraseall $TARGET_MTD 2> /dev/null > /dev/null #/sbin/eraseall $TARGET_MTD 2 echo 'done' ISFORMATTED=1 fi #### prepare progress bar echo '' echo '0% 100%' PROGSTEP=`expr $DATASIZE / $ONESIZE + 1` PROGSTEP=`expr 25 / $PROGSTEP` if [ $PROGSTEP = 0 ] then PROGSTEP=1 fi #### #### WTF? #00 means header information VTMPNAME=$TMPPATH'/vtmp'`date '+%s'`'.tmp' MTMPNAME=$TMPPATH'/mtmp'`date '+%s'`'.tmp' /sbin/nandlogical $LOGOCAL_MTD READ $VERBLOCK 0x4000 $VTMPNAME > /dev/null 2>&1 /sbin/nandlogical $LOGOCAL_MTD READ $MVRBLOCK 0x4000 $MTMPNAME > /dev/null 2>&1 #echo 'found header' /sbin/verchg -v $VTMPNAME $TMPHEAD $MODULEID $MODULESIZE > /dev/null 2>&1 /sbin/verchg -m $MTMPNAME $TMPHEAD $MODULEID $MODULESIZE > /dev/null 2>&1 #### FLASH!!! #loop while [ $DATAPOS -lt $DATASIZE ] do #data create bcut -a $DATAPOS -s $ONESIZE -o $TMPDATA $TARGETFILE TMPSIZE=`wc -c $TMPDATA` TMPSIZE=`echo $TMPSIZE | cut -d' ' -f1` DATAPOS=`expr $DATAPOS + $TMPSIZE` #handle data file #echo 'ADDR='$ADDR #echo 'SIZE='$TMPSIZE if [ $ISLOGICAL = 0 ] then next_addr=`/sbin/nandcp -a $ADDR $TMPDATA $TARGET_MTD 2>/dev/null | fgrep "mtd address" | cut -d- -f2 | cut -d\( -f1` if [ "$next_addr" = "" ]; then echo "ERROR:flash write" rm $TMPDATA > /dev/null 2>&1 RESULT=3 break; fi ADDR=$next_addr else /sbin/nandlogical $LOGOCAL_MTD WRITE $ADDR $DATASIZE $TMPDATA > /dev/null 2>&1 ADDR=`expr $ADDR + $TMPSIZE` fi rm $TMPDATA > /dev/null 2>&1 #progress SPNUM=0 while [ $SPNUM -lt $PROGSTEP ] do echo -n '.' SPNUM=`expr $SPNUM + 1` done done echo '' #finish rm -f $TMPPATH/*.bin > /dev/null 2>&1 if [ $RESULT = 0 ] then /sbin/nandlogical $LOGOCAL_MTD WRITE $VERBLOCK 0x4000 $VTMPNAME > /dev/null 2>&1 /sbin/nandlogical $LOGOCAL_MTD WRITE $MVRBLOCK 0x4000 $MTMPNAME > /dev/null 2>&1 rm -f $VTMPNAME > /dev/null 2>&1 rm -f $MTMPNAME > /dev/null 2>&1 echo 'Success!' else echo 'Error!' exit $RESULT fi fi done exit 0