X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/Ventoy.git/blobdiff_plain/86b13727ca79f5ae60eaafe6af3c7148478fe063..HEAD:/IMG/cpio/ventoy/init_chain diff --git a/IMG/cpio/ventoy/init_chain b/IMG/cpio/ventoy/init_chain index a2feafa..6034370 100644 --- a/IMG/cpio/ventoy/init_chain +++ b/IMG/cpio/ventoy/init_chain @@ -72,21 +72,29 @@ ventoy_unpack_initramfs() { for vtx in '1F8B zcat' '1F9E zcat' '425A bzcat' '5D00 lzcat' 'FD37 xzcat' '894C lzopcat' '0221 lz4cat' '28B5 zstdcat' '3037 cat' '4C5A lunzip -c'; do if [ "${vtx:0:4}" = "${vtmagic:0:4}" ]; then - echo "vtx=$vtx" >> $VTLOG - if [ $vtskip -eq 0 ]; then - if [ "${vtx:5}" = "xzcat" ]; then + echo "vtx=$vtx" >> $VTLOG + if [ $vtskip -ne 0 ]; then + dd if=$vtfile skip=$vtskip iflag=skip_bytes status=none > ${vtfile}.skip + rm -f $vtfile + mv ${vtfile}.skip $vtfile + fi + + if [ "${vtx:5}" = "xzcat" ]; then + rm -f $VTOY_PATH/xzlog + ${vtx:5} $vtfile 2> $VTOY_PATH/xzlog | (cpio -idmu 2>>$VTLOG; cat > $vttmp) + if grep -q 'corrupted data' $VTOY_PATH/xzlog; then + echo 'xzcat failed, now try xzminidec...' >> $VTLOG rm -f $VTOY_PATH/xzlog - ${vtx:5} $vtfile 2> $VTOY_PATH/xzlog | (cpio -idmu 2>>$VTLOG; cat > $vttmp) - if grep -q 'corrupted data' $VTOY_PATH/xzlog; then - echo 'xzcat failed, now try xzcat_musl ...' >> $VTLOG + cat $vtfile | xzminidec 2> $VTOY_PATH/xzlog | (cpio -idmu 2>>$VTLOG; cat > $vttmp) + + if grep -q 'limit' $VTOY_PATH/xzlog; then + echo 'xzminidec failed, now try xzcat_musl ...' >> $VTLOG xzcat_musl $vtfile | (cpio -idmu 2>>$VTLOG; cat > $vttmp) fi - else - ${vtx:5} $vtfile | (cpio -idmu 2>>$VTLOG; cat > $vttmp) fi else - dd if=$vtfile skip=$vtskip iflag=skip_bytes status=none | ${vtx:5} | (cpio -idmu 2>>$VTLOG; cat > $vttmp) - fi + ${vtx:5} $vtfile | (cpio -idmu 2>>$VTLOG; cat > $vttmp) + fi break fi done @@ -106,6 +114,28 @@ ventoy_unpack_initrd() { done } +vtfile_head_zero() { + local vsize + local voffset + local vfile + local vzero + local vdump + + voffset=0 + vfile=$1 + vsize=$(stat -c '%s' ${vfile}) + vzero=$(hexdump -n 512 -e '512/1 "%02X"' $vfile) + + while [ $voffset -lt $vsize ]; do + vdump=$(hexdump -s $voffset -n 512 -e '512/1 "%02X"' $vfile) + if [ "$vdump" != "$vzero" ]; then + echo $voffset + return + fi + voffset=$($BUSYBOX_PATH/expr $voffset + 512) + done + echo 0 +} # This export is for busybox cpio command export EXTRACT_UNSAFE_SYMLINKS=1 @@ -125,13 +155,22 @@ for vtfile in $(ls /initrd*); do #only for cpio,cpio,...,initrd sequence, initrd,cpio or initrd,initrd sequence is not supported while [ -e ${vtfile}_tmp ] && [ $(stat -c '%s' ${vtfile}_tmp) -gt 512 ]; do mv ${vtfile}_tmp $vtfile + vtdump=$(hexdump -n 512 -e '512/1 "%02X"' $vtfile) vtmagic=$(echo $vtdump | sed 's/^\(00\)*//') let vtoffset="(${#vtdump}-${#vtmagic})/2" if [ -z "$vtmagic" ]; then - echo "terminate with all zero data file" >> $VTLOG - break + vtHeadZero=$(vtfile_head_zero $vtfile) + if [ $vtHeadZero -gt 0 ]; then + vtdump=$(hexdump -s $vtHeadZero -n 512 -e '512/1 "%02X"' $vtfile) + vtmagic=$(echo $vtdump | sed 's/^\(00\)*//') + let vtoffset="(${#vtdump}-${#vtmagic})/2+$vtHeadZero" + echo "skip head $vtHeadZero zeros with magic ${vtmagic:0:4}" >> $VTLOG + else + echo "terminate with all zero data file" >> $VTLOG + break + fi fi ventoy_unpack_initramfs $vtfile $vtoffset ${vtmagic:0:4} ${vtfile}_tmp