Daftar Isi:
- Terminologi
- Konversi
- Mengkonfigurasi (+ Dual boot)
Terminologi
BIOS = Sistem Input / Output Dasar
(U) EFI = (Unified) Antarmuka Firmware yang Dapat Diperbesar
MBR = Master Boot Record
GPT = GUID Partition Table
UEFI / EFI / BIOS = Antarmuka firmware
MBR / GPT = Bagaimana komputer tahu (per hard disk) partisi apa yang ada di drive dan cara mem-boot darinya.
UEFI / BIOS
Sebuah antarmuka firmware adalah cara bahwa firmware (perangkat lunak dalam perangkat) dan sistem operasi berinteraksi. Ini menginisialisasi perangkat keras kemudian menjalankan sistem operasi dan memastikan bahwa driver sistem operasi dapat mengoperasikan perangkat keras.
BIOS telah menjadi antarmuka firmware yang biasa digunakan. UEFI adalah antarmuka yang lebih baru yang memiliki beberapa fitur, seperti menjadi lebih cepat, memiliki GUI dan dapat memulai kartu jaringan dan mendapatkan alamat ip. UEFI menggantikan EFI. (Mereka yang mengembangkan EFI melihat bahwa ada orang lain melakukan sesuatu yang serupa dan bergabung dengan mereka, membawa ide-ide EFI dengan mereka. Ini kemudian menjadi UEFI).
BIOS mengharuskan bootloader berada di awal disk, namun UEFI menggunakan partisi untuk ini dan dapat memilih di antara beberapa bootloader yang akan digunakan.
MBR / GPT + GRUB
The MBR adalah bagian kode pada awal disk yang berisi boot loader (untuk BIOS), serta peta partisi dan pengenal disk yang unik.
Untuk menginstal GRUB ke disk dengan MBR, GRUB menempatkan program kecil di MBR untuk memuat sisa GRUB dari bagian lain disk. (Ini dilakukan karena MBR terlalu kecil untuk menampung semua GRUB). Ruang yang dipilih adalah ruang antara MBR dan partisi pertama, yang biasanya ada.
GPT adalah standar untuk bagaimana partitons ditentukan. Memang memiliki MBR 'protektif', namun ini hanya untuk memungkinkan komputer berbasis BIOS untuk boot dan menghentikan alat yang hanya tahu tentang MBR dari mencoba untuk membuang GPT. Itu bisa
(Bagaimana GPT ditangani tergantung pada apakah itu boot menggunakan BIOS (atau sistem UEFI dalam mode emulasi BIOS) atau UEFI. Saya akan fokus pada UEFI karena berkaitan dengan pertanyaan).
Boot loader untuk sistem operasi disimpan dalam partion yang disebut EFI System Partiton, yang diformat (biasanya) dengan FAT32. Di sinilah GRUB diinstal.
Konversi
Pertama...
Kami bermain-main dengan tabel partisi, jadi jaminan keamanan tidak mungkin. Ini adalah operasi yang berisiko. Namun, metode ini tidak boleh kehilangan data.
Orang lain menemukan ini: Jangan gunakan di Apple Mac.
Sekarang...
Anda perlu melakukan ini pada live CD (atau instalasi linux lain yang diinstal ke disk lain.)
Saat berurusan dengan disk GPT, kita perlu menggunakan program yang sadar GPT. 'GPT fdisk' adalah alat yang baik untuk digunakan dan apa yang akan saya gunakan. Itu dapat dipanggil gptfdisk
atau
gdisk
tergantung pada distribusi (Ubuntu menyebutnya gdisk
). Parted (dan Gparted) juga sadar GPT, jadi 'aman' dapat digunakan dengan disk GPT.
Untuk mengkonversi Anda perlu:
- Ubah ukuran partisi agar sesuai dengan data GPT dan partisi sistem EFI.
- Konversikan disk dan tambahkan partisi
- Instal GRUB ke partisi sistem EFI.
1) Ubah ukuran partisi
Gunakan parted
(baris perintah) atau gparted
(GUI) untuk mengubah ukuran partisi pertama dan terakhir. Partisi pertama harus memiliki sekitar 200MiB sebelum itu, dan partisi terakhir harus memiliki 1MiB ke 2MiB (keduanya akan dilakukan) diambil dari akhirnya.
2) Konversi disk
Lari
gdisk /dev/sdx
mengubah perangkat yang ingin Anda konversi adalah /dev/sdx
.
Ini akan memberi tahu Anda bahwa itu akan mengonversi 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):
Sekarang tambahkan partisi baru, membuatnya dari jenis 'sistem EFI'. Seharusnya menemukan ruang kosong di awal (saya sarankan beberapa nomor sektor rendah seperti 34) dan secara otomatis menggunakan semua ruang kosong. Contoh-contoh menggunakan flash drive USB 4GB dengan 1 partisi sudah ada di sana, ukurannya seperti di atas.
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'
Anda sekarang harus memiliki partisi 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
Lalu keluar 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.
Sekarang gunakan Gparted (atau command-line mkfs.vfat
) untuk memformat partisi sebagai FAT32.
3) Instal GRUB
Ini datang dengan lebih sedikit jaminan bahwa bagian sebelumnya karena saya belum mencobanya sendiri.
Saya tidak yakin tentang langkah ini, jadi saya akan menebak menggunakan instruksi RAOF :
Untuk beralih ke grub-efi yang Anda inginkan
- Temukan partisi EFI Anda; pasang di / boot / efi. Tambahkan ini ke / etc / fstab¹
- Instal paket grub-efi
- Alihkan prioritas boot BIOS Anda dari UEFI dan Legacy ke UEFI saja (atau opsi serupa)
Anda harus menentukan versi grub-efi mana yang harus Anda instal
ioreg -l -p IODeviceTree | grep firmware-abi
Jika dikatakan EFI32
instal grub-efi-ia32
paket, jika dikatakan EFI64
instal grub-efi-amd64
paket. Anda dapat menginstal paket dengan
sudo apt-get install <package name>
Ini mungkin hanya akan berfungsi jika Anda mem-boot dalam mode EFI.
Jika tidak bekerja, Anda bisa mencoba ini petunjuk langkah demi langkah (di bawah "Instal grub2 di (sistem U) EFI") setelah grub-efi
diinstal.
Mengkonfigurasi (+ Dual Boot)
Jika instruksi RAOK berfungsi, Anda harus dapat menambahkan baris berikut
/etc/grub.d/40_custom
menuentry "Windows 7" {
set root='(hd0,gpt1)'
chainloader /EFI/microsoft/bootmgfw.efi
}
Diasumsikan bahwa Windows dikenali hd0
oleh GRUB. Mungkin perlu diubah hd1
agar bisa bekerja.
Sekarang jalankan
update-grub
untuk memperbarui file konfigurasi.
Referensi dan bacaan lebih lanjut
Saya menggunakan beberapa sumber.