Spis treści:
- Terminologia
- Konwersja
- Konfiguracja (+ Podwójny rozruch)
Terminologia
BIOS = Podstawowy system wejścia / wyjścia
(U) EFI = (Unified) Extensible Firmware Interface
MBR = główny rekord rozruchowy
GPT = Tabela partycji GUID
UEFI / EFI / BIOS = Interfejs oprogramowania wewnętrznego
MBR / GPT = Skąd komputer wie (na dysk twardy), jakie partycje znajdują się na dysku i jak się z nich uruchomić.
UEFI / BIOS
Firmware Interface to sposób, że firmware (oprogramowanie wewnątrz urządzenia) i system operacyjny interakcji. Inicjuje sprzęt, a następnie uruchamia system operacyjny i zapewnia, że sterowniki systemu operacyjnego mogą obsługiwać sprzęt.
BIOS był zwykłym interfejsem oprogramowania układowego, który został użyty. UEFI to nowszy interfejs, który ma kilka funkcji, takich jak szybsze działanie, posiadanie GUI oraz możliwość uruchomienia karty sieciowej i uzyskania adresu IP. UEFI zastępuje EFI. (Ci, którzy rozwijali EFI, zauważyli, że inni robili coś podobnego, więc dołączyli do nich, niosąc ze sobą pomysły EFI. To stało się wtedy UEFI).
BIOS wymaga, aby bootloader znajdował się na początku dysku, jednak UEFI używa do tego partycji i może wybierać spośród wielu programów ładujących.
MBR / GPT + GRUB
MBR jest fragment kodu na początku dysku, który zawiera program ładujący (dla BIOS), a także mapę partycji oraz unikalny identyfikator dysku.
Aby zainstalować GRUB na dysku z MBR, GRUB umieszcza mały program w MBR, aby załadować resztę GRUB z innej części dysku. (Dzieje się tak, ponieważ MBR jest zbyt mały, aby pomieścić cały GRUB). Wybrane miejsce to odstęp między MBR a pierwszą partycją, która zwykle istnieje.
GPT jest standardem określania partitonów. Ma „ochronny” MBR, ale służy to tylko do umożliwienia komputerom z systemem BIOS uruchamiania i zatrzymywania narzędzi, które wiedzą tylko o MBR przed próbą wyrzucenia GPT. Może mieć
(Sposób obsługi GPT zależy od tego, czy uruchamia się przy użyciu systemu BIOS (lub systemu UEFI w trybie emulacji BIOS), czy UEFI. Skoncentruję się na UEFI, ponieważ odnosi się do pytania).
Programy ładujące dla systemów operacyjnych są przechowywane w części o nazwie Partio systemu EFI, która jest sformatowana (zwykle) za pomocą FAT32. Tutaj instalowany jest GRUB.
Konwersja
Pierwszy...
Bawimy się tabelą partycji, więc zagwarantowane bezpieczeństwo nie jest możliwe. To ryzykowna operacja. Jednak metoda nie powinna tracić danych.
Inni spotykają się z tym: nie używaj na komputerach Apple Mac.
Teraz...
Musisz to zrobić na Live CD (lub innej instalacji Linuksa zainstalowanej na innym dysku).
W przypadku dysków GPT musimy używać programu obsługującego GPT. „GPT fdisk” to dobre narzędzie do użycia i tego, czego będę używać. Można go wywołać gptfdisk
lub w
gdisk
zależności od dystrybucji (Ubuntu nazywa to gdisk
). Parted (i Gparted) jest również świadomy GPT, więc można go bezpiecznie używać z dyskami GPT.
Aby dokonać konwersji, musisz:
- Zmień rozmiar partycji, aby dopasować dane GPT i partycję systemową EFI.
- Konwertuj dysk i dodaj partycje
- Zainstaluj GRUB na partycji systemowej EFI.
1) Zmień rozmiar partycji
Użyj parted
(wiersza polecenia) lub gparted
(GUI), aby zmienić rozmiar pierwszej i ostatniej partycji. Pierwsza partycja powinna mieć około 200 MB przed nią, a ostatnia partycja powinna mieć od 1 MB do 2 MB (każda z nich zrobi) zdjęta z końca.
2) Konwertuj dysk
Biegać
gdisk /dev/sdx
zmienia się urządzenie, które chcesz przekonwertować /dev/sdx
.
Powinien ci powiedzieć, że przekształci tabelę partiton.
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):
Teraz dodaj nową partycję, czyniąc ją typu „system EFI”. Powinien znaleźć wolne miejsce na początku (sugeruję niski numer sektora, np. 34) i automatycznie wykorzystać całe wolne miejsce. W przykładach wykorzystano dysk flash USB o pojemności 4 GB z już zainstalowaną 1 partycją, o zmienionym rozmiarze zgodnie z powyższym opisem.
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'
Powinieneś teraz mieć partycję 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
Następnie wyjdź 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.
Teraz użyj Gparted (lub wiersza polecenia mkfs.vfat
), aby sformatować partycję jako FAT32.
3) Zainstaluj GRUB
Daje to mniej pewności, że poprzednia część, ponieważ sam tego nie próbowałem.
Nie jestem pewien co do tego kroku, więc zgaduję, używając instrukcji RAOF :
Aby przełączyć się na grub-efi, chcesz
- Znajdź swoją partycję EFI; zamontuj go w / boot / efi. Dodaj to do / etc / fstab¹
- Zainstaluj pakiet grub-efi
- Zmień priorytet rozruchu systemu BIOS z UEFI i Legacy tylko na UEFI (lub podobną opcję)
Powinieneś dowiedzieć się, z którą wersją grub-efi zainstalować
ioreg -l -p IODeviceTree | grep firmware-abi
Jeśli mówi, EFI32
zainstaluj grub-efi-ia32
pakiet, jeśli mówi, EFI64
zainstaluj grub-efi-amd64
pakiet. Możesz zainstalować pakiety za pomocą
sudo apt-get install <package name>
Prawdopodobnie zadziała to tylko wtedy, gdy uruchomiłeś system w trybie EFI.
Jeśli to nie działa, możesz wypróbować te instrukcje krok po kroku (w sekcji „Zainstaluj GRUB2 w systemach (U) EFI”) po grub-efi
zainstalowaniu.
Konfiguracja (+ Dual Boot)
Jeśli instrukcje RAOK działają, powinieneś być w stanie dodać następujący wiersz
/etc/grub.d/40_custom
menuentry "Windows 7" {
set root='(hd0,gpt1)'
chainloader /EFI/microsoft/bootmgfw.efi
}
Zakłada się, że system Windows jest rozpoznawany hd0
przez GRUB. Może wymagać zmiany na hd1
, aby działał.
Teraz biegnij
update-grub
zaktualizować plik konfiguracyjny.
Referencje i dalsze czytanie
Użyłem kilku źródeł.