- PVSM.RU - https://www.pvsm.ru -
Достаточно много было шумихи по поводу того, что из-за нового чипа T2 невозможно установить linux на новые MacBook 2018 года с тачбаром. Шло время, и под конец 2019 года стронними разработчиками был реализован ряд драйверов и патчей ядра для взаимодействия с чипом T2. Основной драйвер для MacBook моделей 2018 и новее реализует работу VHCI (работа тача/клавиатуры/и.т.д.), а также функционирование звука.
Проект mbp2018-bridge-drv [1] разделен на 3 основных компонента:
Второй проект называется macbook12-spi-driver [2], и он реализует возможность работы драйвера ввода для клавиатуры, трекпада SPI, тачбара для MacBook Pro конца 2016 г. и более поздних версий. Часть драйверов для клавиатуры/трекпада теперь включена в ядро, начиная с версии 5.3.
Также была реализована поддержка таких устройств, как wi-fi, тачпад, etc, с помощью патчей ядра. На текущий момент версия ядра 5.3.5-1 [3]
Данный туториал применим для macbookpro15,1 и macbookpro15,2. За основу была взята статья с гитхаба на английском отсюда [4]. Не все из этой статьи заработало, поэтому пришлось искать решение самостоятельно.
https://support.apple.com/en-us/HT208330 [5]
https://www.ninjastik.com/support/2018-macbook-pro-boot-from-usb/ [6]
Для удобства я сразу выделил 30Гб на диск, отформатировав его в exfat в самом Disk Utility. Разбиение физического диска на разделы Disk Utility [7].
Варианты:
Устанавливаем archiso [9]
pacman -S archiso
cp -r /usr/share/archiso/configs/releng/ archlive
cd archlive
Добавляем репозиторий в pacman.conf:
[mbp]
Server = https://packages.aunali1.com/archlinux/$repo/$arch
Игнорируем оригинальное ядро в pacman.conf:
IgnorePkg = linux linux-headers
Добавляем необходимые пакеты, в конце добавляем ядро linux-mbp и linux-mbp-headers
...
wvdial
xl2tpd
linux-mbp
linux-mbp-headers
Изменяем скрипт для работы в интерактивном режиме (заменяем pacstrap -C на pacstrap -i -C):
sudo nano /usr/bin/mkarchiso
# Install desired packages to airootfs
_pacman ()
{
_msg_info "Installing packages to '${work_dir}/airootfs/'..."
if [[ "${quiet}" = "y" ]]; then
pacstrap -i -C "${pacman_conf}" -c -G -M "${work_dir}/airootfs" $* &> /dev/null
else
pacstrap -i -C "${pacman_conf}" -c -G -M "${work_dir}/airootfs" $*
fi
_msg_info "Packages installed successfully!"
}
Формируем образ:
sudo ./build.sh -v
Нажимаем Y, чтобы пропустить игнорируемые пакеты, затем пишем iso-образ на usb флешку:
sudo dd if=out/archlinux*.iso of=/dev/sdb bs=1M
Перезагружаемся с вставленной флешкой и клавиатурой. Нажимаем options при появлении яблока, выбираем EFI BOOT.
Далее необходимо нажать клавишу «e» и вписать в конец командной строки module_blacklist=thunderbolt. Если этого не сделать, то система может не загрузиться, и вылетит ошибка Thunderbolt ICM Error.
С помощью fdisk/cfdisk находим наш раздел (у меня это nvme0n1p4), форматируем и производим установку арча. Можно воспользоваться официальной инструкцией [10] или строронней [11].
Загрузочный раздел не создаем, загрузчик будем писать в /dev/nvme0n1p1
После того, как полностью сформировано окружение в /mnt и перед тем, как перейти в arch-chroot, пишем:
mount /dev/nvme0n1p1 /mnt/boot
arch-chroot /mnt /bin/bash
Добавляем в /etc/pacman.conf:
[mbp]
Server = https://packages.aunali1.com/archlinux/$repo/$arch
Устанавливаем ядро:
sudo pacman -S linux-mbp linux-mbp-headers
sudo mkinitcpio -p linux-mbp
Прописываем thunderbolt и applesmc в /etc/modprobe.d/blacklist.conf
blacklist thunderbolt
blacklist applesmc
Устанавливаем yay:
sudo pacman -S git gcc make fakeroot binutils
git clone https://aur.archlinux.org/yay.git
cd yay
makepkg -si
Устанавливаем модули для работы тачбара:
git clone --branch mbp15 https://github.com/roadrunner2/macbook12-spi-driver.git
cd macbook12-spi-driver
make install
Добавляем модули в автозагрузку: /etc/modules-load.d/apple.conf
industrialio_triggered_buffer
apple-ibridge
apple-ib-tb
apple-ib-als
Устанавливаем модули ядра для работы клавиатуры. В репозитории anuali1 [3] есть готовый пакет, он называется apple-bce-dkms-git. Чтобы его установить, пишем в консоли:
pacman -S apple-bce-dkms-git
В этом случае модуль ядра будет называться apple-bce. В случае самостоятельной сборки он называется bce. Соответственно, если вы хотите прописать модуль в раздел MODULES в файл mkinicpio.conf, то не забудьте, какой модуль вы устанавливали.
Сборка вручную:
git clone https://github.com/MCMrARM/mbp2018-bridge-drv.git
cd mbp2018-bridge-drv
make
cp bce.ko /usr/lib/modules/extramodules-mbp/bce.ko
Добавляем модуль bce или apple-bce в автозагрузку: /etc/modules-load.d/bce.conf
bce
Если хотите использовать по умолчанию кнопки Fn, то в файл /etc/modprobe.d/apple-tb.conf пишем:
options apple-ib-tb fnmode=2
Обновляем ядро и initramfs.
mkinitcpio -p linux-mbp
Установим iwd:
sudo pacman -S networkmanager iwd
После того, как внутри chroot все основные пакеты установлены, можно приступать к установке загрузчика.
Мне так и не удалось заставить работать grub. С внешнего usb-диска grub загружается, но при попытке прописать его в nvme через
grub-install --target=x86_64-efi --efi-directory=/boot --bootloader-id=grub
система улетала в kernel panic, и после перезагрузки нового пункта через options не появлялось. Какого-то внятного решения данной проблемы я не нашел и поэтому решил попробовать реализовать загрузку с помощью systemd-boot.
bootctl --path=/boot install
и улетаем в kernel panic. Выключаем MacBook, включаем заново, жмем options (usb-c хаб с клавиатурой не отключаем)
mount /dev/nvme0n1p4 /mnt
mount /dev/nvme0n1p1 /mnt/boot
arch-chroot /mnt
Если необходимо, чтобы клавиатура работала до полной загрузки системы (это необходимо в случае использования шифрования luks/dm-crypt) то прописываем в файл /etc/mkinicpio.conf в разделе MODULES:
MODULES=(ext4 applespi intel_lpss_pci spi_pxa2xx_platform bce)
Обновляем ядро и initramfs.
mkinicpio -p linux-mbp
Редактируем файл /boot/loader/loader.conf, удаляем все, что там внутри, и вносим следующее:
default arch
timeout 5
editor 1
Переходим в папку /boot/loader/entries, создаем файл arch.conf и пишем:
title arch
linux /vmlinuz-linux-mbp
initrd /initramfs-linux-mbp.img
options root=/dev/<b>nvme0n1p4</b> rw pcie_ports=compat
В случае, если использовали luks и lvm, то
options cryptdevice=/dev/<b>nvme0n1p4</b>:luks root=/dev/mapper/vz0-root rw pcie_ports=compat
Перезагружаемся в MacOS.
Как в итоге выяснилось, файлы прошивок для wi-fi адаптера MacOS хранит в папке /usr/share/firmware/wifi , и можно их от туда взять в виде блобов и скормить модулю ядра brcmfmac. Для того, чтобы выяснить, какие именно файлы использует ваш адаптер, открываем терминал в MacOS и пишем:
ioreg -l | grep C-4364
Получаем длинный список. Нам нужны файлы только из раздела RequestedFiles:
"RequestedFiles" = ({"Firmware"="<b>C-4364__s-B2/maui.trx</b>","TxCap"="C-4364__s-B2/maui-X3.txcb","Regulatory"="C-4364__s-B2/<b>maui-X3.clmb</b>","NVRAM"="C-4364__s-B2/<b>P-maui-X3_M-HRPN_V-m__m-7.7.txt</b>"})
В вашем случае названия файлов могут отличаться. Копируем их из папки /usr/share/firmware/wifi на флешку и переименовываем в следующий вид:
maui.trx -> brcmfmac4364-pcie.bin
maui-X3.clmb -> brcmfmac4364-pcie.clm_blob
P-maui-X3_M-HRPN_V-m__m-7.7.txt -> brcmfmac4364-pcie.Apple Inc.-<b>MacBookPro15,2.txt</b>
В данном случае последний текстовый файл содержит названия модели, если ваша модель не macbookpro15,2, то необходимо переименовать этот файл в соответствии с вашей моделью макбука.
Перезагружаемся в арч.
Копируем файлы с флешки в папку /lib/firmware/brcm/
sudo cp brcmfmac4364-pcie.bin /lib/firmware/brcm/
sudo cp brcmfmac4364-pcie.clm_blob /lib/firmware/brcm/
sudo cp 'brcmfmac4364-pcie.Apple Inc.-<b>MacBookPro15,2.txt' /lib/firmware/brcm/
Проверяем работоспособность модуля:
rmmod brcmfmac
modprobe brcmfmac
Убеждаемся, что сетевой интерфейс появился через ifconfig/ip.
Настраиваем wifi через iwctl [12]
Внимание. Через netctl, nmcli, etc. интерфейс не работает, только через iwd.
Заставляем NetworkManager использовать iwd. Для этого создаем файл /etc/NetworkManager/NetworkManager.conf и пишем:
[device]
wifi.backend=iwd
Запускаем службу NetworkManager
sudo systemctl start NetworkManager.service
sudo systemctl enable NetworkManager.service
Для того, чтобы заработал звук, необходимо установить pulseaudio:
sudo pacman -S pulseaudio
Скачиваем три файла:
Перемещаем их:
/usr/share/alsa/cards/AppleT2.conf
/usr/share/pulseaudio/alsa-mixer/profile-sets/apple-t2.conf
/usr/lib/udev/rules.d/91-pulseaudio-custom.rules
На текущий момент 16.10.2019 приходится выбирать либо звук, либо suspend/resume. Ждем, пока автор bce модуля допилит функционал.
Чтобы собрать модуль с поддержкой susped/resume, необходимо выполнить следующее:
git clone https://github.com/MCMrARM/mbp2018-bridge-drv.git
cd mbp2018-bridge-drv
git checkout suspend
make
cp bce.ko /usr/lib/modules/extramodules-mbp/bce.ko
modprobe bce
Если вы устанавливали готовый модуль apple-bce из репозитория anuali1, то необходимо его предварительно удалить и только после этого собирать и устанавливать bce модуль с поддежкой suspend режима.
Также, необходимо добавить в blacklist модуль applesmc (если вы этого не сделали ранее) и убедиться, что в /boot/loader/entries/arch.conf в строке options в конце добавлен параметр pcie_ports=compat.
На текущий момент драйвер тачбара вылетает при входе в режим suspend, а драйвер thunderbolt иногда подвешивает систему более чем на 30 секунд, а при возобновлении — на несколько минут. Это можно исправить путем автоматической выгрузки проблемных модулей.
Создайте скрипт /lib/systemd/system-sleep/rmmod.sh:
#!/bin/sh
if [ "${1}" == "pre" ]; then
rmmod thunderbolt
rmmod apple_ib_tb
elif [ "${1}" == "post" ]; then
modprobe apple_ib_tb
modprobe thunderbolt
fi
Сделайте его исполняемым:
sudo chmod +x /lib/systemd/system-sleep/rmmod.sh
На этом пока все. В итоге получась вполне работоспособная система, за исключением некоторых нюансов с suspend/resume. Никаких вылетов и kernel panic не наблюдается на протяжении нескольких дней аптайма. Надеюсь, в ближайшее время автор модуля bce его допилит, и мы получим полноценную поддержку suspend/resume и звука.
Автор: br0zer
Источник [16]
Сайт-источник PVSM.RU: https://www.pvsm.ru
Путь до страницы источника: https://www.pvsm.ru/apple/333724
Ссылки в тексте:
[1] mbp2018-bridge-drv: https://github.com/MCMrARM/mbp2018-bridge-drv
[2] macbook12-spi-driver: https://github.com/roadrunner2/macbook12-spi-driver
[3] 5.3.5-1: https://github.com/aunali1/linux-mbp-arch
[4] отсюда: https://gist.github.com/TRPB/437f663b545d23cc8a2073253c774be3
[5] https://support.apple.com/en-us/HT208330: https://support.apple.com/en-us/HT208330
[6] https://www.ninjastik.com/support/2018-macbook-pro-boot-from-usb/: https://www.ninjastik.com/support/2018-macbook-pro-boot-from-usb/
[7] Разбиение физического диска на разделы Disk Utility: https://support.apple.com/ru-ru/guide/disk-utility/dskutl14027/mac
[8] ссылка на готовый образ: https://r.je/tmp/arch-mbp.iso
[9] archiso: https://wiki.archlinux.org/index.php/Archiso
[10] официальной инструкцией: https://wiki.archlinux.org/index.php/Installation_guide_(%D0%A0%D1%83%D1%81%D1%81%D0%BA%D0%B8%D0%B9)
[11] строронней: https://bogachev.biz/2016/01/25/ustanovka-i-pervonachalynaya-nastroika-archlinux/
[12] iwctl: https://wiki.archlinux.org/index.php/Iwd
[13] 91-pulseaudio-custom.rules: https://gist.github.com/MCMrARM/c357291e4e5c18894bea10665dcebffb/raw/fb28a34e3f255fd4e5a9fe7ac08319165d7efe4d/91-pulseaudio-custom.rules
[14] apple-t2.conf: https://gist.github.com/MCMrARM/c357291e4e5c18894bea10665dcebffb/raw/fb28a34e3f255fd4e5a9fe7ac08319165d7efe4d/apple-t2.conf
[15] AppleT2.conf: https://gist.github.com/MCMrARM/c357291e4e5c18894bea10665dcebffb/raw/fb28a34e3f255fd4e5a9fe7ac08319165d7efe4d/AppleT2.conf
[16] Источник: https://habr.com/ru/post/472106/?utm_campaign=472106&utm_source=habrahabr&utm_medium=rss
Нажмите здесь для печати.