Tabla de contenido:
- Terminología
- Mudado
- Configuración (+ arranque dual)
Terminología
BIOS = Sistema básico de entrada / salida
(U) EFI = (Unificado) Interfaz de firmware extensible
MBR = Registro de arranque maestro
GPT = Tabla de particiones GUID
UEFI / EFI / BIOS = interfaz de firmware
MBR / GPT = Cómo la computadora sabe (por disco duro) qué particiones hay en el disco y cómo arrancar desde ellas.
UEFI / BIOS
Una interfaz de firmware es la forma en que interactúan el firmware (el software dentro de los dispositivos) y el sistema operativo. Inicializa el hardware, luego ejecuta el sistema operativo y garantiza que los controladores del sistema operativo puedan operar el hardware.
El BIOS ha sido la interfaz de firmware habitual que se ha utilizado. La UEFI es una interfaz más nueva que tiene varias características, como ser más rápida, tener una GUI y poder iniciar la tarjeta de red y obtener una dirección IP. UEFI reemplaza a EFI. (Los que desarrollaron EFI vieron que había otros haciendo algo similar y se unieron a ellos, trayendo las ideas de EFI con ellos. Esto se convirtió en UEFI).
Un BIOS requiere que el cargador de arranque esté al inicio del disco, sin embargo, un UEFI usa una partición para esto y puede elegir entre múltiples cargadores de arranque para usar.
MBR / GPT + GRUB
El MBR es una sección de código al comienzo del disco que contiene un cargador de arranque (para el BIOS), así como el mapa de partición y un identificador de disco único.
Para instalar GRUB en un disco con un MBR, GRUB coloca un pequeño programa en el MBR para cargar el resto de GRUB desde otra parte del disco. (Esto se hace porque el MBR es demasiado pequeño para contener todo GRUB). El espacio que se elige es el espacio entre el MBR y la primera partición, que generalmente existe.
GPT es un estándar sobre cómo se especifican las particiones. Tiene un MBR 'protector', sin embargo, esto es solo para permitir que las computadoras basadas en BIOS arranquen y detengan herramientas que solo saben acerca de MBR al intentar destruir la GPT. Puede tener
(La forma en que se maneja GPT depende de si se está iniciando utilizando un BIOS (o un sistema UEFI en modo de emulación de BIOS) o UEFI. Me centraré en UEFI en lo que respecta a la pregunta).
Los cargadores de arranque para sistemas operativos se almacenan en una partición llamada EFI System Partiton, que está formateada (generalmente) con FAT32. Aquí es donde está instalado GRUB.
Mudado
Primero...
Estamos jugando con la mesa de partición, por lo que la seguridad garantizada no es posible. Es una operación arriesgada. Sin embargo, el método no debe perder datos.
Otros se encuentran con esto: no lo use en Apple Macs.
Ahora...
Deberá hacer esto en un CD en vivo (u otra instalación de Linux instalada en un disco diferente).
Cuando se trata de discos GPT, necesitamos usar un programa compatible con GPT. 'GPT fdisk' es una buena herramienta para usar y lo que usaré. Se puede llamar gptfdisk
o
gdisk
dependiendo de la distribución (Ubuntu lo llama gdisk
). Parted (y Gparted) también es compatible con GPT, por lo que se puede usar de forma 'segura' con discos GPT.
Para convertir necesitas:
- Cambie el tamaño de las particiones para que se ajusten a los datos GPT y a la partición del sistema EFI.
- Convierte el disco y agrega particiones
- Instale GRUB en la partición del sistema EFI.
1) Cambiar el tamaño de la partición
Use parted
(línea de comando) o gparted
(GUI) para cambiar el tamaño de la primera y la última partición. La primera partición debe tener aproximadamente 200MiB antes que ella, y la última partición debe tener 1MiB a 2MiB (cualquiera de las dos tendrá) al final.
2) Convertir el disco
correr
gdisk /dev/sdx
cambiar el dispositivo que quieres convertir es /dev/sdx
.
Debería decirle que convertirá la tabla de partición.
GPT fdisk (gdisk) version 0.6.14
Partition table scan:
MBR: MBR only
BSD: not present
APM: not present
GPT: not present
***************************************************************
Found invalid GPT and valid MBR; converting MBR to GPT format.
THIS OPERATION IS POTENTIALLY DESTRUCTIVE! Exit by typing 'q' if
you don't want to convert your MBR partitions to GPT format!
***************************************************************
Command (? for help):
Ahora agregue una nueva partición, haciéndola del tipo 'sistema EFI'. Debería encontrar el espacio libre al principio (sugiero un número de sector bajo como 34) y usar automáticamente todo el espacio libre. Los ejemplos utilizan una unidad flash USB de 4 GB con 1 partición ya allí, redimensionada según lo anterior.
Command (? for help): n
Partition number (2-128, default 2): 2
First sector (34-7831518, default = 34) or {+-}size{KMGTP}:
Information: Moved requested sector from 34 to 2048 in
order to align on 2048-sector boundaries.
Use 'l' on the experts' menu to adjust alignment
Last sector (2048-421887, default = 421887) or {+-}size{KMGTP}:
Current type is 'Linux/Windows data'
Hex code or GUID (L to show codes, Enter = 0700): L
0700 Linux/Windows data 0c01 Microsoft reserved 2700 Windows RE
4200 Windows LDM data 4201 Windows LDM metadata 7501 IBM GPFS
7f00 ChromeOS kernel 7f01 ChromeOS root 7f02 ChromeOS reserved
8200 Linux swap 8301 Linux reserved 8e00 Linux LVM
a500 FreeBSD disklabel a501 FreeBSD boot a502 FreeBSD swap
a503 FreeBSD UFS a504 FreeBSD ZFS a505 FreeBSD Vinum/RAID
a800 Apple UFS a901 NetBSD swap a902 NetBSD FFS
a903 NetBSD LFS a904 NetBSD concatenated a905 NetBSD encrypted
a906 NetBSD RAID ab00 Apple boot af00 Apple HFS/HFS+
af01 Apple RAID af02 Apple RAID offline af03 Apple label
af04 AppleTV recovery be00 Solaris boot bf00 Solaris root
bf01 Solaris /usr & Mac Z bf02 Solaris swap bf03 Solaris backup
bf04 Solaris /var bf05 Solaris /home bf06 Solaris alternate se
bf07 Solaris Reserved 1 bf08 Solaris Reserved 2 bf09 Solaris Reserved 3
bf0a Solaris Reserved 4 bf0b Solaris Reserved 5 c001 HP-UX data
c002 HP-UX service ef00 EFI System ef01 MBR partition scheme
ef02 BIOS boot partition fd00 Linux RAID
Hex code or GUID (L to show codes, Enter = 0700): ef00
Changed type of partition to 'EFI System'
Ahora debería tener la partición EFI.
Command (? for help): p
Disk /dev/sdd: 7831552 sectors, 3.7 GiB
Logical sector size: 512 bytes
Disk identifier (GUID): 669247F2-37F7-4797-98F9-9CE56F7EA8C8
Partition table holds up to 128 entries
First usable sector is 34, last usable sector is 7831518
Partitions will be aligned on 2048-sector boundaries
Total free space is 4029 sectors (2.0 MiB)
Number Start (sector) End (sector) Size Code Name
1 421888 7829503 3.5 GiB 0700 Linux/Windows data
2 2048 421887 205.0 MiB EF00 EFI System
Luego salga gdisk
Command (? for help): w
Final checks complete. About to write GPT data. THIS WILL OVERWRITE EXISTING
PARTITIONS!!
Do you want to proceed, possibly destroying your data? (Y/N): y
OK; writing new GUID partition table (GPT).
The operation has completed successfully.
Ahora use Gparted (o línea de comandos mkfs.vfat
) para formatear la partición como FAT32.
3) Instalar GRUB
Esto viene con menos garantías de que la parte anterior ya que no lo he probado yo mismo.
No estoy seguro de este paso, así que supongo que usaré las instrucciones de RAOF :
Para cambiar a grub-efi, querrás
- Encuentra tu partición EFI; móntelo en / boot / efi. Agregue esto a / etc / fstab¹
- Instale el paquete grub-efi
- Cambie la prioridad de arranque de su BIOS de UEFI y Legacy a UEFI solamente (o una opción similar)
Debe averiguar con qué versión de grub-efi instalar
ioreg -l -p IODeviceTree | grep firmware-abi
Si dice EFI32
instalar el grub-efi-ia32
paquete, si dice EFI64
instalar el grub-efi-amd64
paquete. Puedes instalar los paquetes con
sudo apt-get install <package name>
Esto probablemente solo funcionará si ha arrancado en modo EFI.
Si no funciona, puede probar estas instrucciones paso a paso (en "Instalar GRUB2 en sistemas (U) EFI") una vez que grub-efi
esté instalado.
Configuración (+ arranque dual)
Si las instrucciones de RAOK funcionan, debería poder agregar la siguiente línea a
/etc/grub.d/40_custom
menuentry "Windows 7" {
set root='(hd0,gpt1)'
chainloader /EFI/microsoft/bootmgfw.efi
}
Se supone que Windows es reconocido hd0
por GRUB. Es posible que deba cambiarse para hd1
que funcione.
Ahora corre
update-grub
para actualizar el archivo de configuración.
Referencias y lecturas adicionales
Usé varias fuentes.