Skip to content

Latest commit

 

History

History
164 lines (121 loc) · 11.9 KB

README.md

File metadata and controls

164 lines (121 loc) · 11.9 KB

T2 Atomic

bluebuild

bluebuild

bluebuild

bluebuild

bluebuild

Fedora Atomic Desktops for Macs with T2 chips

Gnome - Plasma - Sway - Bluefin/Aurora/DX - Cosmic - SwayFX - River

New! a Bluefin, Aurora (and DX variant) images are now available, with River and SwayFX images in testing.

tl;dr?: Things mostly works, skip to installation instructions

The final generation of Intel Macs, with T2 chip, requires kernel patches and arguments, packages, configs, and firmware to be usable on Linux. T2Linux has built a lot of documentation,tooling, and specialty repositories to support installing distros on T2 Macs, including Fedora Workstation. T2-Atomic is built off these efforts, brought into the atomic/immutable world.

Why Atomic?

Your T2 Mac has specialized needs. Instead of worrying if the latest version of some small but critical utility will break your keyboard on reboot, let our build and test pipeline help. Relax and let the daily updates stage in the background.

Something still go wrong? Boot to the previous image and run rpm-ostree rollback

Current State (10 September 2024)

Editor's Note: Please don't buy a MacBook to use Linux on it, this project is for those of us tired of macOS, with hand-me-downs, etc. Buy a Framework, something from System76, or for the love of compute at least a used ThinkPad. But, if you must...

Warning: a 2023 Apple firmware update broke deep sleep and this is still broken. See note above.

  • Current images and tags published (** denoting test images or advanced images that require some configuration):

    • Gnome (Silverblue)
    • Plasma (Kinoite)
    • Sway (Sericea)
    • Cosmic Alpha** - based on Silverblue, includes Gnome and Gnome apps
    • Bluefin and Aurora - Universal Blue's Bluefin and Aurora images, for T2
    • Bluefin-DX and Aurora-DX - Univeral Blue's Bluefin Developer Experience, for T2
    • River** - Isaac Freund's River dynamic tiling Wayland compositor with flexible runtime configuration, on Universal Blue "base" image
    • Swayfx** - effectively Sericea modified to use Swayfx instead of Sway.
    • Tags: latest (we may add a "stable" with fsync-ba kernel like Bluefin has available)
  • Note: External/USB input devices are required for installation. The internal keyboard and trackpad will not work during installation, or during encryption password prompt on boot (the latter fixed with a simple command later). If a build ever breaks the keyboard/trackpad, the immutability of Atomic Desktops helps, just boot to an earlier image and rpm-ostree rollback.

  • We install bits that aren't possible to layer later via rpm-ostree, such as the wifi/bt firmware, audio components, and kernel.

  • Post-install, Several manual steps are needed to enable some of the installed packages and configuration. Examples (detailed in the instructions below):

    • Deep sleep causes a crash and must be disabled with a kernel argument.
    • Encrypted disk unlock with the internal keyboard requires a command to be run once.
    • Radeon graphics-equipped models (including MacBookPro 16,1) can be used with hybrid graphics via renaming a configuration file.
    • tuned DSP audio is available for some models (including the 6-speaker array MacBook Pro 16,1). The pipewire configuration file in /etc needs to be renamed to enable it.

What Works, What Doesn't

For general information on the state of Linux on T2, see t2linux wiki

