Skip to content

Commit

Permalink
nixos: rework guide (#527)
Browse files Browse the repository at this point in the history
* mkdocs: add pymdownx.tabbed

Tabbed helps illustrate various configuration methods in the NixOS installation guide.

Also removed a redundant item

* nixos: add faq page

* nixos: add home page

* nixos: rewrite installation guide

* nixos: disable two markdownlint rules

Applying fixes to these 2 rules cause breakage to content tabs.
Disabling them locally so as to let other files be checked normally and still pass CI.
  • Loading branch information
soopyc authored May 8, 2024
1 parent cee2b19 commit f30c3bc
Show file tree
Hide file tree
Showing 5 changed files with 241 additions and 37 deletions.
4 changes: 4 additions & 0 deletions docs/distributions/nixos/faq.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# The LiveCD does not boot/only shows a blank screen

This situation occurred due to regressions in the bootloader, which the wider NixOS community was also affected.
The bug has been fixed. Make sure you are using ISOs tagged at or newer than `6.4.9-2`. Nevertheless, usage of [the latest ISO](https://github.com/t2linux/nixos-t2-iso/releases/latest) is recommended.
11 changes: 11 additions & 0 deletions docs/distributions/nixos/home.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# Home

Welcome to the NixOS on T2 Linux wiki! To get started, head over to [the installation guide](./installation.md).

If you have any questions, consult the [FAQ](./faq.md) to see if anything there helps. [Our discord server](https://discord.com/invite/68MRhQu) is also open; feel free to ask questions in the `#nixos` channel there.

## New to NixOS?

NixOS is not exactly an easy Linux distribution to use. If you are entirely new to Linux or had no prior experience with Nix, we strongly recommend you choose another distro like [Fedora](../fedora/home.md) first. Should you decide to proceed further, the [Nixpkgs manual](https://nixos.org/manual/nixpkgs/unstable), [Zero-to-Nix](https://zero-to-nix.com/), [NixOS Options Search](https://search.nixos.org/options) and [the official Nix wiki](https://nix.dev) could come in handy.

That said, if you know what you're doing, feel free to help us out! You know where to find us.
255 changes: 220 additions & 35 deletions docs/distributions/nixos/installation.md
Original file line number Diff line number Diff line change
@@ -1,44 +1,229 @@
# NixOS Installation
<!-- markdownlint-disable MD046 MD038 -->
<!-- Rationale: Both rules break mkdocs-material's content tabs feature. -->

!!! note "Pre-Installation Guide"
This guide assumes that you have followed the [pre-installation guide](https://wiki.t2linux.org/guides/preinstall).
# NixOS Installation Guide

1. Partition your disk using `cfdisk` or the tool of your preference, initialize the partitions with the `mkfs` command of the filesystem you want (`mkswap` is for swap) and mount them under `/mnt`.
You will need:

**Note**: You might want to leave a little part of your disk as a FAT32 partition to be able to transfer files easily between MacOS and Linux.
- A Mac device with a T2 chip
- A spare USB stick or other reasonably large storage medium (>2G recommended)
- Some experience with the command line
- Sufficient mental energy to find and fix errors

2. To connect to internet, you should load the firmware with these commands first:
## Installation Steps

```sh
sudo mkdir -p /lib/firmware/brcm
sudo cp /mnt/boot/firmware/* /lib/firmware/brcm
sudo modprobe -r brcmfmac && sudo modprobe brcmfmac
```
### Preparation

Follow the [Pre-Installation guide](../../guides/preinstall.md). You may not be able to complete some steps without doing so, like [Partitioning](#partitioning).

### Partitioning

After booting to the live environment, partition the disk (usually `/dev/nvme0n1`) using `cfdisk` or other tools of your preference.
If you have followed the pre-installation guide, there should be another partition created just for Linux.

- Remove that and allocate new partitions accordingly - there are no hard rules. Just make sure to not delete the EFI partition and the macOS partition. See the [NixOS Installation Manual](https://nixos.org/manual/nixos/stable/#sec-installation-manual-partitioning-UEFI) for examples.
- Format the newly provisioned partitions with `mkfs.<filesystem>` commands and `mkswap` a swap partition (if any).
- Mount the partitions under `/mnt`, and create directories as necessary. Then, enable the swap partition by using `swapon`. You should finally have something that looks similar to this:

```console
$ lsblk
NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTS
loop0 7:0 0 972.5M 0 loop /nix/.ro-store
sda 8:0 1 14.5G 0 disk
├─sda1 8:1 1 1021M 0 part
└─sda2 8:2 1 3M 0 part
nvme0n1 259:0 0 465.9G 0 disk
├─nvme0n1p1 259:1 0 300M 0 part /mnt/boot # EFI partition
├─nvme0n1p2 259:2 0 83.9G 0 part # APFS/macOS partition
├─nvme0n1p3 259:3 0 1G 0 part /mnt/macos_share # optional
├─nvme0n1p4 259:4 0 8G 0 part [SWAP] # Swap Partition
└─nvme0n1p5 259:5 0 372.8G 0 part /mnt # Linux Partition
```

This is just an example and does not have to be done this way.

!!! tip
You might want to leave a little part of your disk as a FAT32 partition to be able to transfer files easily between MacOS and Linux. You would not have the chance to do so later, so do it now if needed.

### Internet Setup

If you wish to use Ethernet, no additional actions should be needed apart from an adapter.

If you wish to use Wi-Fi, follow the [Imperative firmware setup section](#imperative-setup) and come back.

### Configuration and Installation

Before doing anything else in this section, make sure partitions are **created and mounted** to `/mnt`. Check that with tools like `lsblk` and `findmnt -R /mnt`.

Generate a configuration the following command:

sudo nixos-generate-config --root /mnt

Then run `systemctl start wpa_supplicant` and then connect to internet using `wpa_cli`.
When running the commands, don't forget to change `/mnt/boot` to the place you mounted your ESP at (for example `/mnt/boot/efi`).
3. Generate your configuration using `sudo nixos-generate-config --root /mnt`.
4. Edit `/mnt/etc/nixos/configuration.nix`:
* Add `"${builtins.fetchGit { url = "https://github.com/NixOS/nixos-hardware.git"; }}/apple/t2"` to `imports`.
* Copy the WiFi/Bluetooth firmware to `/mnt/etc/nixos/firmware/brcm` and add this snippet to your `configuration.nix`:
```nix
hardware.firmware = [
(pkgs.stdenvNoCC.mkDerivation {
name = "brcm-firmware";
buildCommand = ''
dir="$out/lib/firmware"
mkdir -p "$dir"
cp -r ${./files/firmware}/* "$dir"
'';
})
];
This will generate `configuration.nix` and `hardware-configuration.nix`. The former contains some default settings to get you started while the latter contain filesystems mounted at `/mnt` during generation.

You might want to also configure a display manager and a desktop environment. Check out available options at the [NixOS Options Search](https://search.nixos.org/options), and simply edit `configuration.nix` before installation.

=== "Legacy Method"
Edit `/mnt/etc/nixos/configuration.nix`

* Add the following snippet to the nixos config's `imports`
```nix title="configuration.nix" linenums="1" hl_lines="4"
# Keep the generated configuration.nix! You need that, so just merge options here into that one.
{...}: {
imports = [
"${builtins.fetchGit { url = "https://github.com/NixOS/nixos-hardware.git"; }}/apple/t2"
];
}
```

* Add a bootloader, `systemd-boot` works quite well. If you want to use `GRUB`, don't forget to set `boot.grub.efiInstallAsRemovable`, `boot.grub.efiSupport` to `true` and `boot.grub.device` to `"nodev"`.
5. Run `sudo nixos-install`.
=== "Flakes"
Nix flakes is a new system that is designed to replace nix channels and to improve reproducibility. It is still in an experimental stage and is locked behind a number of feature flags.

Flakes support in the ISO is enabled since the v6.4.9-3 ISO. You can validate if you're using that by running `nix run nixpkgs#hello`. If it outputs "Hello, world!", you can continue without modifying commands. If it errors, you are not.

To use flakes, pass `--extra-experimental-features "flakes nix-command"` to nix commands in the live environment. Nix commands with hyphens (`-`, i.e. `nixos-rebuild`, `nix-store`) in them generally do not require this since they were not built with flakes in mind.

Below are the setup steps. Adapt the locations as needed.

0. You should have ran `nixos-generate-config`. If not, [do that](#configuration-and-installation).
* Make a new file at `/mnt/etc/nixos/flake.nix`, or use `nix flake init` while being in `/mnt/etc/nixos`
* Add a flake input: `github:NixOS/nixos-hardware`
* Add the apple-t2 NixOS module from `nixos-hardware` to your NixOS config.
* For reasons stated above, add "flakes" and "nix-command" to nix's `experimental-features`.
* Add a nixosConfigurations output, in which add a new attribute with any valid name. The common standard is to use the hostname. This will be used to activate your system.
* Set the value of the attribute as a call to the lib.nixosSystem function (from the nixpkgs input) with a new attribute set, which contains the items outlined in the example below.

!!! quote "Example Configuration"

```nix title="flake.nix" linenums="1"
{
inputs = {
nixpkgs.url = "nixpkgs/nixos-unstable";
nixos-hardware.url = "github:nixos/nixos-hardware";
};
outputs = {nixpkgs, nixos-hardware, ...}: {
nixosConfigurations.replaceThisWithAnything = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
modules = [
./configuration.nix
nixos-hardware.nixosModules.apple-t2
];
};
};
}
```

```nix title="configuration.nix (snippet)" linenums="1"
# Keep the generated configuration.nix! You need that, so just merge options here into that one.
{...}: [
imports = [./hardware-configuration.nix]; # this should already be present
nix.settings.experimental-features = [
"nix-command"
"flakes"
];
]
```

!!! tip
You do not need to keep your flake at `/etc/nixos` if you use this approach. You may safely copy the entire `/etc/nixos` directory to your home directory with whatever name you like. Then, [re]building the system is easy as running

nixos-rebuild build .# # when building
sudo nixos-rebuild switch .# # when switching

within the flake directory.

It is recommended to make the flake a git repo. Do so inside the flake with `git init`.

Then add a bootloader, `systemd-boot` works quite well and is recommended. `GRUB` is also available, but its usability has not been tested.
<!-- TODO: test that lol -->

=== "systemd-boot"
```nix title="configuration.nix" linenums="1"
{...}: {
boot.loader = {
efi.efiSysMountPoint = "/boot"; # make sure to change this to your EFI partition!
systemd-boot.enable = true;
};
}
```

=== "GRUB"
```nix title="configuration.nix" linenums="1"
{...}: {
boot.loader = {
efi.efiSysMountPoint = "/boot"; # make sure to change this to your EFI partition!
grub = {
efiInstallAsRemovable = true;
efiSupport = true;
device = "nodev";
};
};
}
```

If you want to use Wi-Fi and/or Bluetooth after installation, now is the time to [set up the firmware declaratively.](#declarative-setup)

It is now time to install the system.

=== "Legacy Method"
Simply run `sudo nixos-install` and hope that it works.

=== "Flakes"
Run `sudo nixos-install --flake .#<your host>`, where `<your host>` is the `nixosConfiguration` attribute name defined above.

With the example, the command would be as thus.

sudo nixos-install --flake .#replaceThisWithAnything

Finally, reboot and the installation is complete! If it did not work out as expected, feel free to ask in our Discord server. Provide as much detail as possible about what's not working so less time is wasted for all participants.

To change the system configuration after installation, simply edit `configuration.nix` and run `sudo nixos-rebuild switch`.

If you would like to organize your configuration a little better, check out other people's configuration or read the [Nix manuals](https://nixos.org/learn).

---

## Wi-Fi and Bluetooth setup

### Imperative Setup

The imperative setup is useful for temporary situations like the Live environment.

The following commands should get you up and running. You should have acquired the firmware script from the pre-installation guide. Note that `/lib/firmware` has to be manually created because NixOS does not come with that.

sudo mkdir -p /lib/firmware
sudo /mnt/boot/firmware.sh
# ^~~~~~~~~ change this if the EFI partition is mounted elsewhere

Then run `systemctl start wpa_supplicant` and then connect to internet using `wpa_cli`. Consult documentations such as the [Arch Linux wiki](https://wiki.archlinux.org/title/Wpa_supplicant#Connecting_with_wpa_cli) for command usage.

---

### Declarative Setup

The declarative setup is suitable for long-term use after you have installed NixOS.

=== "Legacy Method"
<!-- TODO: extend the firmware script to short-circuit the installation and just give users a usable .tar -->
This step currently requires the completion of the firmware [imperative setup](#imperative-setup).

Assuming your `configuration.nix` is at `/mnt/etc/nixos/`, copy the existing firmware files at `/lib/firmware` to `/mnt/etc/nixos/firmware`. Then add this snippet to your `configuration.nix`:

```nix linenums="1" hl_lines="2-11" title="configuration.nix"
{pkgs, ...}: {
hardware.firmware = [
(stdenvNoCC.mkDerivation (final: {
name = "brcm-firmware";
src = ./firmware/brcm;
installPhase = ''
mkdir -p $out/lib/firmware/brcm
cp ${final.src}/* "$out/lib/firmware/brcm"
'';
}))
]
}
```

And the installation is complete!
Note that you should probably transition to a more structured configuration [using flakes](https://github.com/NixOS/nixos-hardware/blob/master/README.md#using-nix-flakes-support), that is omitted here for brevity.
=== "Flakes"
<!-- TODO -->
We're working on a flake output! That should make this easier. In the meantime, the "legacy" option also apply to flakes.
2 changes: 1 addition & 1 deletion docs/distributions/overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,6 @@ This is a landing page for the distribution specific guides contained in this wi
- [Fedora](https://wiki.t2linux.org/distributions/fedora/home/)
- [Gentoo](https://wiki.t2linux.org/distributions/gentoo/installation/)
- [Manjaro](https://wiki.t2linux.org/distributions/manjaro/home/)
- [NixOS](https://wiki.t2linux.org/distributions/nixos/installation/)
- [NixOS](https://wiki.t2linux.org/distributions/nixos/home/)
- [Ubuntu](https://wiki.t2linux.org/distributions/ubuntu/home/)
- [Debian, Linux Mint, Kali, Pop!_OS and other similar distros](https://wiki.t2linux.org/distributions/debian/installation/)
6 changes: 5 additions & 1 deletion mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ theme:
font: false
features:
- tabs
- content.tabs.link
favicon: assets/images/icon.png

docs_dir: docs
Expand All @@ -28,11 +29,12 @@ markdown_extensions:
- pymdownx.superfences
- pymdownx.tasklist:
custom_checkbox: true
- pymdownx.tabbed:
alternate_style: true
- toc:
permalink: true
- admonition
- pymdownx.details
- pymdownx.superfences

plugins:
- redirects:
Expand Down Expand Up @@ -80,6 +82,8 @@ nav:
- FAQ: distributions/manjaro/faq.md
- Installation: distributions/manjaro/installation.md
- NixOS:
- Home: distributions/nixos/home.md
- FAQ: distributions/nixos/faq.md
- Installation: distributions/nixos/installation.md
- Ubuntu:
- Home: distributions/ubuntu/home.md
Expand Down

0 comments on commit f30c3bc

Please sign in to comment.