Arch Linux não mostra o bootloader no sistema UEFI

5

Instalei recentemente o Arch no meu laptop (Dell Precision M4500). Eu tinha acabado de mudar o disco rígido, então tive que particionar do zero durante a instalação. Eu escolhi ir para uma partição GPT e também definir o meu sistema para inicializar com UEFI.

Durante a instalação, tentei instalar o GRUB e falhei, pois estava usando o comando tradicional para instalar em um disco MBR ( grub-install /dev/sda ). Isso falhou com uma mensagem sobre EFI (eu não me lembro o que) então eu fui para bootctl em vez disso. Eu segui o Guia do Arch Beginners ao pé da letra:

# bootctl install

Criado boot/loader/entries/arch.conf com o seguinte conteúdo:

title   Arch Linux
linux   /vmlinuz-linux
initrd  /initramfs-linux.img
options root=/dev/sda2 rw

e /boot/loader/loader.conf

timeout 3
default arch

Eu então comecei a instalar o sistema normalmente. No entanto, após a reinicialização, me é apresentada uma tela preta e nenhum gerenciador de inicialização após os POSTs do sistema. A única maneira de chegar ao bootloader é pressionar F12 para abrir o menu de inicialização do sistema (o mesmo que permite - ou permitir, quando o sistema não era EFI de qualquer maneira - chegar ao BIOS ) e depois escolha "linux bootloader" no menu. Isso me levará a uma tela de bootloader onde eu posso escolher "Arch".

  1. O menu que eu obtenho quando pressiono F12 :

  2. Seeuescolher"grub", obtenho:

    escolhendo"grub" novamente me leva de volta ao mesmo menu.

  3. Se, no primeiro menu, eu escolher "Linux Boot Manager", recebo um menu com uma entrada Arch e uma entrada "EFI default loader":

    Escolher"Arch" inicializa minha instalação do Arch e a opção "EFI default loader" me leva ao menu mostrado em 4 abaixo.

  4. Se, no primeiro menu, eu escolher "UEFI: INT 13 (RAID.0x80)", recebo um menu com apenas uma entrada Arch, escolhendo qual será o boot do meu sistema Arch:

Eutambémtenteiinstalargrub(corretamentedestavez):

pacman-Sefibootmgrgrubos-probergrub-install--target=x86_64-efi--efi-directory=/boot/EFI--bootloader-id=grub--recheckgrub-mkconfig-o/boot/grub/grub.cfg

Issofezcomqueumanovaentrada"grub" aparecesse no menu de inicialização F12 , mas a seleção me levou a uma tela preta e depois de volta ao menu de inicialização.

Meu grub.cfg é (comentários removidos):

insmod part_gpt
insmod part_msdos
if [ -s $prefix/grubenv ]; then
  load_env
fi
if [ "${next_entry}" ] ; then
   set default="${next_entry}"
   set next_entry=
   save_env next_entry
   set boot_once=true
else
   set default="0"
fi

if [ x"${feature_menuentry_id}" = xy ]; then
  menuentry_id_option="--id"
else
  menuentry_id_option=""
fi

export menuentry_id_option

if [ "${prev_saved_entry}" ]; then
  set saved_entry="${prev_saved_entry}"
  save_env saved_entry
  set prev_saved_entry=
  save_env prev_saved_entry
  set boot_once=true
fi

function savedefault {
  if [ -z "${boot_once}" ]; then
    saved_entry="${chosen}"
    save_env saved_entry
  fi
}

function load_video {
  if [ x$feature_all_video_module = xy ]; then
    insmod all_video
  else
    insmod efi_gop
    insmod efi_uga
    insmod ieee1275_fb
    insmod vbe
    insmod vga
    insmod video_bochs
    insmod video_cirrus
  fi
}

if [ x$feature_default_font_path = xy ] ; then
   font=unicode
else
insmod part_gpt 
insmod ext2
set root='hd0,gpt2'
if [ x$feature_platform_search_hint = xy ]; then
  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt2 --hint-efi=hd0,gpt2 --hint-baremetal=ahci0,gpt2  98202b4b-af35-413a-b3ff-87c149c5061d
else
  search --no-floppy --fs-uuid --set=root 98202b4b-af35-413a-b3ff-87c149c5061d
fi
    font="/usr/share/grub/unicode.pf2"
fi

if loadfont $font ; then
  set gfxmode=auto
  load_video
  insmod gfxterm
  set locale_dir=$prefix/locale
  set lang=en_US
  insmod gettext
fi
terminal_input console
terminal_output gfxterm
if [ x$feature_timeout_style = xy ] ; then
  set timeout_style=menu
  set timeout=5
