wok rev 18771
iso2exe: update /init
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Thu Dec 31 15:49:20 2015 +0100 (2015-12-31) |
parents | 61e23282014d |
children | e8de1b7505ef |
files | syslinux/stuff/iso2exe/init syslinux/stuff/iso2exe/taziso |
line diff
1.1 --- a/syslinux/stuff/iso2exe/init Thu Dec 31 14:51:53 2015 +0200 1.2 +++ b/syslinux/stuff/iso2exe/init Thu Dec 31 15:49:20 2015 +0100 1.3 @@ -640,7 +640,7 @@ 1.4 fddata() 1.5 { 1.6 [ -e /sys/block/fd0 ] && 1.7 - [ $(get 28 /mnt/$ISO 1 2> /dev/null || echo 0) -ne 0 ] && 1.8 + [ $(get 26 /mnt/$ISO 1 2> /dev/null || echo 0) -ne 0 ] && 1.9 echo -en "\"$1\" \"$2\"" 1.10 } 1.11 1.12 @@ -678,6 +678,42 @@ 1.13 wodim -v -blank=fast 1.14 } 1.15 1.16 +customsector() 1.17 +{ 1.18 + echo $(($(get 32848 "/mnt/$ISO" 4)+16)) 1.19 +} 1.20 + 1.21 +hascustomconf() 1.22 +{ 1.23 + [ "$(ddq bs=2k skip=$(customsector) if="/mnt/$ISO" | ddq bs=1 count=6)" \ 1.24 + == "#!boot" ] 1.25 +} 1.26 + 1.27 +gotcustomconf() 1.28 +{ 1.29 + hascustomconf && menuitem "$@" 1.30 +} 1.31 + 1.32 +getcustomconf() 1.33 +{ 1.34 + cd /mnt 1.35 + ddq bs=2k skip=$(customsector) if="$ISO" | while read line; do 1.36 + case "$line" in 1.37 + \#!boot*) ;; 1.38 + append=*) echo ${line#append=} > cmdline && ls -l cmdline ;; 1.39 + initrd:*) cnt=${line#initrd:} 1.40 + { ddq bs=512 count=$(($cnt / 512)); 1.41 + ddq bs=1 count=$(($cnt % 512)); } > initrd && 1.42 + ls -l initrd 1.43 + break ;; 1.44 + *) break ;; 1.45 + esac 1.46 + done 1.47 + cd - > /dev/null 1.48 + echo -e "\rPress RETURN to continue." 1.49 + read n 1.50 +} 1.51 + 1.52 gotisomd5() 1.53 { 1.54 [ "$(which md5sum 2> /dev/null)" ] && 1.55 @@ -699,14 +735,188 @@ 1.56 [ $(((1+$s+$(get $(($n+1)) /mnt/$ISO 1)) % 65536)) -eq 0 ] && 1.57 echo "OK" || echo "ERROR" 1.58 fi 1.59 + if hascustomconf; then 1.60 + echo -en "\rChecking iso custom config..." 1.61 + TMP=/tmp/$(basename $0)$$md5 1.62 + md5="$(ddq bs=2k skip=$(customsector) if=/mnt/$ISO | while read line; do 1.63 + case "$line" in 1.64 + \#!boot*) echo ${line#*boot } > $TMP ;; 1.65 + append=*) echo $line ;; 1.66 + initrd:*) echo $line 1.67 + cnt=${line#initrd:} 1.68 + ddq bs=512 count=$((cnt / 512)) 1.69 + ddq bs=1 count=$((cnt % 512)) 1.70 + break ;; 1.71 + *) break ;; 1.72 + esac 1.73 + done | md5sum | cut -c1-32)" 1.74 + [ "$md5" == "$(cat $TMP)" ] && echo "OK" || echo "ERROR" 1.75 + rm -f $TMP 1.76 + fi 1.77 rm -f /tmp/wait 1.78 echo -e "\rPress RETURN to continue." 1.79 read n 1.80 } 1.81 1.82 +if [ "$1" == "--build" ]; then #install-begin 1.83 + uuencode -m - < ifmem.bin | sed -e '/^ifmemcode$/r/dev/stdin' \ 1.84 + -e '/^ifmemcode$/d' -i $0 1.85 + uuencode -m - < bootloader.bin | sed -e '/^bootloader$/r/dev/stdin' \ 1.86 + -e '/^bootloader$/d' -e '/install-begin$/,/install-end$/d' -i $0 1.87 + exit 1.88 +fi #install-end 1.89 +parse_isolinux() 1.90 +{ 1.91 + awk 'BEGIN { IGNORECASE=1 } 1.92 +function multi(n) 1.93 +{ 1.94 + auto=$n 1.95 + for (--n; n < NF; n+=2) { 1.96 + s=$n 1.97 + if (s ~ /M$/) s = substr(s,0,length(s)-1) 1.98 + else s /= 1024 1.99 + sizes=int(s) " " sizes 1.100 + } 1.101 + next 1.102 +} 1.103 +{ 1.104 + if ($1 == "LABEL") { 1.105 + label=$2 1.106 + if (auto == "") auto=label 1.107 + } 1.108 + if ($1 == "KERNEL" || $1 == "COM32") kernel[label]=$2 1.109 + if ($1 == "INITRD") initrd[label]=$2 1.110 + if ($1 == "APPEND") { 1.111 + i=2 1.112 + if (kernel[label] ~ "ifmem.c32") multi(3) 1.113 + if (kernel[label] ~ "c32box.c32") { 1.114 + if ($2 == "linux") { kernel[label]=$3; i=4 } 1.115 + if ($2 == "ifmem") multi(4) 1.116 + } 1.117 + if (kernel[label] ~ "ifcpu64.c32") { auto=$4; next } 1.118 + while (i <= NF) { 1.119 + if ($i ~ "^initrd=") initrd[label]=substr($i,8) 1.120 + else cmdline[label]=cmdline[label] " " $i 1.121 + i++ 1.122 + } 1.123 + } 1.124 +} 1.125 +END { 1.126 + print "KERNEL=\"" kernel[auto] "\"" 1.127 + print "INITRD=\"" initrd[auto] "\"" 1.128 + print "CMDLINE=\"" substr(cmdline[auto],2) "\"" 1.129 + print "SIZES=\"" sizes "\"" 1.130 +}' 1.131 +} 1.132 + 1.133 +locase() 1.134 +{ 1.135 + echo "$1" | tr [A-Z] [a-z] 1.136 +} 1.137 + 1.138 +ifmemcode() 1.139 +{ 1.140 + uudecode <<EOT 1.141 +ifmemcode 1.142 +EOT 1.143 +} 1.144 + 1.145 +floppyset() 1.146 +{ 1.147 + gotcdfile isolinux.cfg 1.148 + parse_isolinux < $file > /tmp/var$$ 1.149 + . /tmp/var$$ 1.150 + for i in $media/$KERNEL $(dirname $file)/$KERNEL $media/$(locase $KERNEL) \ 1.151 + $(dirname $file)/$(locase $KERNEL); do 1.152 + [ -s $i ] && KERNEL=$i && break 1.153 + done 1.154 + rm -f /tmp/var$$ 1.155 + [ $(get 514 $KERNEL 4) -eq 1400005704 ] || return 1.156 + n=$(($(get 497 $KERNEL 1)+1)) 1.157 + ddq bs=512 count=$n if=$KERNEL of=/tmp/fd$$ 1.158 + uudecode <<EOT | ddq of=/tmp/fd$$ conv=notrunc 1.159 +bootloader 1.160 +EOT 1.161 + pos=$(($n*512)) 1.162 + if [ -n "$CMDLINE" ]; then 1.163 + echo -n "$CMDLINE" | ddq bs=512 count=1 conv=sync >> /tmp/fd$$ 1.164 + bytes2bin $n | ddq conv=notrunc \ 1.165 + bs=1 seek=497 count=1 of=/tmp/fd$$ 1.166 + words2bin $pos | ddq conv=notrunc \ 1.167 + bs=1 seek=34 count=2 of=/tmp/fd$$ 1.168 + [ $(get 518 $KERNEL 4) -ge 514 ] && 1.169 + words2bin 32768 9 | ddq conv=notrunc \ 1.170 + bs=1 seek=552 count=4 of=/tmp/fd$$ 1.171 + fi 1.172 + syssize=$(echo $(get 500 /tmp/fd$$ 4)) 1.173 + ddq bs=512 skip=$n if=$KERNEL | cat - /dev/zero | \ 1.174 + ddq bs=512 count=$((($syssize+31)/32)) conv=sync >> /tmp/fd$$ 1.175 + base=$(stat -c %s /tmp/fd$$) 1.176 + len= 1.177 + if [ "$INITRD" ]; then 1.178 + l=0 1.179 + for i in ${INITRD//,/ }; do 1.180 + for j in $media/$i $(dirname $KERNEL)/$i $media/$(locase $i) \ 1.181 + $(dirname $KERNEL)/$(locase $i); do 1.182 + [ -s $j ] && i=$j && break 1.183 + done 1.184 + ddq if=$i >> /tmp/fd$$ 1.185 + l=$(($l+$(stat -c %s $i))) 1.186 + r=$((4 - ($l % 4))) 1.187 + if [ $r -ne 4 ]; then 1.188 + ddq if=/dev/zero bs=1 count=$r >> /tmp/fd$$ 1.189 + l=$(($l + $r)) 1.190 + fi 1.191 + case "$i:$INITRD" in 1.192 + *rootfs.gz:*rootfs.gz,*) continue # loram 1.193 + esac 1.194 + len="$len $l"; l=0 1.195 + done 1.196 + rdadrs=${RDADRS:-$(((($syssize*16)+0x1F0000) & -4096))} 1.197 + words2bin $(($rdadrs & 0xFFFF)) $(($rdadrs >> 16)) | ddq \ 1.198 + conv=notrunc bs=1 seek=536 count=4 of=/tmp/fd$$ 1.199 + fi 1.200 + n=$(echo $len | wc -w) 1.201 + if [ $((494 - $(get 494 /tmp/fd$$))) -ge $(($n * 4)) ]; then 1.202 + i=$(($(get 494 /tmp/fd$$))) 1.203 + bytes2bin $(($i + ($n*4) - 256)) | ddq bs=1 conv=notrunc \ 1.204 + seek=496 count=1 of=/tmp/fd$$ 1.205 + else 1.206 + i=$(($pos + 0x1FC - ($n*4))) 1.207 + bytes2bin $(($i % 256)) $((i / 256)) 252 | ddq bs=1 \ 1.208 + conv=notrunc seek=494 count=3 of=/tmp/fd$$ 1.209 + s=$(($i - 2*$(echo "$SIZES" | wc -w))) 1.210 + p=$(($s - $(ifmemcode | wc -c))) 1.211 + ifmemcode | ddq bs=1 conv=notrunc seek=$p of=/tmp/fd$$ 1.212 + words2bin $SIZES | ddq bs=1 conv=notrunc seek=$s of=/tmp/fd$$ 1.213 + bytes2bin 154 $(($p%256)) $(($p/256)) 0 144 | \ 1.214 + ddq bs=1 conv=notrunc seek=60 of=/tmp/fd$$ 1.215 + fi 1.216 + for r in $len ; do 1.217 + words2bin $(($r & 0xFFFF)) $(($r >> 16)) | ddq conv=notrunc \ 1.218 + bs=1 seek=$i count=4 of=/tmp/fd$$ 1.219 + i=$(($i + 4)) 1.220 + done 1.221 + split -b 1440k /tmp/fd$$ fd$$ 1.222 + rm -f /tmp/fd$$ 1.223 + n=1; i=0; r=0 1.224 + set -- $len 1.225 + ls fd$$* | while read file ; do 1.226 + if [ $i -gt $(($1+$base)) ]; then 1.227 + shift 1.228 + r=$(($r+100)); n=0; i=0; base=0 1.229 + fi 1.230 + ddq of=$file bs=18k seek=80 count=0 1.231 + i=$(($i+1474560)) 1.232 + printf "mv %s fd%03d.img\n" $file $(($r+$n)) 1.233 + n=$(($n+1)) 1.234 + done | sh 1.235 + ls fd???.img 1.236 +} 1.237 + 1.238 fdbootstrap() 1.239 { 1.240 - sz=$((512 * $(echo $(get 28 /mnt/$ISO 1)))) 1.241 + sz=$((512 * $(echo $(get 26 /mnt/$ISO 1)))) 1.242 $DIALOG --clear \ 1.243 --title " Create a floppy bootstrap " \ 1.244 --yes-label "Continue" --yesno \ 1.245 @@ -954,6 +1164,16 @@ 1.246 rm -rf /tmp/data 1.247 } 1.248 1.249 +flavor() 1.250 +{ 1.251 + cd /mnt 1.252 + name="$(flavdata | cpio -t 2> /dev/null | sed 's/.[a-z]*$//;q')" 1.253 + echo "Create ${name:=flavor}.flavor..." 1.254 + tazlito iso2flavor "/mnt/$ISO" $name 1.255 + ls -l $name.flavor 2> /dev/null || sleep 5 1.256 + cd - > /dev/null 1.257 +} 1.258 + 1.259 shell() 1.260 { 1.261 trap text 2 1.262 @@ -975,7 +1195,7 @@ 1.263 which $DIALOG 2> /dev/null || DIALOG=tinydialog 1.264 dmesg > /tmp/dmesg 1.265 1.266 -isotitle="$(basename $ISO) $(stat -c %y /cdrom/media/. | sed 's/ .*//'\ 1.267 +isotitle="$(basename $ISO) $(stat -c %y /media/cdrom | sed 's/ .*//'\ 1.268 ) $(blkid /mnt/$ISO | sed 's/.*LABEL="\([^"]*\).*/\1/')" 1.269 while true; do 1.270 trap shell 2 1.271 @@ -990,6 +1210,7 @@ 1.272 $(cdfile boot/bzImage "live" "Linux RAM boot (full desktop)") \ 1.273 "text" "Linux RAM boot" \ 1.274 $(cdfile "README*" "readme" "Show the README file") \ 1.275 +$(gotcustomconf "getcustomconf" "Get custom config") \ 1.276 $(gotisomd5 "isomd5" "Check the ISO image") \ 1.277 $(cdfile "md5sum*" "md5" "Check the ISO files") \ 1.278 $(cdfile "sha*sum*" "sha" "Check the ISO files") \ 1.279 @@ -1000,15 +1221,17 @@ 1.280 $(xfile tazusb "usbkey" "USB key read/write installation") \ 1.281 $(ishybrid "usbbootkey" "USB boot key (read only)") \ 1.282 $(hasflavinfo "showfavinfo" "Show flavor extra info") \ 1.283 +$(xfile tazlito "flavor" "Get flavor file") \ 1.284 $(fddata "fdbootstrap" "Create a floppy bootstrap") \ 1.285 +$(cdfile isolinux.cfg "floppyset" "Boot floppy set") \ 1.286 "tazboot" "Get tazboot.exe Linux loader" \ 1.287 $(cdexe boot/bzImage "bzimage" "Get linux DOS/EXE file") \ 1.288 $(cdexe "memtest*" "memtest" "Get Memtest86 DOS/EXE file") \ 1.289 $(cdfilef "memtest*" "fdmemtest" "Create a Memtest86 boot floppy") \ 1.290 -$(cdfilex "memtest*" "runmemtest" "Start Memtest86") \ 1.291 +$(:||cdfilex "memtest*" "runmemtest" "Start Memtest86") \ 1.292 $(cdexe "?pxe" "pxe" "Get SliTaz Web boot DOS/EXE utility") \ 1.293 $(cdfilef "?pxe" "fdpxe" "Create a SliTaz Web boot floppy") \ 1.294 -$(cdfilex "?pxe" "runpxe" "Start the SliTaz Web boot utility") \ 1.295 +$(:||cdfilex "?pxe" "runpxe" "Start the SliTaz Web boot utility") \ 1.296 $(xfile reboot "restart" "Restart the computer") \ 1.297 $(xfile poweroff "stop" "Power off") \ 1.298 "bootlog" "Linux boot messages" \
2.1 --- a/syslinux/stuff/iso2exe/taziso Thu Dec 31 14:51:53 2015 +0200 2.2 +++ b/syslinux/stuff/iso2exe/taziso Thu Dec 31 15:49:20 2015 +0100 2.3 @@ -1107,7 +1107,11 @@ 2.4 name="$(flavdata | cpio -t 2> /dev/null | sed 's/.[a-z]*$//;q')" 2.5 echo "Create ${name:=flavor}.flavor..." 2.6 tazlito iso2flavor "$ISO" $name 2.7 - ls -l $name.flavor 2.8 + ls -l $name.flavor 2> /dev/null && return 2.9 + sleep 5 2.10 + [ "$1" ] && return 2.11 + echo -e "\rPress RETURN to continue." 2.12 + read n 2.13 } 2.14 2.15 if [ "$1" == "--build" ]; then #install-begin 2.16 @@ -1343,6 +1347,6 @@ 2.17 retval=$? 2.18 exec 3>&- 2.19 rm -f /tmp/dialog$$ 2.20 - [ $retval -eq 0 ] || break 2.21 + [ $retval -eq 0 ] || quit 2.22 $value 2.23 done