X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/Ventoy.git/blobdiff_plain/132649c4e577e4c133d41c910549ad4480e44822..7fa4724743fb687288eba28df902b36a69c47d4e:/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 ad05c7c..80765e3 100644 --- a/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh +++ b/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh @@ -278,11 +278,23 @@ ventoy_dm_patch() { $CAT /proc/kallsyms | $BUSYBOX_PATH/sort > $VTOY_PATH/kallsyms - vtLine=$($VTOY_PATH/tool/vtoyksym dm_get_table_device $VTOY_PATH/kallsyms) + if $GREP -m1 -q 'open_table_device.isra' $VTOY_PATH/kallsyms; then + vtLine=$($VTOY_PATH/tool/vtoyksym open_table_device.isra $VTOY_PATH/kallsyms) + vtlog "get open_table_device.isra address $vtLine" + else + vtLine=$($VTOY_PATH/tool/vtoyksym dm_get_table_device $VTOY_PATH/kallsyms) + vtlog "get dm_get_table_device address $vtLine" + fi get_addr=$(echo $vtLine | $AWK '{print $1}') get_size=$(echo $vtLine | $AWK '{print $2}') - vtLine=$($VTOY_PATH/tool/vtoyksym dm_put_table_device $VTOY_PATH/kallsyms) + if $GREP -m1 -q 'close_table_device.isra' $VTOY_PATH/kallsyms; then + vtLine=$($VTOY_PATH/tool/vtoyksym close_table_device.isra $VTOY_PATH/kallsyms) + vtlog "get close_table_device.isra address $vtLine" + else + vtLine=$($VTOY_PATH/tool/vtoyksym dm_put_table_device $VTOY_PATH/kallsyms) + vtlog "get dm_put_table_device address $vtLine" + fi put_addr=$(echo $vtLine | $AWK '{print $1}') put_size=$(echo $vtLine | $AWK '{print $2}') @@ -293,6 +305,9 @@ ventoy_dm_patch() { if [ "$VTOY_DEBUG_LEVEL" = "01" ]; then printk_addr=$($GREP ' printk$' /proc/kallsyms | $AWK '{print $1}') + if [ -z "$printk_addr" ]; then + printk_addr=$($GREP ' _printk$' /proc/kallsyms | $AWK '{print $1}') + fi vtDebug="-v" else printk_addr=0 @@ -350,11 +365,13 @@ ventoy_dm_patch() { fi #step1: modify vermagic/mod crc/relocation + vtlog "$VTOY_PATH/tool/vtoykmod -u $VTOY_PATH/tool/$vtKoName $VTOY_PATH/$vtModName $vtDebug" $VTOY_PATH/tool/vtoykmod -u $VTOY_PATH/tool/$vtKoName $VTOY_PATH/$vtModName $vtDebug #step2: fill parameters vtPgsize=$($VTOY_PATH/tool/vtoyksym -p) - $VTOY_PATH/tool/vtoykmod -f $VTOY_PATH/tool/$vtKoName $vtPgsize 0x$printk_addr 0x$ro_addr 0x$rw_addr $get_addr $get_size $put_addr $put_size 0x$kprobe_reg_addr 0x$kprobe_unreg_addr $vtDebug + vtlog "$VTOY_PATH/tool/vtoykmod -f $VTOY_PATH/tool/$vtKoName $vtPgsize 0x$printk_addr 0x$ro_addr 0x$rw_addr $get_addr $get_size $put_addr $put_size 0x$kprobe_reg_addr 0x$kprobe_unreg_addr $vtKv $vtDebug" + $VTOY_PATH/tool/vtoykmod -f $VTOY_PATH/tool/$vtKoName $vtPgsize 0x$printk_addr 0x$ro_addr 0x$rw_addr $get_addr $get_size $put_addr $put_size 0x$kprobe_reg_addr 0x$kprobe_unreg_addr $vtKv $vtDebug $BUSYBOX_PATH/insmod $VTOY_PATH/tool/$vtKoName @@ -736,6 +753,7 @@ ventoy_udev_disk_common_hook() { fi if $GREP -q 'dm_patch' /proc/modules; then + vtlog "remove dm_patch module." $BUSYBOX_PATH/rmmod dm_patch fi } @@ -866,3 +884,28 @@ ventoy_check_install_module_xz() { $BUSYBOX_PATH/insmod "$1" fi } + +ventoy_check_umount() { + for vtLoop in 0 1 2 3 4 5 6 7 8 9; do + $BUSYBOX_PATH/umount "$1" > /dev/null 2>&1 + if $BUSYBOX_PATH/mountpoint -q "$1"; then + $SLEEP 1 + else + break + fi + done +} + +ventoy_wait_dir() { + vtdir=$1 + vtsec=0 + + while [ $vtsec -lt $2 ]; do + if [ -d "$vtdir" ]; then + break + else + $SLEEP 1 + vtsec=$(expr $vtsec + 1) + fi + done +}