7 echo 'Usage: Ventoy2Disk.sh CMD [ OPTION ] /dev/sdX'
9 echo ' -i install ventoy to sdX (fail if disk already installed with ventoy)'
10 echo ' -I force install ventoy to sdX (no matter installed or not)'
11 echo ' -u update ventoy in sdX'
12 echo ' -l list Ventoy information in sdX'
14 echo ' OPTION: (optional)'
15 echo ' -r SIZE_MB preserve some space at the bottom of the disk (only for install)'
16 echo ' -s/-S enable/disable secure boot support (default is disabled)'
17 echo ' -g use GPT partition style, default is MBR (only for install)'
18 echo ' -L Label of the 1st exfat partition (default is Ventoy)'
26 if [ "$1" = "-i" ]; then
28 elif [ "$1" = "-I" ]; then
31 elif [ "$1" = "-u" ]; then
33 elif [ "$1" = "-l" ]; then
35 elif [ "$1" = "-s" ]; then
37 elif [ "$1" = "-S" ]; then
39 elif [ "$1" = "-g" ]; then
41 elif [ "$1" = "-L" ]; then
44 elif [ "$1" = "-r" ]; then
48 elif [ "$1" = "-V" ] || [ "$1" = "--version" ]; then
50 elif [ "$1" = "-h" ] || [ "$1" = "--help" ]; then
54 if ! [ -b "$1" ]; then
55 vterr
"$1 is NOT a valid device"
65 if [ -z "$MODE" ]; then
70 if ! [ -b "$DISK" ]; then
71 vterr
"Disk $DISK does not exist"
75 if [ -e /sys
/class
/block
/${DISK#/dev/}/start
]; then
76 vterr
"$DISK is a partition, please use the whole disk."
78 vterr
" sudo sh Ventoy2Disk.sh -i /dev/sdX1 <=== This is wrong"
79 vtinfo
" sudo sh Ventoy2Disk.sh -i /dev/sdX <=== This is right"
84 if [ -n "$RESERVE_SPACE" -a "$MODE" = "install" ]; then
85 if echo $RESERVE_SIZE_MB | grep -q '^[0-9][0-9]*$'; then
86 vtdebug
"User will reserve $RESERVE_SIZE_MB MB disk space"
88 vterr
"$RESERVE_SIZE_MB is invalid for reserved space"
94 if dd if="$DISK" of
=/dev
/null bs
=1 count
=1 >/dev
/null
2>&1; then
95 vtdebug
"root permission check ok ..."
97 vterr
"Failed to access $DISK, maybe root privilege is needed!"
102 vtdebug
"MODE=$MODE FORCE=$FORCE RESERVE_SPACE=$RESERVE_SPACE RESERVE_SIZE_MB=$RESERVE_SIZE_MB"
105 if check_tool_work_ok
; then
106 vtdebug
"check tool work ok"
108 vterr
"Some tools can not run in current system. Please check log.txt for detail."
112 if [ "$MODE" = "list" ]; then
113 version
=$(get_disk_ventoy_version $DISK)
114 if [ $?
-eq 0 ]; then
115 echo "Ventoy Version in Disk: $version"
117 vtPart1Type
=$(dd if=$DISK bs=1 count=1 skip=450 status=none | hexdump -n1 -e '1/1 "%02X"')
118 if [ "$vtPart1Type" = "EE" ]; then
119 echo "Disk Partition Style : GPT"
121 echo "Disk Partition Style : MBR"
124 vtPART2
=$(get_disk_part_name $DISK 2)
125 rm -rf .
/tmpmntp2
&& mkdir .
/tmpmntp2
126 mount
$vtPART2 .
/tmpmntp2
> /dev
/null
2>&1
128 if [ -e .
/tmpmntp
2/EFI
/BOOT
/MokManager.efi
]; then
129 echo "Secure Boot Support : YES"
131 echo "Secure Boot Support : NO"
133 umount .
/tmpmntp2
> /dev
/null
2>&1
136 echo "Ventoy Version: NA"
143 grep "^$DISK" /proc
/mounts
| while read mtline
; do
144 mtpnt
=$(echo $mtline | awk '{print $2}')
145 vtdebug
"Trying to umount $mtpnt ..."
146 umount
$mtpnt >/dev
/null
2>&1
149 if grep "$DISK" /proc
/mounts
; then
150 vterr
"$DISK is already mounted, please umount it first!"
154 #check swap partition
155 if swapon
--help 2>&1 | grep -q '^ \-s,'; then
156 if swapon
-s | grep -q "^${DISK}[0-9]"; then
157 vterr
"$DISK is used as swap, please swapoff it first!"
162 #check tmp_mnt directory
163 if [ -d .
/tmp_mnt
]; then
164 vtdebug
"There is a tmp_mnt directory, now delete it."
165 umount .
/tmp_mnt
>/dev
/null
2>&1
167 if [ -d .
/tmp_mnt
]; then
168 vterr
"tmp_mnt directory exit, please delete it first."
174 if [ "$MODE" = "install" ]; then
175 vtdebug
"install ventoy ..."
177 if [ -n "$VTGPT" ]; then
178 if parted
-v > /dev
/null
2>&1; then
181 vterr
"parted is not found in the system, Ventoy can't create new partitions without it."
182 vterr
"You should install \"GNU parted\" first."
186 if parted
-v > /dev
/null
2>&1; then
188 elif fdisk
-v >/dev
/null
2>&1; then
191 vterr
"Both parted and fdisk are not found in the system, Ventoy can't create new partitions."
196 version
=$(get_disk_ventoy_version $DISK)
197 if [ $?
-eq 0 ]; then
198 if [ -z "$FORCE" ]; then
199 vtwarn
"$DISK already contains a Ventoy with version $version"
200 vtwarn
"Use -u option to do a safe upgrade operation."
201 vtwarn
"OR if you really want to reinstall ventoy to $DISK, please use -I option."
207 disk_sector_num
=$(cat /sys/block/${DISK#/dev/}/size)
208 disk_size_gb
=$(expr $disk_sector_num / 2097152)
210 if [ $disk_sector_num -gt 4294967296 ] && [ -z "$VTGPT" ]; then
211 vterr
"$DISK is over 2TB size, MBR will not work on it."
215 if [ -n "$RESERVE_SPACE" ]; then
216 sum_size_mb
=$(expr $RESERVE_SIZE_MB + $VENTOY_PART_SIZE_MB)
217 reserve_sector_num
=$(expr $sum_size_mb \* 2048)
219 if [ $disk_sector_num -le $reserve_sector_num ]; then
220 vterr
"Can't reserve $RESERVE_SIZE_MB MB space from $DISK"
227 parted
-s $DISK p
2>&1 | grep Model
228 echo "Size : $disk_size_gb GB"
229 if [ -n "$VTGPT" ]; then
236 if [ -n "$RESERVE_SPACE" ]; then
237 echo "You will reserve $RESERVE_SIZE_MB MB disk space "
242 vtwarn
"You will install Ventoy to $DISK."
243 vtwarn
"All the data on the disk $DISK will be lost!!!"
246 read -p 'Continue? (y/n) ' Answer
247 if [ "$Answer" != "y" ]; then
248 if [ "$Answer" != "Y" ]; then
254 vtwarn
"All the data on the disk $DISK will be lost!!!"
255 read -p 'Double-check. Continue? (y/n) ' Answer
256 if [ "$Answer" != "y" ]; then
257 if [ "$Answer" != "Y" ]; then
262 if [ $disk_sector_num -le $VENTOY_SECTOR_NUM ]; then
263 vterr
"No enough space in disk $DISK"
267 if ! dd if=/dev
/zero of
=$DISK bs
=1 count
=512 status
=none conv
=fsync
; then
268 vterr
"Write data to $DISK failed, please check whether it's in use."
272 if [ -n "$VTGPT" ]; then
273 vtdebug
"format_ventoy_disk_gpt $RESERVE_SIZE_MB $DISK $PARTTOOL ..."
274 format_ventoy_disk_gpt
$RESERVE_SIZE_MB $DISK $PARTTOOL
276 vtdebug
"format_ventoy_disk_mbr $RESERVE_SIZE_MB $DISK $PARTTOOL ..."
277 format_ventoy_disk_mbr
$RESERVE_SIZE_MB $DISK $PARTTOOL
282 # DiskSize > 32GB Cluster Size use 128KB
283 # DiskSize < 32GB Cluster Size use 32KB
284 if [ $disk_size_gb -gt 32 ]; then
290 PART1
=$(get_disk_part_name $DISK 1)
291 PART2
=$(get_disk_part_name $DISK 2)
293 mkexfatfs
-n "$VTNEW_LABEL" -s $cluster_sectors ${PART1}
295 vtinfo
"writing data to disk ..."
297 dd status
=none conv
=fsync
if=.
/boot
/boot.img of
=$DISK bs
=1 count
=446
299 if [ -n "$VTGPT" ]; then
300 echo -en '\x22' | dd status
=none of
=$DISK conv
=fsync bs
=1 count
=1 seek
=92
301 xzcat .
/boot
/core.img.xz
| dd status
=none conv
=fsync of
=$DISK bs
=512 count
=2014 seek
=34
302 echo -en '\x23' | dd of
=$DISK conv
=fsync bs
=1 count
=1 seek
=17908 status
=none
304 xzcat .
/boot
/core.img.xz
| dd status
=none conv
=fsync of
=$DISK bs
=512 count
=2047 seek
=1
307 xzcat .
/ventoy
/ventoy.disk.img.xz
| dd status
=none conv
=fsync of
=$DISK bs
=512 count
=$VENTOY_SECTOR_NUM seek
=$part2_start_sector
310 testUUIDStr
=$(vtoy_gen_uuid | hexdump -C)
311 vtdebug
"test uuid: $testUUIDStr"
314 vtoy_gen_uuid
| dd status
=none conv
=fsync of
=${DISK} seek
=384 bs
=1 count
=16
317 vtoy_gen_uuid
| dd status
=none conv
=fsync of
=${DISK} skip
=12 seek
=440 bs
=1 count
=4
319 vtinfo
"sync data ..."
322 vtinfo
"esp partition processing ..."
325 mtpnt
=$(grep "^${PART2}" /proc/mounts | awk '{print $2}')
326 if [ -n "$mtpnt" ]; then
327 umount
$mtpnt >/dev
/null
2>&1
330 if [ "$SECUREBOOT" != "YES" ]; then
333 vtdebug
"mounting part2 ...."
335 if mount
${PART2} .
/tmp_mnt
; then
336 vtdebug
"mounting part2 success"
340 mtpnt
=$(grep "^${PART2}" /proc/mounts | awk '{print $2}')
341 if [ -n "$mtpnt" ]; then
342 umount
$mtpnt >/dev
/null
2>&1
347 rm -f .
/tmp_mnt
/EFI
/BOOT
/BOOTX64.EFI
348 rm -f .
/tmp_mnt
/EFI
/BOOT
/grubx64.efi
349 rm -f .
/tmp_mnt
/EFI
/BOOT
/BOOTIA32.EFI
350 rm -f .
/tmp_mnt
/EFI
/BOOT
/grubia32.efi
351 rm -f .
/tmp_mnt
/EFI
/BOOT
/MokManager.efi
352 rm -f .
/tmp_mnt
/EFI
/BOOT
/mmia32.efi
353 rm -f .
/tmp_mnt
/ENROLL_THIS_KEY_IN_MOKMANAGER.cer
354 mv .
/tmp_mnt
/EFI
/BOOT
/grubx64_real.efi .
/tmp_mnt
/EFI
/BOOT
/BOOTX64.EFI
355 mv .
/tmp_mnt
/EFI
/BOOT
/grubia32_real.efi .
/tmp_mnt
/EFI
/BOOT
/BOOTIA32.EFI
358 if umount .
/tmp_mnt
; then
359 vtdebug
"umount part2 success"
363 vtdebug
"umount part2 failed, now retry..."
370 vtinfo
"Install Ventoy to $DISK successfully finished."
374 vtdebug
"update ventoy ..."
376 oldver
=$(get_disk_ventoy_version $DISK)
377 if [ $?
-ne 0 ]; then
378 vtwarn
"$DISK does not contain ventoy or data corupted"
380 vtwarn
"Please use -i option if you want to install ventoy to $DISK"
385 #reserve secure boot option
386 if [ -z "$SECUREBOOT" ]; then
387 if check_disk_secure_boot
$DISK; then
394 curver
=$(cat ./ventoy/version)
396 vtinfo
"Upgrade operation is safe, all the data in the 1st partition (iso files and other) will be unchanged!"
399 read -p "Update Ventoy $oldver ===> $curver Continue? (y/n)" Answer
400 if [ "$Answer" != "y" ]; then
401 if [ "$Answer" != "Y" ]; then
406 PART2
=$(get_disk_part_name $DISK 2)
407 SHORT_PART2
=${PART2#/dev/}
408 part2_start
=$(cat /sys/class/block/$SHORT_PART2/start)
410 PART1_TYPE
=$(dd if=$DISK bs=1 count=1 skip=450 status=none | hexdump -n1 -e '1/1 "%02X"')
414 dd status
=none conv
=fsync
if=${DISK} skip
=384 bs
=1 count
=16 of
=.
/diskuuid.bin
416 dd status
=none conv
=fsync
if=.
/boot
/boot.img of
=$DISK bs
=1 count
=440
417 dd status
=none conv
=fsync
if=.
/diskuuid.bin of
=$DISK bs
=1 count
=16 seek
=384
422 dd status
=none conv
=fsync
if=${DISK} skip
=2040 bs
=512 count
=8 of
=.
/rsvdata.bin
424 if [ "$PART1_TYPE" = "EE" ]; then
425 vtdebug
"This is GPT partition style ..."
426 echo -en '\x22' | dd status
=none of
=$DISK conv
=fsync bs
=1 count
=1 seek
=92
427 xzcat .
/boot
/core.img.xz
| dd status
=none conv
=fsync of
=$DISK bs
=512 count
=2014 seek
=34
428 echo -en '\x23' | dd of
=$DISK conv
=fsync bs
=1 count
=1 seek
=17908 status
=none
430 vtdebug
"This is MBR partition style ..."
432 PART1_ACTIVE
=$(dd if=$DISK bs=1 count=1 skip=446 status=none | hexdump -n1 -e '1/1 "%02X"')
433 PART2_ACTIVE
=$(dd if=$DISK bs=1 count=1 skip=462 status=none | hexdump -n1 -e '1/1 "%02X"')
435 vtdebug
"PART1_ACTIVE=$PART1_ACTIVE PART2_ACTIVE=$PART2_ACTIVE"
436 if [ "$PART1_ACTIVE" = "00" ] && [ "$PART2_ACTIVE" = "80" ]; then
437 vtdebug
"change 1st partition active, 2nd partition inactive ..."
438 echo -en '\x80' | dd of
=$DISK conv
=fsync bs
=1 count
=1 seek
=446 status
=none
439 echo -en '\x00' | dd of
=$DISK conv
=fsync bs
=1 count
=1 seek
=462 status
=none
441 xzcat .
/boot
/core.img.xz
| dd status
=none conv
=fsync of
=$DISK bs
=512 count
=2047 seek
=1
444 dd status
=none conv
=fsync
if=.
/rsvdata.bin seek
=2040 bs
=512 count
=8 of
=${DISK}
447 xzcat .
/ventoy
/ventoy.disk.img.xz
| dd status
=none conv
=fsync of
=$DISK bs
=512 count
=$VENTOY_SECTOR_NUM seek
=$part2_start
451 if [ "$SECUREBOOT" != "YES" ]; then
454 vtdebug
"mounting part2 ...."
456 if mount
${PART2} .
/tmp_mnt
; then
457 vtdebug
"mounting part2 success"
463 rm -f .
/tmp_mnt
/EFI
/BOOT
/BOOTX64.EFI
464 rm -f .
/tmp_mnt
/EFI
/BOOT
/grubx64.efi
465 rm -f .
/tmp_mnt
/EFI
/BOOT
/BOOTIA32.EFI
466 rm -f .
/tmp_mnt
/EFI
/BOOT
/grubia32.efi
467 rm -f .
/tmp_mnt
/EFI
/BOOT
/MokManager.efi
468 rm -f .
/tmp_mnt
/EFI
/BOOT
/mmia32.efi
469 rm -f .
/tmp_mnt
/ENROLL_THIS_KEY_IN_MOKMANAGER.cer
470 mv .
/tmp_mnt
/EFI
/BOOT
/grubx64_real.efi .
/tmp_mnt
/EFI
/BOOT
/BOOTX64.EFI
471 mv .
/tmp_mnt
/EFI
/BOOT
/grubia32_real.efi .
/tmp_mnt
/EFI
/BOOT
/BOOTIA32.EFI
475 if umount .
/tmp_mnt
; then
476 vtdebug
"umount part2 success"
480 vtdebug
"umount part2 failed, now retry..."
487 vtinfo
"Update Ventoy to $DISK successfully finished."