Unified Extensible Firmware Interface (Español)
La Unified Extensible Firmware Interface (UEFI o EFI para abreviar) es un nuevo modelo de interfaz para interactuar entre los sistemas operativos y el firmware. Proporciona un entorno estándar para iniciar un sistema operativo y ejecutar aplicaciones previas al inicio.
Es un método distito del comunmente usado «código de arranque MBR» seguido por los sistemas BIOS. Consulte Arch boot process para conocer sus diferencias y el proceso de arranque con UEFI. Para configurar los cargadores de arranque UEFI, vea Category:Boot loaders.
Versiones de UEFI
- UEFI comenzó como EFI de Intel en las versiones 1.x.
- Luego, un grupo de empresas denominado UEFI Forum, se hizo cargo de su desarrollo, a partir del cual se llamó EFI Unificado desde de la versión 2.0.
- Salvo que se especifique expresamente como EFI 1.x, los términos EFI y UEFI se utilizarán indistintamente para referirse al firmware 2.x de UEFI .
- La implementación EFI de Apple no es ni la versión 1.x de EFI ni la versión 2.x, sino una combinación de ambas. Este tipo de firmware no entra dentro de ninguna versión de la especificación (U)EFI uno y, por lo tanto, no es un estándar del firmware de UEFI. A menos que se indique explícitamente, estas instrucciones son generales y algunas de ellas pueden no funcionar o pueden ser diferentes en Apple Macs.
La última especificación de UEFI se puede encontrar en https://uefi.org/specifications.
Firmware de UEFI
Con UEFI, cada programa, ya sea un cargador de sistema operativo o una utilidad (por ejemplo, una aplicación de prueba de memoria o una herramienta de recuperación), debe ser una aplicación EFI correspondiente a la arquitectura/bitness del firmware de UEFI.
La gran mayoría de los firmwares UEFI, incluidos los recientes Macs de Apple, usan el firmware UEFI x86_64. Los únicos dispositivos conocidos que utilizan UEFI IA32 (32 bits) son Apple Mac antiguos (anteriores a 2008), algunos ultrabooks Intel Cloverfield y algunas tarjetas del servidor Intel antiguo que se sabe que operan con firmware Intel EFI 1.10.
Un firmware UEFI x86_64 no incluye soporte para el inicio de aplicaciones EFI de 32 bits (a diferencia de las versiones de Linux y Windows x86_64, que incluyen dicho soporte). Por lo tanto, la aplicación EFI debe compilarse para el firmware de esa específica arquitectura del procesador.
Sistemas UEFI que no son Mac
Compruebe si el directorio /sys/firmware/efi
existe; si existe, significa que el kernel ha arrancado en modalidad UEFI. En ese caso, se presumirá que la arquitectura de UEFI coincidirá con la del kernel (es decir, i686 o x86_64)
Mac de Apple
Los Mac anteriores a 2008 tienen, en su mayoría, un firware IA32 EFI, mientras que los Mac >=2008 tienen, en su mayoría, x86_64 EFI. Todos los Mac capaces de ejecutar el kernel de Mac OS X Snow Leopard de 64-bit tienen un firmware EFI 1.x para x86_64.
Para saber la arquitectura del firmware EFI en un Mac, debe arrancar Mac OS X y escribir en un terminal la siguiente orden:
$ ioreg -l -p IODeviceTree | grep firmware-abi
Si la orden devuelve EFI32, entonces es el firmware EFI IA32 (32 bits). Si devuelve EFI64, entonces es el firmware EFI x86_64. La mayoría de los Mac no tienen firmware UEFI 2.x ya que la implementación de EFI de Apple no es totalmente compatible con la especificación UEFI 2.x.
Configuración de las opciones del kernel de Linux para UEFI
Las opciones requeridas para la configuración del kernel de Linux para sistemas UEFI son:
CONFIG_RELOCATABLE=y CONFIG_EFI=y CONFIG_EFI_STUB=y CONFIG_FB_EFI=y CONFIG_FRAMEBUFFER_CONSOLE=y
- Soporte para las Variables Runtime de UEFI (el sistema de archivos efivarfs ——). Esta opción es importante, ya que es necesaria para manipular las variables runtime de UEFI usando herramientas como . La opción de configuración siguiente está añadida en el kernel 3.10 y posterior.:
- Soporte para las Variables Runtime de UEFI (la interfaz antigua efivars sysfs ——). Esta opción debe ser desactivada para evitar posibles problemas entre efivarfs con sysfs-efivars activados.:
CONFIG_EFI_VARS=n
- Opción de configuración de GUID Partition Table (GPT) —necesaria para dar soporte a UEFI—:
CONFIG_EFI_PARTITION=y
Obtenido de https://docs.kernel.org/x86/x86_64/uefi.html.
Variables de UEFI
UEFI define las variables como la interacción de un sistema operativo con el firmware. Las variables de arranque de UEFI («UEFI Boot Variables») son utilizadas por el cargador de arranque y por el sistema operativo únicamente durante la primera fase de arranque. Las variables «runtime» de UEFI permiten a un sistema operativo gestionar ciertos ajustes del firmware, como la gestión del arranque de UEFI o la gestión de las claves para el protocolo «Boot Secure» de UEFI, etc. Se puede obtener el listado de las variables utilizando:
$ efivar --list
Soporte de las variables UEFI en el kernel de Linux
El kernel de Linux expone los datos de las variables UEFI en el espacio de usuario a través de la interfaz efivarfs (EFI VARiable FileSystem) () —montada utilizando el módulo del kernel en — no tiene límite de tamaño máximo y admite las variables «Secure Boot» de UEFI. Introducido en kernel 3.8.
Requisitos para que el soporte de las variables UEFI funcione correctamente
- La arquitectura del procesador del Kernel y del procesador de UEFI deben coincidir.
- El kernel debe arrancar en modo EFI (a través de EFISTUB o de cualquier otro gestor de arranque EFI, no a través de BIOS/CSM o «bootcamp» de Apple que también es BIOS/CSM)
- El soporte para EFI Runtime Services debe estar presente en el kernel (, compruebe si están presente con ).
- Los EFI Runtime Services del kernel NO DEBEN ser desactivados a través de un terminal, es decir, el parámetro del kernel NO DEBE ser usado.
- El sistema de archivos debe estar montado en , en otro caso, debe montar efivarfs.
- debe mostar (con la opción ) las variables EFI sin ningún error.
Si el soporte para las variables de EFI no funciona, incluso después de cumplirse las condiciones precedentes, pruebe las siguientes soluciones:
- Si cualquier herramienta del espacio de usuario no puede modificar los datos de las variables de EFI, compruebe la existencia de archivos en . Si existen, elimínelos, reinicie y vuelva a intentarlo de nuevo.
- Si el paso anterior no resuelve el problema, intente arrancar con el parámetro del kernel
efi_no_storage_paranoia
para desactivar la variable efi del kernel que comprueba el espacio de almacenamiento, la cual puede impedir la escritura/modificación de las variables de efi.
efi_no_storage_paranoia
solo debe utilizarse cuando sea necesario y no se debe dejar como una opción de arranque normal. El efecto de este parámetro en la línea de órdenes del kernel cancela una garantía que se pone en marcha para ayudar a evitar la saturación de las máquinas cuando NVRAM se llena demasiado.Montar efivarfs
Si no se monta automáticamente en por systemd durante el arranque, entonces necesita montarla manualmente para dejar expuesto el soporte para las variables de UEFI a las herramientas del espacio de usuario tales como efibootmgr:
# mount -t efivarfs efivarfs /sys/firmware/efi/efivars
Consulte efivarfs.html para documentarse más sobre el kernel.
Herramientas en el espacio de usuario
Existen algunas herramientas que permiten acceder/modificar las variables UEFI, como:
efibootmgr
Para añadir una nueva opción de arranque usando efibootmgr, necesita saber tres cosas:
- El disco que contiene la EFI system partition (Español) (ESP):
- El número de partición de la ESP en ese disco: la en
/dev/sdXY
- La ruta a la aplicación EFI (relativa a la raíz de la ESP)
Por ejemplo, si desea agregar una opción de arranque para donde es el punto de montaje de la partición ESP, ejecute:
$ findmnt /efi
TARGET SOURCE FSTYPE OPTIONS /efi /dev/sda1 vfat rw,flush,tz=UTC
En este ejemplo, esto indica que la partición ESP está en el disco y el número de la partición es 1. La ruta a la aplicación EFI relativa a la raíz de la ESP es . Sabiendo esto, se crearía la entrada de arranque de la siguiente manera:
# efibootmgr --create --disk /dev/sda --part 1 --loader /EFI/refind/refind_x64.efi --label "rEFInd Boot Manager" --verbose
Consulte o el archivo README de efibootmgr para obtener más información.
Intérprete de órdenes UEFI
El intérprete de órdenes de UEFI es una intérprete/terminal para el firmware, que permite ejecutar aplicaciones UEFI que incluyen los cargadores de arranque UEFI. Aparte de esto, el intérprete también se puede utilizar para obtener información variada sobre el sistema o del firmware del mapa de la memoria (memmap), modificar las variables del gestor de arranque (bcfg), ejecutar programas de gestión de particiones (diskpart), cargar los controladores UEFI, editar archivos de texto (edit), hexedit, etc.
Obtener el intérprete de órdenes UEFI
Puede descargar un intérprete de órdenes UEFI con licencia BSD de Tianocore de Intel desde el proyecto UDK/EDK2.
- Paquete de AUR (recomendado) —proporciona la shell x86_64 para x86_64 (64-bit) de UEFI y la shell IA32 para IA32 (32-bit) de UEFI— compilado directamente de la última fuente de TianoCore EDK2.
- Hay copias de la shell v1 y v2 en el directorio EFI en la imagen de instalación de Arch.
- Binarios precompilados de la shell v2 de UEFI (puede no estar actualizado).
- Binarios precompilados de UEFI Shell v1 (no actualizado por los desarrolladores).
- Binario precompilado de la shell v2 de UEFI con bcfg modificado para trabajar con el firmware UEFI pre-2.3 —del cargador de arranque Clover EFI—.
La versión 2.0 de la shell únicamente funciona en sistemas UEFI 2.3 + y se recomienda su uso con preferencia a la shell 1.0 en esos sistemas. La versión 1.3 de la shell debería funcionar en todos los sistemas UEFI, independientemente de la especificación de la versión del firmware. Más información en ShellPkg y este correo[enlace roto 2022-09-23].
Lanzar el intérprete de órdenes UEFI
Algunas placas base Asus y otras basadas en el firmware UEFI AMI Aptio x86_64 (de Sandy Bridge en adelante) ofrecen una opción llamada . Para estas placas base, descargue la shell de UEFI x86_64 y cópiela a la partición del sistema UEFI renombrándola como (normalmente en la carpeta ).
Los sistemas con un firmware UEFI Phoenix SecureCore Tiano se sabe que llevan integrada la shell de UEFI, la cual se puede iniciar presionando las teclas , o .
Shell.efi
, copiada con la ruta (USB)/efi/boot/bootx64.efi
. Este USB debería aparecer en el menú de arranque del firmware. La inicialización de esta opción lanzará la shell de UEFI.Órdenes importantes del intérprete UEFI
Las órdenes del intérprete UEFI generalmente dan soporte a la opción que hace una pausa después de la salida de cada página. Ejecute para ver las órdenes disponibles.
Puede obtener más información en https://software.intel.com/en-us/articles/efi-shells-and-scripting/
bcfg
La orden se utiliza para modificar las entradas en la NVRAM de UEFI, lo que permite cambiar las entradas de arranque o las opciones del controlador. Esta orden se describe con detalle en la página 83 (sección 5.3) del documento UEFI Shell Specification 2.0
- Se recomienda probar
bcfg
únicamente siefibootmgr
no puede crear entradas de inicio que funcionen en el propio sistema. - La versión 1 del binario oficial del intérprete de órdenes UEFI no proporciona soporte para la orden
bcfg
. Consulte #Obtener el intérprete de órdenes UEFI para un binario UEFI shell v2 modificado que puede funcionar en UEFI con firmwares anteriores a 2.3.
Para conocer una lista de entradas de arranque actuales:
Shell> bcfg boot dump -v
Para añadir una entrada para rEFInd (por ejemplo) como cuarta (la numeración empieza desde cero) en el menú de arranque:
Shell> bcfg boot add 3 FS0:\EFI\refind\refind_x64.efi "rEFInd"
donde es la asignación correspondiente a la partición del sistema UEFI y es el archivo que se pondrá en marcha.
Para agregar una entrada con el fin de iniciar directamente su sistema, sin un gestor de arranque, configure una opción de arranque utilizando su kernel como EFISTUB:
Shell> bcfg boot add N fsV:\vmlinuz-linux "Arch Linux" Shell> bcfg boot -opt N "root=/dev/sdX# initrd=\initramfs-linux.img"
donde es la prioridad, es el número de volumen donde se encuetra la partición de sistema EFI, y es la partición raíz.
Para quitar la opción de arranque cuarta:
Shell> bcfg boot rm 3
Para mover la opción de arranque #3 a #0 (es decir, a la primera posición o la entrada por defecto en el menú de inicio de UEFI):
Shell> bcfg boot mv 3 0
Para mostrar el texto de ayuda de bcfg:
Shell> help bcfg -v -b
o
Shell> bcfg -? -v -b
map
La orden muestra un mapeado de los dispositivos, es decir, los nombres de los sistemas de archivos disponibles () y los dispositivos de almacenamiento (blk0
).
Antes de ejecutar órdenes relacionadas con el sistema de archivos, como o , debe cambiar el intérprete de órdenes al sistema de archivos correspondiente, escribiendo su nombre:
Shell> FS0: FS0:\> cd EFI/
edit
La orden edit
proporciona un editor de texto básico, con una interfaz similar al editor de texto nano, pero ligeramente menos funcional. Maneja codificación UTF-8 y se hace cargo del final de la línea LF frente a CRLF.
Para editar, por ejemplo, de rEFInd en la partición del sistema UEFI (FS0: en el firmware):
Shell> edit FS0:\EFI\refind\refind.conf
Escriba para obtener ayuda.
Soporte para arrancar UEFI
Crear un USB arrancable con UEFI desde la ISO
Siga las instrucciones del siguiente artículo USB Installation Media (Español)#Crear USB para arrancar desde sistemas BIOS y UEFI
Eliminar el apoyo de arranque de UEFI de una unidad óptica
La mayoría de los Mac EFI de 32-bit y algunos Mac EFI de 64 bits se niegan a arrancar desde un CD/DVD bootable con una combinación de UEFI(X64)+BIOS. Si se desea continuar con la instalación con soportes ópticos, puede que sea necesario, primero, eliminar el apoyo a UEFI.
- Monte el soporte de instalación oficial y obtenga el como se muestra en la sección anterior.
# mount -o loop input.iso /mnt/iso
- Después reconstruya la ISO, excluyendo el soporte de arranque de UEFI de la imágen destinada al disco óptico, utilizando de . Asegúrese de configurar el archisolabel correcto, por ejemplo «ARCH_201411» o similar:
$ xorriso -as mkisofs -iso-level 3 \ -full-iso9660-filenames\ -volid "''archisolabel''" \ -appid "Arch Linux CD" \ -publisher "Arch Linux <https://archlinux.org>" \ -preparer "prepared by $USER" \ -eltorito-boot isolinux/isolinux.bin \ -eltorito-catalog isolinux/boot.cat \ -no-emul-boot -boot-load-size 4 -boot-info-table \ -isohybrid-mbr "/mnt/iso/isolinux/isohdpfx.bin" \ -output ''output.iso'' /mnt/iso/
- Grabe en el disco óptico y continúe con la instalación de forma normal.
Probar UEFI en sistemas sin soporte nativo
OVMF para máquinas virtuales
OVMF es un proyecto de TianoCore destinado a activar la compatibilidad de UEFI para máquinas virtuales. OVMF contiene una muestra de firmware UEFI para QEMU.
Se puede instalar desde el repositorio extra.
Es recomendable hacer una copia local del conjunto de variables no volátiles para su máquina virtual:
$ cp /usr/share/ovmf/x64/OVMF_VARS.fd my_uefi_vars.bin
Para usar el firmware OVMF y el conjunto de variables, añada la siguiente orden a su QEMU:
-drive if=pflash,format=raw,readonly,file=/usr/share/ovmf/x64/OVMF_CODE.fd \ -drive if=pflash,format=raw,file=my_uefi_vars.bin
Por ejemplo:
$ qemu-system-x86_64 -enable-kvm -m 1G -drive if=pflash,format=raw,readonly,file=/usr/share/ovmf/x64/OVMF_CODE.fd -drive if=pflash,format=raw,file=my_uefi_vars.bin …
DUET para sistemas BIOS únicamente
DUET es un proyecto TianoCore que permite cargar en cadena un entorno UEFI completo desde un sistema BIOS, de manera similar al arranque de los sistemas operativos en entorno BIOS. Este método se está discutiendo ampliamente en https://www.insanelymac.com/forum/topic/186440-linux-and-windows-uefi-boot-using-tianocore-duet-firmware/ . Imágenes DUET precompiladas se pueden descargar de uno de los repositorios de https://gitorious.org/tianocore_uefi_duet_buildsenlace+roto+2022-09-23. Instrucciones específicas para la creación de DUET están disponible en https://gitorious.org/tianocore_uefi_duet_builds/tianocore_uefi_duet_installer/blobs/raw/master/Migle_BootDuet_INSTALL.txtenlace+roto+2022-09-23 .
También puede probar https://sourceforge.net/projects/cloverefiboot/ que proporciona imágenes DUET modificadas que puedan contener algunos arreglos específicos del sistema y son más frecuentemente actualizadas en comparación con las de los repositorios gitorious.
Solución de problemas
Windows 7 no se inicia en la modalidad UEFI
Si tiene instalado Windows en un disco duro con particionado GPT y sigue teniendo otro disco duro diferente con particionado MBR en su ordenador, entonces es posible que el firmware (UEFI) está dando su apoyo CSM a este último (para arrancar particiones MBR) y por ello Windows no arranca. Para resolver este problema convierta el particionado de su disco MBR a GPT, o desactive el puerto SATA del disco duro cuando esté conectado, o bien, desenchufe el puerto SATA de este disco duro.
Placas base con este tipo de problema:
- Gigabyte Z77X-UD3H rev. 1.1 (BIOS UEFI versión F19e)
- La opción «UEFI Only» de la BIOS UEFI no pretende hacer que la BIOS UEFI arranque desde CSM.
Windows cambia el orden de arranque
Si el arranque dual con Windows y su placa base solo inicia Windows de forma inmediata en lugar mostrar la elección de su aplicación EFI, existen varias causas posibles y soluciones alternativas.
- Asegúrese de que el inicio rápido esté desactivado en las opciones de energía de Windows
- Asegúrese de que Secure Boot esté desactivado en su BIOS (si no está utilizando un gestor de arranque firmado)
- Asegúrese de que el orden de arranque de UEFI no tiene establecido primero «Windows Boot Manager» utilizando, por ejemplo, #efibootmgr and what you see in the configuration tool of the UEFI. Algunas placas base anulan, por defecto, cualquier configuración establecida con efibootmgr por Windows, si la detecta. Esto se confirma en una computadora portátil Packard Bell.
- Si su placa base está iniciando la ruta de inicio predeterminada (), este archivo puede haber sido sobrescrito con el cargador de arranque de Windows. Intente configurar la ruta de inicio correcta, por ejemplo utilizando #efibootmgr.
- Si los pasos anteriores no funcionan, puede decirle al gestor de arranque de Windows que ejecute una aplicación EFI diferente. Desde un prompt de órdenes de «Windows Administrator»:
- Alternativamente, puede establecer una secuencia de órdenes de inicio en Windows que garantice que el orden de inicio esté configurado correctamente cada vez que inicie Windows.
- Abra un promtp de órdenes (símbolo del sistema) con privilegios de administrador. Ejecute y encuentre la entrada de inicio deseada.
- Copie el Identificador, incluidos los corchetes, por ejemplo
- Cree un archivo por lotes con la siguiente orden
- Abra gpedit.msc y en Local Computer Policy > Computer Configuration > Windows Settings > Scripts(Startup/Shutdown), seleccione Startup
- En la pestaña Scripts, seleccione el botón Add, y seleccione su archivo por lotes.
El soporte USB se topa con una pantalla negra
Este problema puede ocurrir debido a un problema con KMS. Pruebe desactivar KMS mientras arranca el USB.
El cargador de arranque UEFI no aparece en el menú del firmware
En ciertas placas base UEFI, como algunas placas con un chipset Intel Z77, agregar entradas con o desde la shell de UEFI no funcionará, porque no aparecerán en la lista del menú de arranque después de haber sido agregadas a NVRAM.
Este problema se debe a que las placas base solo pueden cargar Microsoft Windows. Para resolver esto, debe colocar el archivo .efi en la ubicación que usa Windows.
Copie el archivo bootx64.efi
del soporte de instalación de Arch Linux () en el directorio de Microsoft de la partición ESP de su disco duro (). Haga esto arrancando la shell EFI y escribiendo:
Shell> mkdir FS1:\EFI\Microsoft Shell> mkdir FS1:\EFI\Microsoft\Boot Shell> cp FS0:\EFI\BOOT\bootx64.efi FS1:\EFI\Microsoft\Boot\bootmgfw.efi
Después del reinicio, las entradas agregadas a la NVRAM deben aparecer en el menú de inicio.
Véase también
- Wikipedia:UEFI
- UEFI Forum - contains the official UEFI Specifications - GUID Partition Table is part of UEFI Specification
- UEFI boot: how does that actually work, then? - A blog post by AdamW
- Linux Kernel x86_64 UEFI Documentation
- Intel's page on EFI
- Intel Architecture Firmware Resource Center
- Matt Fleming - The Linux EFI Boot Stub
- Matt Fleming - Accessing UEFI Variables from Linux
- Rod Smith - Linux on UEFI: A Quick Installation Guide
- UEFI Boot problems on some newer machines (LKML)
- LPC 2012 Plumbing UEFI into Linux
- LPC 2012 UEFI Tutorial : part 1
- LPC 2012 UEFI Tutorial : part 2
- Intel's TianoCore Project for Open-Source UEFI firmware which includes DuetPkg for direct BIOS based booting and OvmfPkg used in QEMU and Oracle VirtualBox
- FGA: The EFI boot process[enlace roto 2022-09-23]
- Microsoft's Windows and GPT FAQ
- Convert Windows x64 from BIOS-MBR mode to UEFI-GPT mode without Reinstall
- Create a Linux BIOS+UEFI and Windows x64 BIOS+UEFI bootable USB drive
- Rod Smith - A BIOS to UEFI Transformation
- EFI Shells and Scripting - Intel Documentation
- UEFI Shell - Intel Documentation
- UEFI Shell - bcfg command info