Steve McIntyre <st...@einval.com> (2014-11-12):
> Current patches attached here.
> 
> I was totally thrown in testing by #768788 - some of my tests on
> installed EFI systems were failing, due to the broken GUID on the
> ESP. Yay!
> 
> I've merged things forward and I'm ready to push these changes. Please
> review one last time?

The HW situation looks crazy but your patches do not (from my very
limited comprehension of the issue); the partman-efi one slightly gives
me the creeps but basically only because I'm really not familiar with
this code. ;)

(I hope you won't have to run fast because of the templates. ;))

Good job, Steve!

Mraw,
KiBi.

> -- 
> Steve McIntyre, Cambridge, UK.                                st...@einval.com
> "I've only once written 'SQL is my bitch' in a comment. But that code 
>  is in use on a military site..." -- Simon Booth

> >From 3d16e8491d1ddc0a8903d173af989906de1b7d43 Mon Sep 17 00:00:00 2001
> From: Steve McIntyre <st...@einval.com>
> Date: Wed, 1 Oct 2014 23:58:10 +0100
> Subject: [PATCH] Recognise the new ignore_uefi flag from partman-efi
> 
> ---
>  debian/changelog |    7 +++++++
>  grub-installer   |    6 +++++-
>  2 files changed, 12 insertions(+), 1 deletion(-)
> 
> diff --git a/debian/changelog b/debian/changelog
> index 4baf893..ff8fa14 100644
> --- a/debian/changelog
> +++ b/debian/changelog
> @@ -1,3 +1,10 @@
> +grub-installer (1.99) unstable; urgency=medium
> +
> +  [ Steve McIntyre ]
> +  * Recognise the new ignore_uefi flag from partman-efi.
> +
> + -- Steve McIntyre <93...@debian.org>  Wed, 01 Oct 2014 01:42:22 +0100
> +
>  grub-installer (1.98) unstable; urgency=medium
>  
>    [ Philip Hands ]
> diff --git a/grub-installer b/grub-installer
> index bff4174..ad5d688 100755
> --- a/grub-installer
> +++ b/grub-installer
> @@ -329,7 +329,11 @@ case $ARCH in
>       fi
>       ;;
>      i386/efi|amd64/efi)
> -     grub_package="grub-efi"
> +     if [ -f /var/lib/partman/ignore_uefi ]; then
> +             grub_package="grub-pc"
> +     else
> +             grub_package="grub-efi"
> +     fi
>       ;;
>      i386/*|amd64/*)
>       grub_package="grub-pc"
> -- 
> 1.7.10.4
> 

> >From f8633afbcbae7f8c9b0a588b62de8c7f490d7638 Mon Sep 17 00:00:00 2001
> From: Steve McIntyre <st...@einval.com>
> Date: Wed, 12 Nov 2014 01:08:55 +0000
> Subject: [PATCH] Recognise the new ignore_uefi flag from partman-efi
> 
> ---
>  debian/changelog |    7 +++++++
>  src/system/efi.c |    9 ++++++++-
>  2 files changed, 15 insertions(+), 1 deletion(-)
> 
> diff --git a/debian/changelog b/debian/changelog
> index d10bc4d..f637394 100644
> --- a/debian/changelog
> +++ b/debian/changelog
> @@ -1,3 +1,10 @@
> +libdebian-installer (0.98) unstable; urgency=low
> +
> +  [ Steve McIntyre ]
> +  * Recognise the new ignore_uefi flag from partman-efi.
> +
> + -- Steve McIntyre <93...@debian.org>  Wed, 01 Oct 2014 01:42:22 +0100
> +
>  libdebian-installer (0.97) unstable; urgency=low
>  
>    [ Jérémy Bobbio ]
> diff --git a/src/system/efi.c b/src/system/efi.c
> index 41af731..84659ef 100644
> --- a/src/system/efi.c
> +++ b/src/system/efi.c
> @@ -28,7 +28,14 @@ int di_system_is_efi(void)
>  {
>       int ret = access("/sys/firmware/efi", R_OK);
>       if (ret == 0)
> -             return 1;
> +     {
> +             /* Have we been told to ignore EFI in partman-efi? */
> +             ret = access("/var/lib/partman/ignore_uefi", R_OK);
> +             if (ret == 0)
> +                     return 0;
> +             else
> +                     return 1;
> +     }
>       else
>               return 0;
>  }
> -- 
> 1.7.10.4
> 

> >From e5870c91bdf678208a28806370af3b16a09e5e74 Mon Sep 17 00:00:00 2001
> From: Steve McIntyre <st...@einval.com>
> Date: Thu, 2 Oct 2014 00:03:25 +0100
> Subject: [PATCH] Recognise the new ignore_uefi flag from partman-efi
> 
> ---
>  debian/changelog     |    7 +++++++
>  debian/isinstallable |    2 +-
>  2 files changed, 8 insertions(+), 1 deletion(-)
> 
> diff --git a/debian/changelog b/debian/changelog
> index 61ac47e..615acee 100644
> --- a/debian/changelog
> +++ b/debian/changelog
> @@ -1,3 +1,10 @@
> +lilo-installer (1.47) unstable; urgency=low
> +
> +  [ Steve McIntyre ]
> +  * Recognise the new ignore_uefi flag from partman-efi.
> +
> + -- Steve McIntyre <93...@debian.org>  Wed, 01 Oct 2014 01:42:22 +0100
> +
>  lilo-installer (1.46) unstable; urgency=low
>  
>    [ Updated translations ]
> diff --git a/debian/isinstallable b/debian/isinstallable
> index e3f9708..80a7939 100755
> --- a/debian/isinstallable
> +++ b/debian/isinstallable
> @@ -11,7 +11,7 @@ case $ARCH in
>       # LILO stands a better chance of working in BIOS compatibility mode,
>       # where /sys/firmware/efi doesn't exist.
>       # Note: depends on partman-efi to load the efivars module!
> -     if [ -d /sys/firmware/efi ]; then
> +     if [ -d /sys/firmware/efi ] && [ ! -f /var/lib/partman/ignore_uefi ]; 
> then
>               log "LILO not usable on EFI PCs without BIOS compatibility; use 
> grub-efi"
>               exit 1
>       fi
> -- 
> 1.7.10.4
> 

> >From d4199b453834801538d0f41b5b18f0a71850425a Mon Sep 17 00:00:00 2001
> From: Steve McIntyre <st...@einval.com>
> Date: Thu, 2 Oct 2014 00:05:15 +0100
> Subject: [PATCH] Recognise the new ignore_uefi flag from partman-efi
> 
> ---
>  debian/changelog                  |    7 +++++++
>  os-probes/mounted/x86/05efi       |    2 +-
>  os-probes/mounted/x86/20microsoft |    2 +-
>  3 files changed, 9 insertions(+), 2 deletions(-)
> 
> diff --git a/debian/changelog b/debian/changelog
> index 1499695..84a81e4 100644
> --- a/debian/changelog
> +++ b/debian/changelog
> @@ -1,3 +1,10 @@
> +os-prober (1.65) unstable; urgency=medium
> +
> +  [ Steve McIntyre ]
> +  * Recognise the new ignore_uefi flag from partman-efi.
> +
> + -- Steve McIntyre <93...@debian.org>  Wed, 01 Oct 2014 01:42:22 +0100
> +
>  os-prober (1.64) unstable; urgency=medium
>  
>    [ Frederic Bonnard ]
> diff --git a/os-probes/mounted/x86/05efi b/os-probes/mounted/x86/05efi
> index e77ca6d..93309ce 100755
> --- a/os-probes/mounted/x86/05efi
> +++ b/os-probes/mounted/x86/05efi
> @@ -8,7 +8,7 @@ mpoint="$2"
>  type="$3"
>  
>  # This file is for UEFI platform only
> -if [ ! -d /sys/firmware/efi ]; then
> +if [ ! -d /sys/firmware/efi ] || [ -f /var/lib/partman/ignore_uefi ]; then
>       debug "Not on UEFI platform"
>       exit 1
>  fi
> diff --git a/os-probes/mounted/x86/20microsoft 
> b/os-probes/mounted/x86/20microsoft
> index bf829d9..6fb3cc5 100755
> --- a/os-probes/mounted/x86/20microsoft
> +++ b/os-probes/mounted/x86/20microsoft
> @@ -8,7 +8,7 @@ mpoint="$2"
>  type="$3"
>  
>  # This script looks for legacy BIOS bootloaders only. Skip if running UEFI
> -if [ -d /sys/firmware/efi ]; then
> +if [ -d /sys/firmware/efi ] && [ ! -f /var/lib/partman/ignore_uefi ]; then
>       debug "Skipping legacy bootloaders on UEFI system"
>       exit 1
>  fi
> -- 
> 1.7.10.4
> 

