- boot=`basename $i`
- mountpoint -q /hd && umount /hd
- dialog --title " Confirm " --defaultno --yesno \
- "\n Do you want to format the boot partition\n /dev/$boot?" 8 45
- [ $? -eq 0 ] && mkdosfs -n EFI /dev/$boot
- try_mount rw /dev/$boot /hd
- cp -af /grub2/efi /hd
- grubcfg=/hd/efi/boot/grub.cfg
- echo -e "set timeout=6" > $grubcfg
- echo -e "menuentry \"Android-x86 $VER\" {\n\tsearch --set=root --file /$asrc/kernel\n\tlinuxefi /$asrc/kernel quiet $cmdline \n\tinitrdefi /$asrc/initrd.img\n}" >> $grubcfg
- echo -e "menuentry \"Android-x86 $VER (DEBUG mode)\" {\n\tsearch --set=root --file /$asrc/kernel\n\tlinuxefi /$asrc/kernel $cmdline DEBUG=2\n\tinitrdefi /$asrc/initrd.img\n}" >> $grubcfg
- if [ -e /hd/EFI/Microsoft/Boot/bootmgfw.efi ]; then
- echo -e "menuentry \"Windows (UEFI)\" {\n\tsearch --set=root --file /EFI/Microsoft/Boot/bootmgfw.efi\n\tchainloader /EFI/Microsoft/Boot/bootmgfw.efi\n}" >> $grubcfg
+ if [ -z "$esp" ]; then
+ get_part_info $1
+ boot=$(blkid /dev/$disk* | grep -v $disk: | grep vfat | cut -d: -f1 | head -1)
+ [ -z "$boot" ] && boot=`find_partition $disk 1` || boot=`basename $boot`
+ esp=`cat /sys/block/$disk/$boot/partition`
+ fi
+ mkdir -p efi
+ mountpoint -q efi && umount efi
+ wait_for_device $boot
+ until try_mount rw /dev/$boot efi; do
+ dialog --title " Confirm " --defaultno --yesno "\n Cannot mount /dev/$boot.\n Do you want to format it?" 8 37
+ [ $? -eq 0 ] && mkdosfs -n EFI /dev/$boot
+ done
+ if [ "$efi" = "32" ]; then
+ grubcfg=efi/boot/grub/i386-efi/grub.cfg
+ bootefi=bootia32.efi
+ else
+ grubcfg=efi/boot/grub/x86_64-efi/grub.cfg
+ bootefi=BOOTx64.EFI
+ fi
+ if [ -d efi/efi/boot -a ! -s efi/efi/boot/android.cfg ]; then
+ efidir=/efi/Android
+ else
+ efidir=/efi/boot
+ rm -rf efi/efi/Android
+ fi
+ mkdir -p `dirname $grubcfg` efi$efidir
+ cp -af grub2/efi/boot/* efi$efidir
+ sed -i "s|VER|$VER|; s|CMDLINE|$cmdline|; s|OS_TITLE|$OS_TITLE|" efi$efidir/android.cfg
+ [ -s efi/boot/grub/grubenv ] || ( printf %-1024s "# GRUB Environment Block%" | sed 's/k%/k\n/; s/ /###/g' > efi/boot/grub/grubenv )
+
+ echo -e 'set timeout=5\nset debug_mode="(DEBUG mode)"' > $grubcfg
+ # Our grub-efi doesn't support ntfs directly.
+ # Copy boot files to ESP so grub-efi could read them
+ if [ "$fs" = "fuseblk" ]; then
+ cp -f src/kernel src/initrd.img efi$efidir
+ echo -e "set kdir=$efidir\nset src=SRC=/$asrc" >> $grubcfg
+ else
+ echo -e "set kdir=/$asrc" >> $grubcfg
+ fi
+ echo -e '\nsource $cmdpath/android.cfg' >> $grubcfg
+
+ # Checking for old EFI entries, removing them and adding new depending on bitness
+ efibootmgr | grep -Eo ".{0,6}Android-x86" | cut -c1-4 > /tmp/efientries
+ if [ -s /tmp/efientries ]; then
+ set_answer_if_auto 1
+ adialog --title " Question " --yesno "\nEFI boot entries for previous Android-x86 installations were found.\n\nDo you wish to delete them?" 10 61
+ [ $? -eq 0 ] && while read entry; do efibootmgr -Bb "$entry" > /dev/tty4 2>&1; done < /tmp/efientries
+ fi
+ efibootmgr -v -c -d /dev/$disk -p $esp -L "Android-x86 $VER" -l $efidir/$bootefi > /dev/tty4 2>&1
+
+ if [ -s efi/startup.nsh ]; then
+ sed -i "s|\\\\efi\\\\Android|$efidir|; s|/|\\\\|g" efi/startup.nsh
+ else
+ echo $efidir/$bootefi | sed 's|/|\\|g' > efi/startup.nsh