Mục lục:
- Thuật ngữ
- Chuyển đổi
- Định cấu hình (+ Khởi động kép)
Thuật ngữ
BIOS = Hệ thống đầu vào / đầu ra cơ bản
(U) EFI = (Hợp nhất) Giao diện phần mềm mở rộng
MBR = Bản ghi khởi động chính
Bảng phân vùng GPT = GUID
UEFI / EFI / BIOS = Giao diện phần sụn
MBR / GPT = Làm thế nào máy tính biết (trên mỗi đĩa cứng) phân vùng nào trên ổ đĩa và cách khởi động từ chúng.
UEFI / BIOS
Một giao diện firmware là cách mà các firmware (phần mềm bên trong thiết bị) và hệ điều hành tương tác với nhau. Nó khởi chạy phần cứng sau đó chạy hệ điều hành và đảm bảo rằng trình điều khiển hệ điều hành có thể vận hành phần cứng.
BIOS là giao diện phần sụn thông thường đã được sử dụng. UEFI là một giao diện mới hơn có một số tính năng, chẳng hạn như nhanh hơn, có GUI và có thể khởi động card mạng và nhận địa chỉ IP. UEFI thay thế EFI. (Những người đang phát triển EFI thấy rằng có những người khác đang làm điều gì đó tương tự và vì vậy đã tham gia cùng họ, mang theo ý tưởng của EFI với họ. Điều này sau đó đã trở thành UEFI).
Một BIOS yêu cầu bộ tải khởi động phải ở đầu đĩa, tuy nhiên UEFI sử dụng phân vùng cho việc này và có thể chọn trong số nhiều bộ tải khởi động để sử dụng.
MBR / GPT + GRUB
Các MBR là một phần của mã vào đầu đĩa có chứa một bộ nạp khởi động (đối với BIOS), cũng như các bản đồ phân vùng và định danh đĩa độc đáo.
Để cài đặt GRUB vào đĩa có MBR, GRUB đặt một chương trình nhỏ trong MBR để tải phần còn lại của GRUB từ một phần khác của đĩa. (Điều này được thực hiện vì MBR quá nhỏ để chứa tất cả GRUB). Không gian được chọn là không gian giữa MBR và phân vùng đầu tiên, thường tồn tại.
GPT là một tiêu chuẩn cho cách thức các partitons được chỉ định. Nó có MBR 'bảo vệ', tuy nhiên điều này chỉ để cho phép các máy tính dựa trên BIOS khởi động và dừng các công cụ chỉ biết về MBR khi cố gắng dọn rác GPT. Nó có thể có
(Cách xử lý GPT tùy thuộc vào việc nó khởi động bằng BIOS (hay hệ thống UEFI ở chế độ mô phỏng BIOS) hay UEFI. Tôi sẽ tập trung vào UEFI vì nó liên quan đến câu hỏi).
Bộ tải khởi động cho các hệ điều hành được lưu trữ trong một phần gọi là EFI System Partiton, được định dạng (thường) với FAT32. Đây là nơi GRUB được cài đặt.
Chuyển đổi
Đầu tiên...
Chúng tôi đang chơi xung quanh với bảng phân vùng, vì vậy đảm bảo an toàn là không thể. Đó là một hoạt động rủi ro. Tuy nhiên, phương pháp không nên mất dữ liệu.
Những người khác gặp phải điều này: Không sử dụng trên Apple Mac.
Hiện nay...
Bạn sẽ cần phải làm điều này trên một đĩa CD trực tiếp (hoặc một bản cài đặt linux khác được cài đặt vào một đĩa khác.)
Khi xử lý các đĩa GPT, chúng ta cần sử dụng chương trình nhận biết GPT. 'GPT fdisk' là một công cụ tốt để sử dụng và những gì tôi sẽ sử dụng. Nó có thể được gọi gptfdisk
hoặc
gdisk
tùy thuộc vào phân phối (Ubuntu gọi nó gdisk
). Chia tay (và Gparted) cũng là nhận thức của GPT, vì vậy có thể 'an toàn' được sử dụng với các đĩa GPT.
Để chuyển đổi bạn cần:
- Thay đổi kích thước phân vùng để phù hợp với dữ liệu GPT và phân vùng hệ thống EFI.
- Chuyển đổi đĩa và thêm phân vùng
- Cài đặt GRUB vào phân vùng hệ thống EFI.
1) Thay đổi kích thước phân vùng
Sử dụng parted
(dòng lệnh) hoặc gparted
(GUI) để thay đổi kích thước phân vùng đầu tiên và cuối cùng. Phần đầu tiên nên có khoảng 200MiB trước nó và phân vùng cuối cùng sẽ có 1MiB đến 2MiB (một trong hai sẽ làm) được kết thúc.
2) Chuyển đổi đĩa
Chạy
gdisk /dev/sdx
thay đổi thiết bị bạn muốn chuyển đổi là /dev/sdx
.
Nó sẽ cho bạn biết rằng nó sẽ chuyển đổi bảng 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):
Bây giờ thêm một phân vùng mới, làm cho nó thuộc loại 'hệ thống EFI'. Nó sẽ tìm không gian trống ngay từ đầu (tôi đề xuất một số số ngành thấp như 34) và tự động sử dụng tất cả không gian trống. Các ví dụ sử dụng ổ flash USB 4GB với 1 phân vùng đã có trên đó, được thay đổi kích thước theo như trên.
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'
Bây giờ bạn sẽ có phân vùng 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
Sau đó thoát 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.
Bây giờ sử dụng Gparted (hoặc dòng lệnh mkfs.vfat
) để định dạng phân vùng là FAT32.
3) Cài đặt GRUB
Điều này đi kèm với ít sự đảm bảo rằng phần trước như tôi đã không tự mình thử nó.
Tôi không chắc chắn về bước này, vì vậy tôi sẽ đoán bằng cách sử dụng hướng dẫn của RAOF :
Để chuyển sang grub-efi bạn muốn
- Tìm phân vùng EFI của bạn; gắn kết nó trong / boot / efi. Thêm cái này vào / etc / fstab¹
- Cài đặt gói grub-efi
- Chuyển mức ưu tiên khởi động BIOS của bạn từ UEFI và Legacy sang UEFI (hoặc một tùy chọn tương tự)
Bạn nên tìm ra phiên bản grub-efi nào để cài đặt
ioreg -l -p IODeviceTree | grep firmware-abi
Nếu nó nói EFI32
cài đặt grub-efi-ia32
gói, nếu nó nói EFI64
cài đặt grub-efi-amd64
gói. Bạn có thể cài đặt các gói với
sudo apt-get install <package name>
Điều này có thể sẽ chỉ hoạt động nếu bạn đã khởi động ở chế độ EFI.
Nếu nó không hoạt động, bạn có thể thử các hướng dẫn từng bước này (trong phần "Cài đặt GRUB2 trong (U) hệ thống EFI") sau khi grub-efi
được cài đặt.
Định cấu hình (+ Khởi động kép)
Nếu hướng dẫn của RAOK hoạt động, bạn sẽ có thể thêm dòng sau vào
/etc/grub.d/40_custom
menuentry "Windows 7" {
set root='(hd0,gpt1)'
chainloader /EFI/microsoft/bootmgfw.efi
}
Nó giả định rằng Windows được hd0
GRUB công nhận . Nó có thể cần phải được thay đổi hd1
để làm việc.
Bây giờ chạy
update-grub
để cập nhật tập tin cấu hình.
Tài liệu tham khảo và đọc thêm
Tôi đã sử dụng một số nguồn.