Содержание:
- терминология
- преобразование
- Конфигурирование (+ Двойная загрузка)
терминология
BIOS = базовая система ввода / вывода
(U) EFI = (унифицированный) расширяемый интерфейс встроенного ПО
MBR = основная загрузочная запись
GPT = таблица разделов GUID
UEFI / EFI / BIOS = интерфейс прошивки
MBR / GPT = Как компьютер знает (на жесткий диск), какие разделы находятся на диске и как с них загружаться.
UEFI / BIOS
Интерфейс прошивки является способом , что встроенное программное обеспечение (программное обеспечение внутри устройств) и операционной системы взаимодействуют между собой . Он инициализирует оборудование, затем запускает операционную систему и гарантирует, что драйверы операционной системы могут работать с оборудованием.
BIOS был обычным интерфейсом прошивки, который был использован. UEFI является более новым интерфейсом, который имеет несколько функций, таких как быстрая работа, наличие графического интерфейса пользователя и возможность запуска сетевой карты и получения IP-адреса. UEFI заменяет EFI. (Те, кто разрабатывал EFI, увидели, что другие делают что-то подобное, и присоединились к ним, привнося с собой идеи EFI. Затем это стало UEFI).
BIOS требует, чтобы загрузчик находился в начале диска, однако UEFI использует для этого раздел и может выбирать между несколькими загрузчиками.
MBR / GPT + GRUB
MBR представляет собой часть кода в начале диска , который содержит загрузчик (для BIOS), а также карту разделов и уникальный идентификатор диска.
Чтобы установить GRUB на диск с MBR, GRUB помещает небольшую программу в MBR для загрузки остальной части GRUB из другой части диска. (Это сделано потому, что MBR слишком мала, чтобы содержать весь GRUB). Выбранный пробел - это пробел между MBR и первым разделом, который обычно существует.
GPT - это стандарт определения разделов. Он имеет «защитную» MBR, однако это только для того, чтобы позволить компьютерам на базе BIOS загружать и останавливать инструменты, которые знают только о MBR, от попыток уничтожить GPT. Может иметь
(То, как обрабатывается GPT, зависит от того, загружается ли он с использованием BIOS (или системы UEFI в режиме эмуляции BIOS) или UEFI. Я остановлюсь на UEFI, поскольку это относится к вопросу).
Загрузчики для операционных систем хранятся в разделе под названием EFI System Partiton, который отформатирован (обычно) в FAT32. Это где GRUB установлен.
преобразование
Первый...
Мы играем с таблицей разделов, поэтому гарантированная безопасность невозможна. Это рискованная операция. Однако метод не должен терять данные.
Другие сталкиваются с этим: не используйте на Apple Mac.
В настоящее время...
Вам нужно будет сделать это на live CD (или на другой инсталляции linux, установленной на другой диск).
При работе с GPT-дисками нам нужно использовать программу, поддерживающую GPT. «GPT fdisk» - это хороший инструмент, который я буду использовать. Он может быть вызван gptfdisk
или в
gdisk
зависимости от дистрибутива (Ubuntu называет его gdisk
). Parted (и Gparted) также поддерживает GPT, поэтому его можно безопасно использовать с GPT-дисками.
Для конвертации вам необходимо:
- Изменение размера разделов в соответствии с данными GPT и системного раздела EFI.
- Конвертировать диск и добавить разделы
- Установите GRUB в системный раздел EFI.
1) Изменить размер раздела
Используйте parted
(командную строку) или gparted
(GUI), чтобы изменить размер первого и последнего раздела. Первый раздел должен иметь около 200 МБ до него, а последний раздел должен иметь от 1 МБ до 2 МБ (любой будет), снятый с конца.
2) Конвертировать диск
Бегать
gdisk /dev/sdx
изменить устройство, которое вы хотите конвертировать /dev/sdx
.
Он должен сказать вам, что он преобразует таблицу разделов.
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):
Теперь добавьте новый раздел, сделав его типа «система EFI». Он должен найти свободное место в начале (я предлагаю небольшое число секторов, например, 34) и автоматически использовать все свободное пространство. В примерах используется флэш-накопитель USB объемом 4 ГБ, на котором уже есть 1 раздел, с измененным размером, как указано выше.
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'
Теперь у вас должен быть раздел 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
Затем выход 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.
Теперь используйте Gparted (или командную строку mkfs.vfat
) для форматирования раздела как FAT32.
3) Установить GRUB
Это приходит с меньшими гарантиями, что предыдущая часть, поскольку я не пробовал это сам.
Я не уверен в этом шаге, поэтому я угадаю, используя инструкции RAOF :
Чтобы перейти на Grub-EFI, вы бы хотели
- Найдите свой раздел EFI; смонтировать его в / boot / efi. Добавьте это в / etc / fstab¹
- Установите пакет grub-efi
- Переключите приоритет загрузки BIOS с UEFI и Legacy только на UEFI (или аналогичный вариант)
Вы должны решить, какую версию grub-efi установить с
ioreg -l -p IODeviceTree | grep firmware-abi
Если он говорит EFI32
установить grub-efi-ia32
пакет, если он говорит EFI64
установить grub-efi-amd64
пакет. Вы можете установить пакеты с
sudo apt-get install <package name>
Это, вероятно, будет работать, только если вы загрузились в режиме EFI.
Если это не работает, вы можете попробовать эти пошаговые инструкции (в разделе «Установка GRUB2 в (U) EFI-системах») после grub-efi
установки.
Конфигурирование (+ Двойная загрузка)
Если инструкции РАОК работают, вы сможете добавить следующую строку в
/etc/grub.d/40_custom
menuentry "Windows 7" {
set root='(hd0,gpt1)'
chainloader /EFI/microsoft/bootmgfw.efi
}
Предполагается, что Windows распознается как hd0
GRUB. Может потребоваться изменить hd1
, чтобы работать.
Теперь беги
update-grub
обновить файл конфигурации.
Ссылки и дальнейшее чтение
Я использовал несколько источников.