Not Working

  • deep sleep. Will be adding in a justfile command to toggle s2idle but for now this thread on stackexchange should help.
  • Touch ID (or anything the T2 Secure Enclave manages)
  • TPM (T2 isn't a TPM but theoretically...) / secureboot --so no LUKS autounlock via TPM possible (LUKS + window manager autologin as a workaround does)

Works Fairly Well

  • touchbar (tiny-dfr-rust)
  • webcam (via apple-bce)
  • audio. sound quality can be poor and the mic doesn't work well on some models.

Works Quite Well

  • kernel - we're using fsync kernel to align with Universal Blue images.
  • keyboard, trackpad (via apple-bce)
  • fan control (t2fanrd)
  • wifi/bt hardware (customized for Fedora Atomic, but based on NoaHimesaka1873's fork of asahi-installer
  • thunderbolt (video via USB-C works even with thunderbolt disabled)

Installation

Warning
External input devices are required for installation. The internal keyboard and trackpad will not work during installation, or during encryption password prompt on boot (the latter fixed with a simple command later). If a build ever breaks the keyboard/trackpad, the immutability of Atomic Desktops helps, just boot to an earlier image and rpm-ostree rollback.

Step 0 (optional): Try Fedora Workstation

If you're curious how well your T2 Mac works on Fedora, we recommend trying the T2Linux Fedora live images (traditional, non-immutable).

We unfortunately can't provide a live environment image at this time due to the nature of the OCI deployment.

Step 1: Select and Download an Installer

Download the Fedora Atomic Desktop image that most closely matches the T2-Atomic image you'll rebase to. Rebasing from Gnome to Plasma, for example, results in some bugs. Peruse the list of images below and proceed to download the required ISO for install.

T2 Atomic Flagship Images

T2 Atomic Test Images

install if you love rolling back when things break ;)

  • t2-atomic-river - Install Sericea before rebasing (sway will be removed)
  • t2-atomic-cosmic-gnome - install Silverblue before rebasing
  • t2-atomic-swayfx - Install Sericea before rebasing (sway will be replaced)

Step 2: Install Fedora Atomic from ISO

Write the ISO to a USB using dd, Fedora Media Writer, Ventoy, or similar.

Proceed to install per usual (just like a typical Fedora install). Some installers (Gnome) don't have you create a user account during install. Note that dualbooting isn't supported, to attempt it make sure you back up your data before and don't touch Apple's EFI or other partitions from the Fedora installer.

Step 3: Rebase, and Rebase Again

Note: two rebases are needed to get to our signed images from a vanilla Fedora Atomic image.

The following steps are to be done in the terminal app used by your desktop.

  • STEP 3A: Rebase Rebase to an unsigned interim image. Replace [variant] with your desired image: rpm-ostree rebase ostree-unverified-registry:ghcr.io/lauretano/[variant]:latest

    • example, for Gnome: rpm-ostree rebase ostree-unverified-registry:ghcr.io/lauretano/t2-atomic:latest
  • STEP 3B: Reboot

    to complete the rebase: systemctl reboot

  • STEP 3C: Rebase Again: Rebase to the signed image, replacing [variant] with your desired image: rpm-ostree rebase ostree-image-signed:docker://ghcr.io/lauretano/[variant]:latest

    • example, for the default Gnome desktop: rpm-ostree rebase ostree-image-signed:docker://ghcr.io/lauretano/t2-atomic:latest
  • Reboot again to complete the installation systemctl reboot

Step 4: Post-Installation

  • on first boot, the daemons for fan speed and touchbar should already be enabled

Kernel Arguments for PCIe

In a terminal, run: rpm-ostree kargs --append-if-missing="intel_iommu=on" --append-if-missing="iommu=pt" --append-if-missing="mem_sleep_default=s2idle"

Enable keyboard for encryption unlock on boot

In a terminal, run: rpm-ostree initramfs enable and reboot when prompted to. /etc/dracut.conf.d/t2-bce.conf defines the modules it will build in to load at boot, including apple-bce for the keyboard.

Hybrid Graphics / iGPU

In Linux, you can enable the iGPU and the dGPU will operate in a low power state by default, allowing you to specify or limit which apps are allowed dGPU access to save power/heat/battery. By default, the iGPU is disabled and the dGPU operates in the same automatic state. See Hybrid Graphics(T2Linux Wiki) for more information.

To enable the Intel integrated graphics, edit the file /etc/modprobe.d/apple-gmux.conf (creating it if not present). We provide the file with the option commented out. Uncomment, save and reboot to continue. An exmaple of the file enabling the iGPU is as follows:

# /etc/modprobe.d/apple-gmux.conf
#
# Enable the iGPU by setting force_igd=y
# Disable it by commenting out the line or setting force_igd=n
options apple-gmux force_igd=y

Disabling T2-integated Ethernet (connect/disconnect notifications)

Edit or create /etc/modprobe.d/t2-eth-blocklist.conf

# T2 Atomic
# disable the T2 chip internal USB ethernet, as the downstream devices
# aren't yet supported (Touch ID, etc)
blacklist cdc_ncm
blacklist cdc_mbim

Save and restart

Major Updates

  • 10 September 2024, all images have been moved to fsync kernel (which includes T2 patches). Bluefin-DX, River, and SwayFX images are now available.
  • 18 June 2024, We're now publishing Plasma images to celebrate Plasma 6.1 releasing with explicit sync support. The fix for LUKS unlock is working in testing and should be available in builds soon.
  • 10 May 2024, a COSMIC variant is in testing, not for public consumption at this time. It won't work with the below instructions as SELinux has to be disabled for it to work for now. You wouldn't want to install anyway, more of a personal spin for my own internal testing.
  • as of 6 May 2024, we're rapidly approaching our first Beta release. Wifi and BT should now be mostly operational including WPA3
  • keyboard (touchbar via tiny-dfr), fan control (t2fanrd), and audio support are in place. There may be speaker equalizer presets that need to be brought in (such as for MacBookPro16,1).
  • at this time there's only images being built for Gnome (aka Silverblue), but Plasma (aka Kinoite) will be added soon. Let us know if you have any other requests.
  • the T2-enablement work here is also being added to a fork of Universal Blue's hwe repo to possibly support future Bluefin/Bazzite versions with T2 support.

Verification

These images are signed with Sigstore's cosign. You can verify the signature by downloading the cosign.pub file from this repo and running the following command:

cosign verify --key cosign.pub ghcr.io/Lauretano/t2-atomic