X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/Ventoy.git/blobdiff_plain/58a93cdb4082bb42366c480890705d9786602b4a..fc5cd0a00a6745d7a8ce31bfadd76e8d064e18a1:/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh diff --git a/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh b/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh index bb1cb31..7a3a982 100644 --- a/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh +++ b/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh @@ -87,7 +87,13 @@ wait_for_usb_disk_ready() { usb_disk=$(get_ventoy_disk_name) vtlog "wait_for_usb_disk_ready $usb_disk ..." - if [ -e "${usb_disk}2" ]; then + if echo $usb_disk | $EGREP -q "nvme|mmc|nbd"; then + vtpart2=${usb_disk}p2 + else + vtpart2=${usb_disk}2 + fi + + if [ -e "${vtpart2}" ]; then vtlog "wait_for_usb_disk_ready $usb_disk finish" break else @@ -96,6 +102,16 @@ wait_for_usb_disk_ready() { done } +check_usb_disk_ready() { + if echo $1 | $EGREP -q "nvme|mmc|nbd"; then + vtpart2=${1}p2 + else + vtpart2=${1}2 + fi + + [ -e "${vtpart2}" ] +} + is_ventoy_disk() { if $VTOY_PATH/tool/vtoydump -f $VTOY_PATH/ventoy_os_param -c "$1"; then $BUSYBOX_PATH/true @@ -105,7 +121,13 @@ is_ventoy_disk() { } not_ventoy_disk() { - if $VTOY_PATH/tool/vtoydump -f $VTOY_PATH/ventoy_os_param -c "$1"; then + if echo $1 | $EGREP -q "nvme.*p$|mmc.*p$|nbd.*p$"; then + vtDiskName=${1:0:-1} + else + vtDiskName=$1 + fi + + if $VTOY_PATH/tool/vtoydump -f $VTOY_PATH/ventoy_os_param -c "$vtDiskName"; then $BUSYBOX_PATH/false else $BUSYBOX_PATH/true @@ -343,6 +365,37 @@ extract_file_from_line() { fi } +extract_rpm_from_line() { + vtlog "extract_rpm_from_line $1 disk=#$2#" + + if ! [ -b "$2" ]; then + vterr "disk #$2# not exist" + return + fi + + sector=$(echo $1 | $AWK '{print $(NF-1)}') + length=$(echo $1 | $AWK '{print $NF}') + vtlog "sector=$sector length=$length" + + $VTOY_PATH/tool/vtoydm -e -f $VTOY_PATH/ventoy_image_map -d ${2} -s $sector -l $length -o /tmp/xxx.rpm + if [ -e /tmp/xxx.rpm ]; then + vtlog "extract rpm file from iso success" + else + vterr "extract rpm file from iso fail" + return + fi + + CURPWD=$($BUSYBOX_PATH/pwd) + + $BUSYBOX_PATH/mkdir -p $VTOY_PATH/rpm + cd $VTOY_PATH/rpm + vtlog "extract rpm..." + $BUSYBOX_PATH/rpm2cpio /tmp/xxx.rpm | $BUSYBOX_PATH/cpio -idm 2>>$VTLOG + cd $CURPWD + + $BUSYBOX_PATH/rm -f /tmp/xxx.rpm +} + install_rpm_from_line() { vtlog "install_rpm_from_line $1 disk=#$2#" @@ -432,9 +485,12 @@ ventoy_create_persistent_link() { fi } -ventoy_udev_disk_common_hook() { - - VTDISK="${1:0:-1}" +ventoy_udev_disk_common_hook() { + if echo $1 | $EGREP -q "nvme.*p[0-9]$|mmc.*p[0-9]$|nbd.*p[0-9]$"; then + VTDISK="${1:0:-2}" + else + VTDISK="${1:0:-1}" + fi if [ -e /vtoy/vtoy ]; then VTRWMOD="" @@ -502,8 +558,14 @@ is_inotify_ventoy_part() { if echo $1 | $GREP -q "2$"; then if ! [ -e /sys/block/$1 ]; then if [ -e /sys/class/block/$1 ]; then - if [ -e /dev/${1:0:-1} ]; then - $VTOY_PATH/tool/vtoydump -f $VTOY_PATH/ventoy_os_param -c ${1:0:-1} + if echo $1 | $EGREP -q "nvme|mmc|nbd"; then + vtShortName=${1:0:-2} + else + vtShortName=${1:0:-1} + fi + + if [ -e /dev/$vtShortName ]; then + $VTOY_PATH/tool/vtoydump -f $VTOY_PATH/ventoy_os_param -c $vtShortName return fi fi @@ -535,9 +597,9 @@ ventoy_swap_device() { ventoy_extract_vtloopex() { vtCurPwd=$PWD $BUSYBOX_PATH/mkdir -p $VTOY_PATH/partmnt $VTOY_PATH/vtloopex - $BUSYBOX_PATH/mount -o ro -t vfat /dev/${vtdiskname#/dev/}2 $VTOY_PATH/partmnt + $BUSYBOX_PATH/mount -o ro -t vfat $1 $VTOY_PATH/partmnt cd $VTOY_PATH/vtloopex - $CAT $VTOY_PATH/partmnt/ventoy/vtloopex.cpio | $BUSYBOX_PATH/cpio -idm + $CAT $VTOY_PATH/partmnt/ventoy/vtloopex.cpio | $BUSYBOX_PATH/cpio -idm >> $VTLOG 2>&1 $BUSYBOX_PATH/umount $VTOY_PATH/partmnt $BUSYBOX_PATH/rm -rf $VTOY_PATH/partmnt