X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/Ventoy.git/blobdiff_plain/7f63a1c327399e1ea8fce9ba8778685f737da795..bdab55e8aa191ef4066c088df82e7063fc292d7c:/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 62c2996..2ebf801 100644 --- a/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh +++ b/IMG/cpio/ventoy/hook/ventoy-hook-lib.sh @@ -344,6 +344,23 @@ ventoy_dm_patch() { get_addr=$(echo $vtLine | $AWK '{print $1}') get_size=$(echo $vtLine | $AWK '{print $2}') + vtLine=$($VTOY_PATH/tool/vtoyksym blkdev_get_by_dev $VTOY_PATH/kallsyms) + vtlog "get blkdev_get_by_dev address $vtLine" + blkdev_get_addr=$(echo $vtLine | $AWK '{print $1}') + + vtLine=$($VTOY_PATH/tool/vtoyksym blkdev_put $VTOY_PATH/kallsyms) + vtlog "get blkdev_put address $vtLine" + blkdev_put_addr=$(echo $vtLine | $AWK '{print $1}') + + vtLine=$($VTOY_PATH/tool/vtoyksym bdev_open_by_dev $VTOY_PATH/kallsyms) + vtlog "get bdev_open_by_dev address $vtLine" + bdev_open_addr=$(echo $vtLine | $AWK '{print $1}') + + vtLine=$($VTOY_PATH/tool/vtoyksym bdev_file_open_by_dev $VTOY_PATH/kallsyms) + vtlog "get bdev_file_open_by_dev address $vtLine" + bdev_file_open_addr=$(echo $vtLine | $AWK '{print $1}') + + 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" @@ -383,8 +400,9 @@ ventoy_dm_patch() { vtlog get_addr=$get_addr get_size=$get_size vtlog put_addr=$put_addr put_size=$put_size + vtlog blkdev_get_addr=$blkdev_get_addr blkdev_put_addr=$blkdev_put_addr vtlog kprobe_reg_addr=$kprobe_reg_addr kprobe_unreg_addr=$kprobe_unreg_addr - vtlog ro_addr=$ro_addr rw_addr=$rw_addr printk_addr=$printk_addr + vtlog ro_addr=$ro_addr rw_addr=$rw_addr printk_addr=$printk_addr bdev_open_addr=$bdev_open_addr bdev_file_open_addr=$bdev_file_open_addr if [ "$get_addr" = "0" -o "$put_addr" = "0" ]; then vtlog "Invalid symbol address" @@ -397,6 +415,9 @@ ventoy_dm_patch() { vtKv=$($BUSYBOX_PATH/uname -r) + vtKVMajor=$(echo $vtKv | $AWK -F. '{print $1}') + vtKVMinor=$(echo $vtKv | $AWK -F. '{print $2}') + vtKVSubMinor=$(echo $vtKv | $AWK -F. '{print $3}') if [ ! -d /lib/modules/$vtKv ]; then vtlog "No modules directory found" @@ -437,13 +458,18 @@ ventoy_dm_patch() { #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 >>$VTLOG 2>&1 + vtlog "$VTOY_PATH/tool/vtoykmod -u $vtKVMajor $vtKVMinor $VTOY_PATH/tool/$vtKoName $VTOY_PATH/$vtModName $vtDebug" + $VTOY_PATH/tool/vtoykmod -u $vtKVMajor $vtKVMinor $VTOY_PATH/tool/$vtKoName $VTOY_PATH/$vtModName $vtDebug >>$VTLOG 2>&1 #step2: fill parameters vtPgsize=$($VTOY_PATH/tool/vtoyksym -p) - 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 $vtIBT $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 $vtIBT $vtDebug >>$VTLOG 2>&1 + + vtPrams="$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 $vtKVMajor $vtIBT $vtKVMinor $blkdev_get_addr $blkdev_put_addr $vtKVSubMinor $bdev_open_addr $bdev_file_open_addr $vtDebug" + + + vtlog "$VTOY_PATH/tool/vtoykmod -f $vtPrams" + $VTOY_PATH/tool/vtoykmod -f $vtPrams >>$VTLOG 2>&1 + vtlog "insmod $VTOY_PATH/tool/$vtKoName" $BUSYBOX_PATH/insmod $VTOY_PATH/tool/$vtKoName >>$VTLOG 2>&1