Saltar al contenido

¿Cómo puedo cambiar / convertir una unidad MBR de Ubuntu a GPT y hacer que Ubuntu arranque desde EFI?

Buscamos en todo el mundo online para así tenerte la solución para tu problema, si continúas con inquietudes deja un comentario y te contestamos porque estamos para servirte.

Solución:

Tabla de contenido:

  1. Terminología
  2. Mudado
  3. Configuración (+ arranque dual)

Terminología

BIOS = Sistema básico de entrada / salida

(U) EFI = Interfaz de firmware extensible (unificada)

MBR = Registro de arranque maestro

GPT = Tabla de particiones GUID

UEFI / EFI / BIOS = Interfaz de firmware

MBR / GPT = Cómo sabe la computadora (por disco duro) qué particiones hay en la unidad y cómo arrancar desde ellas.

UEFI / BIOS

A 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. 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. (Aquellos que estaban desarrollando EFI vieron que había otros haciendo algo similar y se unieron a ellos, trayendo las ideas de EFI con ellos. Esto luego 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 varios cargadores de arranque para usar.

MBR / GPT + GRUB

los MBR es una sección de código al inicio del disco que contiene un cargador de arranque (para el BIOS), así como el mapa de particiones 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 suele existir.

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 se inicien y eviten que las herramientas que solo conocen MBR intenten eliminar 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 debería 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, debemos utilizar 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 utilizar de forma ‘segura’ con discos GPT.

Para convertir necesitas:

  1. Cambie el tamaño de las particiones para que se ajusten a los datos GPT y la partición del sistema EFI.
  2. Convierta el disco y agregue particiones
  3. Instale GRUB en la partición del sistema EFI.

1) Cambiar el tamaño de la partición

Usar parted (línea de comando) o gparted (GUI) para cambiar el tamaño de la primera y última partición. La primera partición debe tener alrededor de 200MiB antes, y la última partición debe tener de 1MiB a 2MiB (cualquiera de las dos funcionará) al final.

2) Convierte el disco

Correr

gdisk /dev/sdx

cambiar el dispositivo que desea 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 usan una unidad flash USB de 4GB con 1 partición ya instalada, redimensionada como se indicó anteriormente.

Command (? for help): n
Partition number (2-128, default 2): 2
First sector (34-7831518, default = 34) or +-sizeKMGTP: 
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 +-sizeKMGTP: 
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

Entonces sal 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 -F 32 /dev/partition) para formatear la partición como FAT32.

3) Instale GRUB

Esto viene con menos garantías que la parte anterior, ya que no lo he probado yo mismo.

No estoy seguro de este paso, así que supongo que usando las instrucciones de RAOF:

Para cambiar a grub-efi, querrás

  1. Encuentre su partición EFI; móntelo en / boot / efi. Agregue esto a / etc / fstab¹
  2. Instale el paquete grub-efi
  3. Cambie la prioridad de arranque de su BIOS de UEFI y Legacy a UEFI solamente (o una opción similar)

Debe averiguar qué versión de grub-efi instalar con

ioreg -l -p IODeviceTree | grep firmware-abi

Si dice EFI32 Instala el grub-efi-ia32 paquete, si dice EFI64
Instala el grub-efi-amd64 paquete. Puede instalar los paquetes con

sudo apt-get install 

Esto probablemente solo funcionará si ha iniciado en modo EFI.

Si no funciona, puede probar estas instrucciones paso a paso (en “Instalar GRUB2 en sistemas (U) EFI”) una vez grub-efi esta 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

Asume que Windows se reconoce como hd0 por GRUB. Es posible que deba cambiarse a hd1 para que funcione.

Ahora corre

update-grub

para actualizar el archivo de configuración.

Referencias y lecturas adicionales

Usé varias fuentes.

  • “Tutorial de fdisk GPT” de Rod Smith. Bueno para más información.
  • Páginas de Wikipedia para UEFI, BIOS, MBR y GPT.
  • Página wiki de arranque UEFI de Ubuntu. Bueno para más instrucciones si te quedas atascado.
  • Página de información de UEFI.