> >From 7e80794efb8d1b717eafa951a9d70fc30ffe6804 Mon Sep 17 00:00:00 2001
> From: Steve McIntyre <st...@einval.com>
> Date: Wed, 12 Nov 2014 00:40:37 +0000
> Subject: [PATCH] Better handle mixed UEFI and non-UEFI booting
> 
> Warn the user if we've booted in UEFI mode but we seem to have only
> non-UEFI existing OS installations - give them the option to switch
> the installer to non-UEFI mode from this point forwards so they don't
> break potential dual-boot setup. Closes: #763127
> 
> Check for EFI System Partitions on the target disks - if we have none
> but have other filesystems then that suggests there is a BIOS-mode OS
> already installed. If so, ask the user what they want to do.
> 
> Add a flag file /var/lib/partman/ignore_uefi that other bits of d-i
> can look for to know that although the installer is running in UEFI
> mode we should stick to installing for BIOS-mode boot instead.
> ---
>  check.d/efi                  |    4 ++++
>  choose_method/efi/choices    |    4 ++++
>  debian/changelog             |   10 ++++++++++
>  debian/partman-efi.templates |   16 ++++++++++++++++
>  debian/po/templates.pot      |   15 +++++++++++++++
>  init.d/efi                   |   25 +++++++++++++++++++++++++
>  update.d/efi_visuals         |    4 ++++
>  7 files changed, 78 insertions(+)
> 
> diff --git a/check.d/efi b/check.d/efi
> index 395688d..9d74bd3 100755
> --- a/check.d/efi
> +++ b/check.d/efi
> @@ -4,6 +4,10 @@ if [ ! -d /proc/efi ] && [ ! -d /sys/firmware/efi ]; then
>       exit 0
>  fi
>  
> +if [ -f /var/lib/partman/ignore_uefi ]; then
> +     exit 0
> +fi
> +
>  . /lib/partman/lib/base.sh
>  
>  have_efi=no
> diff --git a/choose_method/efi/choices b/choose_method/efi/choices
> index 160a565..b4af018 100755
> --- a/choose_method/efi/choices
> +++ b/choose_method/efi/choices
> @@ -9,6 +9,10 @@ if [ ! -d /proc/efi ] && [ ! -d /sys/firmware/efi ]; then
>       exit 0
>  fi
>  
> +if [ -f /var/lib/partman/ignore_uefi ]; then
> +     exit 0
> +fi
> +
>  db_metaget partman-efi/text/efi description
>  
>  printf "efi\t${RET}\n"
> diff --git a/debian/changelog b/debian/changelog
> index cc9897f..d69a4ac 100644
> --- a/debian/changelog
> +++ b/debian/changelog
> @@ -1,3 +1,13 @@
> +partman-efi (53) UNRELEASED; urgency=medium
> +
> +  [ Steve McIntyre ]
> +  * Warn the user if we've booted in UEFI mode but we seem to have only
> +    non-UEFI existing OS installations - give them the option to switch
> +    the installer to non-UEFI mode from this point forwards so they don't
> +    break potential dual-boot setup. Closes: #763127
> +
> + -- Steve McIntyre <93...@debian.org>  Wed, 12 Nov 2014 00:37:44 +0000
> +
>  partman-efi (52) unstable; urgency=medium
>  
>    [ Steve McIntyre ]
> diff --git a/debian/partman-efi.templates b/debian/partman-efi.templates
> index 6fb2f7d..c03f8de 100644
> --- a/debian/partman-efi.templates
> +++ b/debian/partman-efi.templates
> @@ -41,3 +41,19 @@ Type: error
>  _Description: EFI partition too small
>   EFI System Partitions on this architecture cannot be created with a size
>   less than 35 MB. Please make the EFI System Partition larger.
> +
> +Template: partman-efi/non_efi_system
> +Type: boolean
> +# :sl5:
> +_Description: Force UEFI installation?
> + Your computer's firmware has started the installer in UEFI mode but
> + it looks like there may be existing operating systems already
> + installed on your computer using 'BIOS compatibility mode'. If you
> + continue to install Debian in UEFI mode, it might be difficult to
> + reboot your computer into any BIOS-mode operating systems later.
> + .
> + If you wish to install Debian in UEFI mode and don't care about
> + keeping the ability to boot one of the existing systems, you have the
> + option to force that here. If you wish to keep the option to boot an
> + existing operating system, you should choose NOT to force UEFI
> + installation here.
> diff --git a/debian/po/templates.pot b/debian/po/templates.pot
> index 1a1a857..0fbf475 100644
> --- a/debian/po/templates.pot
> +++ b/debian/po/templates.pot
> @@ -85,3 +85,18 @@ msgid ""
>  "EFI System Partitions on this architecture cannot be created with a size "
>  "less than 35 MB. Please make the EFI System Partition larger."
>  msgstr ""
> +
> +#. Type: boolean
> +#. Description
> +#. :sl5:
> +#: ../partman-efi.templates:9001
> +msgid "Force EFI installation?"
> +msgstr ""
> +
> +#. Type: boolean
> +#. Description
> +#. :sl5:
> +#: ../partman-efi.templates:9001
> +msgid "EFI boot, but no ESP found and other filesystems in use"
> +msgstr ""
> +
> diff --git a/init.d/efi b/init.d/efi
> index 8955718..9418971 100755
> --- a/init.d/efi
> +++ b/init.d/efi
> @@ -30,6 +30,9 @@ fi
>  gpt_efi_type=c12a7328-f81f-11d2-ba4b-00a0c93ec93b
>  msdos_efi_type=0xef
>  
> +NUM_ESP=0
> +NUM_NO=0
> +
>  for dev in /var/lib/partman/devices/*; do
>       [ -d "$dev" ] || continue
>       cd $dev
> @@ -52,6 +55,10 @@ for dev in /var/lib/partman/devices/*; do
>               elif [ "$label_type" = gpt ] && \
>                    [ "$(blkid -o value -s PART_ENTRY_TYPE -p "$path" 
> 2>/dev/null)" = "$gpt_efi_type" ]; then
>                       partitions="$partitions $id"
> +             else
> +                     if [ "$fs" != "free" ]; then
> +                             NUM_NO=$(($NUM_NO + 1))
> +                     fi
>               fi
>       done
>       close_dialog
> @@ -62,7 +69,10 @@ for dev in /var/lib/partman/devices/*; do
>       while { read_line flag; [ "$flag" ]; }; do
>               if [ "$flag" = boot ]; then
>                       efi=yes
> +                     NUM_ESP=$(($NUM_ESP + 1))
>                       # cannot break here
> +             else
> +                     NUM_NO=$(($NUM_NO + 1))
>               fi
>       done
>       close_dialog
> @@ -72,3 +82,18 @@ for dev in /var/lib/partman/devices/*; do
>       fi
>       done
>  done
> +
> +log "Found $NUM_ESP ESPs, $NUM_NO non-ESPs"
> +
> +if [ $NUM_ESP = 0 ] && [ $NUM_NO -gt 0 ]; then
> +     db_input critical partman-efi/non_efi_system || true
> +     db_go || exit 1
> +     db_fset partman-efi/non_efi_system seen true
> +     db_get partman-efi/non_efi_system
> +     if [ "$RET" = false ]; then
> +             log "User chose to ignore UEFI"
> +             touch /var/lib/partman/ignore_uefi
> +     else
> +             log "User chose to continue in UEFI mode"
> +     fi
> +fi
> diff --git a/update.d/efi_visuals b/update.d/efi_visuals
> index eed5412..ac47af5 100755
> --- a/update.d/efi_visuals
> +++ b/update.d/efi_visuals
> @@ -6,6 +6,10 @@ if [ ! -d /proc/efi ] && [ ! -d /sys/firmware/efi ]; then
>       exit 0
>  fi
>  
> +if [ -f /var/lib/partman/ignore_uefi ]; then
> +     exit 0
> +fi
> +
>  dev=$1
>  num=$2
>  id=$3
> -- 
> 1.7.10.4

Attachment: signature.asc
Description: Digital signature

Reply via email to