else
  set timeout=5
fi

menuentry 'Arch Linux' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-simple-98202b4b-af35-413a-b3ff-87c149c5061d' {
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_gpt 
    insmod fat
    set root='hd0,gpt1'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1  9943-114D
    else
      search --no-floppy --fs-uuid --set=root 9943-114D
    fi
    echo    'Loading Linux linux ...'
    linux   /vmlinuz-linux root=UUID=98202b4b-af35-413a-b3ff-87c149c5061d rw  quiet
    echo    'Loading initial ramdisk ...'
    initrd   /initramfs-linux.img
}
submenu 'Advanced options for Arch Linux' $menuentry_id_option 'gnulinux-advanced-98202b4b-af35-413a-b3ff-87c149c5061d' {
    menuentry 'Arch Linux, with Linux linux' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-advanced-98202b4b-af35-413a-b3ff-87c149c5061d' {
        load_video
        set gfxpayload=keep
        insmod gzio
        insmod part_gpt 
        insmod fat
        set root='hd0,gpt1'
        if [ x$feature_platform_search_hint = xy ]; then
          search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1  9943-114D
        else
          search --no-floppy --fs-uuid --set=root 9943-114D
        fi
        echo    'Loading Linux linux ...'
        linux   /vmlinuz-linux root=UUID=98202b4b-af35-413a-b3ff-87c149c5061d rw  quiet
        echo    'Loading initial ramdisk ...'
        initrd   /initramfs-linux.img
    }
    menuentry 'Arch Linux, with Linux linux (fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-fallback-98202b4b-af35-413a-b3ff-87c149c5061d' {
        load_video
        set gfxpayload=keep
        insmod gzio
        insmod part_gpt 
        insmod fat
        set root='hd0,gpt1'
        if [ x$feature_platform_search_hint = xy ]; then
          search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1  9943-114D
        else
          search --no-floppy --fs-uuid --set=root 9943-114D
        fi
        echo    'Loading Linux linux ...'
        linux   /vmlinuz-linux root=UUID=98202b4b-af35-413a-b3ff-87c149c5061d rw  quiet
        echo    'Loading initial ramdisk ...'
        initrd   /initramfs-linux-fallback.img
    }
}
if [ -f  ${config_directory}/custom.cfg ]; then
  source ${config_directory}/custom.cfg
elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
  source $prefix/custom.cfg;
fi

Minha tabela de partições (observe o erro, não sei se isso é relevante):

$ sudo parted  /dev/sda print
Error: The backup GPT table is corrupt, but the primary appears OK, so that will
be used.
OK/Cancel? OK                                                             
Model: ATA TOSHIBA MQ01ABD0 (scsi)
Disk /dev/sda: 750GB
Sector size (logical/physical): 512B/4096B
Partition Table: gpt
Disk Flags: 

Number  Start   End     Size    File system     Name  Flags
 1      1049kB  538MB   537MB   fat32                 boot, esp
 2      538MB   32.7GB  32.2GB  ext4
 3      32.7GB  462GB   429GB   ext4
 4      462GB   479GB   17.2GB  linux-swap(v1)
 5      479GB   750GB   271GB   ntfs                  msftdata

e /etc/fstab :

# /dev/sda2
UUID=98202b4b-af35-413a-b3ff-87c149c5061d   /           ext4        rw,relatime,data=ordered    0 1
# /dev/sda3
UUID=baa9dd1e-835c-4d88-af8a-31dc97ac7af6   /home       ext4        rw,relatime,data=ordered    0 2
# /dev/sda1
UUID=9943-114D          /boot       vfat        rw,relatime,fmask=0022,dmask=0022,codepage=437,iocharset=iso8859-1,shortname=mixed,errors=remount-ro    0 2
# /dev/sda4
UUID=8eaf91cd-f638-487b-8299-50d39342df0d   none        swap        defaults    0 0

(Minha partição EFI ( sda1 ) é montada em /boot ; deve ser /boot/EFI ?)

Então, minha pergunta é: como fazer meu sistema inicializar diretamente em um gerenciador de inicialização utilizável sem precisar pressionar F12 ? Eu preferiria que este bootloader fosse grub , mas eu poderia viver com bootctl , se necessário.

    
por terdon 12.12.2015 / 13:43

1 resposta

4

Depois de tentar todo tipo de coisas, nenhuma das quais fez qualquer diferença, eu finalmente descobri que o que eu tinha que fazer era desabilitar o fastboot no meu BIOS. No meu caso, foi:

Mudandode"Minimal" para "Thorough", vou direto para o meu bootloader sem precisar acertar F12 .

    
por 12.12.2015 / 16:26