Esta respuesta está incompleta; No he probado nada de esto. Es poco probable que se coma alguno de sus datos, ¡pero ha sido advertido!

Lo que supongo que está sucediendo aquí es que su BIOS se inicia preferentemente desde MBR heredado, por lo que el viejo UEFI Windows 7 se pasa por alto.

Una de las cosas buenas de UEFI es que ya no debería tener que preocuparse de que Windows sobrescriba GRUB; ambos deberían coexistir muy bien en la partición EFI. Por tanto, una opción sería cambiar a grub-efi. Nota: No estoy seguro de si grub-efi entiende las particiones estilo MSDOS; I pensar lo hace. Si no es así, no se iniciará y necesitará un LiveCD para recuperarse. De hecho, ¡tenga un LiveCD a mano de todos modos!

Para cambiar a grub-efi te gustaría

  1. Encuentre su partición EFI; montarlo en /boot/efi. Agregar esto a /etc/fstab¹
  2. Instala el grub-efi paquete
  3. Cambie la prioridad de arranque de su BIOS de UEFI and Legacy para UEFI only (o una opción similar)

Ese deberían lo dejo con una instalación de Ubuntu con arranque UEFI. Si no es así, inicie su LiveCD de confianza (o el CD de instalación alternativo de Ubuntu; la opción “Reparar un sistema roto” es lo que busca ☺), haga un chroot en su sistema e instale grub-pc de nuevo.


¹: Más detalles para este paso: necesitará encontrar lo que el kernel de Linux llama la partición del sistema EFI. Esto será algo como /dev/sda2, /dev/sdb3, o tal². Entonces necesitarás hacer el /boot/efi directorio, y agregue una línea a /etc/fstab. Si su partición EFI es /dev/sdb3, luego agregaría la siguiente línea:

/dev/sdb3    /boot/efi    vfat    defaults    0    1

Una vez que corres sudo mount /boot/efi entonces deberías encontrar eso /boot/efi contiene una EFI directorio, con un subdirectorio para Windows 7.


²: Dado que tiene varios discos duros, podría ser una buena idea averiguar el UUID de la partición, ya que se mantendrá estable al agregar / quitar discos duros, mientras que el /dev/sda2 no se garantiza que el nombre no cambie. Sin embargo, esto se puede hacer después de que haya terminado de configurar todo lo demás.

Puede encontrar el UUID mirando en /dev/disk/by-uuid. Por ejemplo, obtengo:

$ ls /dev/disk/by-uuid -lah
total 0
drwxr-xr-x 2 root root 100 Dec  5 09:12 .
drwxr-xr-x 6 root root 120 Dec  5 09:12 ..
lrwxrwxrwx 1 root root  10 Dec  5 09:12 27fae347-4c7f-45cb-92d6-5f3d410599a1 -> ../../sda3
lrwxrwxrwx 1 root root  10 Dec  5 09:12 4405-64C8 -> ../../sda1
lrwxrwxrwx 1 root root  10 Dec  5 09:12 5243e250-8da5-4fea-aa63-61466022661d -> ../../dm-0

En mi caso lo se /dev/sda1 es mi partición del sistema EFI, así que tengo

UUID=4405-64C8  /boot/efi       vfat    defaults        0       1

en mi /etc/fstab.

Tengo mis sistemas operativos en unidades separadas, por lo que GRUB2 no será reemplazado por el cargador de arranque de Windows y viceversa

Eso es ideal, por lo que es probable que tenga al menos una partición primaria libre en la tabla de particiones.

Ahora mi pregunta es, ¿cómo puedo cambiar / convertir la unidad de Ubuntu para que en lugar de usar MBR use GPT y permita que Windows arranque?

No tiene que convertir MBR a GPT para realizar el arranque UEFI, simplemente cree una partición FAT primaria, instale el grub-efi-amd64-bin paquete y siga las instrucciones en Agregar un ESP a una instalación existente con MBR que debería funcionar con las versiones actuales de Ubuntu.

Si te apasiona este mundo, tienes el poder dejar un ensayo acerca de qué te ha impresionado de este artículo.

¡Haz clic para puntuar esta entrada!
(Votos: 0 Promedio: 0)



Utiliza Nuestro Buscador

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *