0
0
mirror of https://github.com/Doodle3D/doodle3d-firmware.git synced 2024-12-31 15:03:48 +01:00

Bumped firmware version.

Fixed image index generator to include all available image versions.
This commit is contained in:
Wouter R 2013-10-21 16:06:48 +02:00
parent 5c199eca94
commit 6ddd038495
2 changed files with 59 additions and 18 deletions

View File

@ -1,11 +1,48 @@
#!/bin/sh #!/bin/sh
# NOTE: this script generates an index based on images found in the target directory.
# So make sure it contains all images ever released (unless you want to actually remove them).
# If this is not the case, first create a mirror of doodle3d.com/updates/images.
#prevent being run as root (which is dangerous) #prevent being run as root (which is dangerous)
if [ "$(id -u)" == "0" ]; then if [ "$(id -u)" == "0" ]; then
echo "Don't run this script as root, it is potentially dangerous." 1>&2 echo "Don't run this script as root, it is potentially dangerous." 1>&2
exit 1 exit 1
fi fi
# expects path of file to return the size of
fileSize() {
stat -f %z ${1}
}
# expects arguments: version, devType, sysupgrade|factory
# image name will be: '${IMAGE_BASENAME}-<version>-<devType>-<sysupgrade|factory>.bin'
constructImageName() {
if [ $# -lt 3 ]; then echo "incorrect usage of constructImageName()"; exit 1; fi
echo "${IMAGE_BASENAME}-${1}-${2}-${3}.bin"
}
# expects arguments: basePath (where the files are), version, devType
generateIndexEntry() {
if [ $# -lt 3 ]; then echo "incorrect usage of generateIndexEntry()"; exit 1; fi
sysupgrade_out_basename=`constructImageName ${2} ${3} sysupgrade`
factory_out_basename=`constructImageName ${2} ${3} factory`
sysupgrade_out_file=${1}/${sysupgrade_out_basename}
factory_out_file=${1}/${factory_out_basename}
sysupgrade_filesize=`fileSize ${sysupgrade_out_file}`
factory_filesize=`fileSize ${factory_out_file}`
sysupgrade_md5sum=`md5 -q ${sysupgrade_out_file}`
factory_md5sum=`md5 -q ${factory_out_file}`
echo "Version: ${2}" >> $IMG_INDEX_FILE
echo "Files: ${sysupgrade_out_basename}; ${factory_out_basename}" >> $IMG_INDEX_FILE
echo "FileSize: ${sysupgrade_filesize}; ${factory_filesize}" >> $IMG_INDEX_FILE
echo "MD5: ${sysupgrade_md5sum}; ${factory_md5sum}" >> $IMG_INDEX_FILE
}
OPENWRT_BASE=. OPENWRT_BASE=.
PKG_SRC_DIR=$OPENWRT_BASE/bin/ar71xx/packages PKG_SRC_DIR=$OPENWRT_BASE/bin/ar71xx/packages
PKG_DEST_SUBPATH=updates PKG_DEST_SUBPATH=updates
@ -19,6 +56,7 @@ IMAGE_BASENAME="doodle3d-wifibox"
COMPRESS_RESULT=0 COMPRESS_RESULT=0
PKG_DEST_BASE=. PKG_DEST_BASE=.
for arg in "$@"; do for arg in "$@"; do
case $arg in case $arg in
-h) -h)
@ -46,6 +84,7 @@ if [ $? -ne 0 ]; then
exit 1 exit 1
fi fi
#determine the wifibox root path #determine the wifibox root path
my_rel_dir=`dirname $0` my_rel_dir=`dirname $0`
pushd "$my_rel_dir" > /dev/null pushd "$my_rel_dir" > /dev/null
@ -83,32 +122,34 @@ for devtype in $DEVICE_TYPES; do
if [ -f $IMG_SRC_PATH/openwrt-ar71xx-generic-${devtype}-v1-squashfs-sysupgrade.bin ]; then if [ -f $IMG_SRC_PATH/openwrt-ar71xx-generic-${devtype}-v1-squashfs-sysupgrade.bin ]; then
sysupgrade_name=$IMG_SRC_PATH/openwrt-ar71xx-generic-${devtype}-v1-squashfs-sysupgrade.bin sysupgrade_name=$IMG_SRC_PATH/openwrt-ar71xx-generic-${devtype}-v1-squashfs-sysupgrade.bin
factory_name=$IMG_SRC_PATH/openwrt-ar71xx-generic-${devtype}-v1-squashfs-factory.bin factory_name=$IMG_SRC_PATH/openwrt-ar71xx-generic-${devtype}-v1-squashfs-factory.bin
sysupgrade_size=`stat -f %z $sysupgrade_name` sysupgrade_size=`fileSize $sysupgrade_name`
factory_size=`stat -f %z $factory_name` factory_size=`fileSize $factory_name`
sysupgrade_out_basename=$IMAGE_BASENAME-${FW_VERSION}-${devtype}-sysupgrade.bin
factory_out_basename=$IMAGE_BASENAME-${FW_VERSION}-${devtype}-factory.bin
echo "Copying images for device '${devtype}' (sysupgrade size: ${sysupgrade_size}, factory size: ${factory_size})" echo "Copying images for device '${devtype}' (sysupgrade size: ${sysupgrade_size}, factory size: ${factory_size})"
cp $sysupgrade_name $PKG_IMG_DIR/`constructImageName ${FW_VERSION} ${devtype} sysupgrade`
#TODO: replace 'wc -c' with something more efficient (stat? ls?) cp $factory_name $PKG_IMG_DIR/`constructImageName ${FW_VERSION} ${devtype} factory`
sysupgrade_filesize=`wc -c < ${sysupgrade_name} | tr -d ' '`
factory_filesize=`wc -c < ${factory_name} | tr -d ' '`
sysupgrade_md5sum=`md5 -q ${sysupgrade_name}`
factory_md5sum=`md5 -q ${factory_name}`
echo "Version: ${FW_VERSION}" >> $IMG_INDEX_FILE
echo "Files: ${sysupgrade_out_basename}; ${factory_out_basename}" >> $IMG_INDEX_FILE
echo "FileSize: ${sysupgrade_filesize}; ${factory_filesize}" >> $IMG_INDEX_FILE
echo "MD5: ${sysupgrade_md5sum}; ${factory_md5sum}" >> $IMG_INDEX_FILE
if [ $sysupgrade_size -gt $MAX_GOOD_IMAGE_SIZE ]; then if [ $sysupgrade_size -gt $MAX_GOOD_IMAGE_SIZE ]; then
echo "WARNING: the sysupgrade image is larger than $MAX_GOOD_IMAGE_SIZE bytes, which probably means it will cause read/write problems when flashed to a device" echo "WARNING: the sysupgrade image is larger than $MAX_GOOD_IMAGE_SIZE bytes, which probably means it will cause read/write problems when flashed to a device"
fi fi
cp $sysupgrade_name $PKG_IMG_DIR/$sysupgrade_out_basename
cp $factory_name $PKG_IMG_DIR/$factory_out_basename
fi fi
done done
# ok this is ugly, but at least it generates a complete index (the loop assumes for each
# sysupgrade image it finds, there is also a factory counterpart)
for file in $PKG_IMG_DIR/${IMAGE_BASENAME}-*-sysupgrade.bin; do
basefile=`basename ${file}`
echo "Considering $basefile (${file})"
# sorry for the shell magic
devtype=${basefile:`expr ${#IMAGE_BASENAME} + 1`}
version=${devtype//-*}
devtype=${devtype#*-}
devtype=${devtype%-*}
generateIndexEntry $PKG_IMG_DIR $version $devtype >> $IMG_INDEX_FILE
done
# NOTE: the aliasing construct in the indexing script does not work (and even then, the md5 command defaults to a different output format), so we hack around it here. # NOTE: the aliasing construct in the indexing script does not work (and even then, the md5 command defaults to a different output format), so we hack around it here.
MD5_HACK_ENABLED=0 MD5_HACK_ENABLED=0
which md5sum >/dev/null 2>&1 which md5sum >/dev/null 2>&1

View File

@ -1 +1 @@
0.9.0 0.9.1