diff --git a/uconsole/configs/configuration.nix b/uconsole/configs/configuration.nix new file mode 100644 index 0000000..94c7fbb --- /dev/null +++ b/uconsole/configs/configuration.nix @@ -0,0 +1,124 @@ +# Edit this configuration file to define what should be installed on +# your system. Help is available in the configuration.nix(5) man page, on +# https://search.nixos.org/options and in the NixOS manual (`nixos-help`). +{ + config, + lib, + pkgs, + ... +}: { + imports = + [ + # Include the results of the hardware scan. + ./hardware-configuration.nix + # Include uConsole settings + ./uConsole.nix + ] + ++ lib.optional (builtins.pathExists ./local.nix) ./local.nix; + + # Use the extlinux boot loader. (NixOS wants to enable GRUB by default) + boot.loader.grub.enable = false; + # Enables the generation of /boot/extlinux/extlinux.conf + boot.loader.generic-extlinux-compatible.enable = true; + + # networking.hostName = "nixos"; # Define your hostname. + # Pick only one of the below networking options. + # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. + # networking.networkmanager.enable = true; # Easiest to use and most distros use this by default. + + # Set your time zone. + # time.timeZone = "Europe/Amsterdam"; + + # Configure network proxy if necessary + # networking.proxy.default = "http://user:password@proxy:port/"; + # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; + + # Select internationalisation properties. + # i18n.defaultLocale = "en_US.UTF-8"; + # console = { + # font = "Lat2-Terminus16"; + # keyMap = "us"; + # useXkbConfig = true; # use xkb.options in tty. + # }; + + # Enable the X11 windowing system. + # services.xserver.enable = true; + + # Configure keymap in X11 + # services.xserver.xkb.layout = "us"; + # services.xserver.xkb.options = "eurosign:e,caps:escape"; + + # Enable CUPS to print documents. + # services.printing.enable = true; + + # Enable sound. + # hardware.pulseaudio.enable = true; + # OR + # services.pipewire = { + # enable = true; + # pulse.enable = true; + # }; + + # Enable touchpad support (enabled default in most desktopManager). + # services.libinput.enable = true; + + # Define a user account. Don't forget to set a password with ‘passwd’. + # users.users.alice = { + # isNormalUser = true; + # extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user. + # packages = with pkgs; [ + # firefox + # tree + # ]; + # }; + + # List packages installed in system profile. To search, run: + # $ nix search wget + # environment.systemPackages = with pkgs; [ + # vim # Do not forget to add an editor to edit configuration.nix! The Nano editor is also installed by default. + # wget + # ]; + + # Some programs need SUID wrappers, can be configured further or are + # started in user sessions. + # programs.mtr.enable = true; + # programs.gnupg.agent = { + # enable = true; + # enableSSHSupport = true; + # }; + + # List services that you want to enable: + + # Enable the OpenSSH daemon. + # services.openssh.enable = true; + + # Open ports in the firewall. + # networking.firewall.allowedTCPPorts = [ ... ]; + # networking.firewall.allowedUDPPorts = [ ... ]; + # Or disable the firewall altogether. + # networking.firewall.enable = false; + + # Copy the NixOS configuration file and link it from the resulting system + # (/run/current-system/configuration.nix). This is useful in case you + # accidentally delete configuration.nix. + # system.copySystemConfiguration = true; + + # This option defines the first version of NixOS you have installed on this particular machine, + # and is used to maintain compatibility with application data (e.g. databases) created on older NixOS versions. + # + # Most users should NEVER change this value after the initial install, for any reason, + # even if you've upgraded your system to a new NixOS release. + # + # This value does NOT affect the Nixpkgs version your packages and OS are pulled from, + # so changing it will NOT upgrade your system - see https://nixos.org/manual/nixos/stable/#sec-upgrading for how + # to actually do that. + # + # This value being lower than the current NixOS release does NOT mean your system is + # out of date, out of support, or vulnerable. + # + # Do NOT change this value unless you have manually inspected all the changes it would make to your configuration, + # and migrated your data accordingly. + # + # For more information, see `man configuration.nix` or https://nixos.org/manual/nixos/stable/options#opt-system.stateVersion . + system.stateVersion = "24.11"; # Did you read the comment? +} diff --git a/uconsole/configs/hardware-configuration.nix b/uconsole/configs/hardware-configuration.nix new file mode 100644 index 0000000..de887e8 --- /dev/null +++ b/uconsole/configs/hardware-configuration.nix @@ -0,0 +1,42 @@ +# Do not modify this file! It was generated by ‘nixos-generate-config’ +# and may be overwritten by future invocations. Please make changes +# to /etc/nixos/configuration.nix instead. +{ + config, + lib, + pkgs, + modulesPath, + ... +}: { + imports = [ + (modulesPath + "/installer/scan/not-detected.nix") + ]; + + boot.initrd.availableKernelModules = []; + boot.initrd.kernelModules = []; + boot.kernelModules = []; + boot.extraModulePackages = []; + + fileSystems."/" = { + device = "/dev/disk/by-uuid/44444444-4444-4444-8888-888888888888"; + fsType = "ext4"; + }; + + fileSystems."/boot/firmware" = { + device = "/dev/disk/by-uuid/2178-694E"; + fsType = "vfat"; + options = ["fmask=0022" "dmask=0022" "nofail" "noauto"]; + }; + + swapDevices = []; + + # Enables DHCP on each ethernet and wireless interface. In case of scripted networking + # (the default) this is the recommended approach. When using systemd-networkd it's + # still possible to use this option, but it's recommended to use it in conjunction + # with explicit per-interface declarations with `networking.interfaces..useDHCP`. + networking.useDHCP = lib.mkDefault true; + # networking.interfaces.enu1u2.useDHCP = lib.mkDefault true; + # networking.interfaces.wlan0.useDHCP = lib.mkDefault true; + + nixpkgs.hostPlatform = lib.mkDefault "aarch64-linux"; +} diff --git a/uconsole/configs/local.nix b/uconsole/configs/local.nix new file mode 100644 index 0000000..c87215c --- /dev/null +++ b/uconsole/configs/local.nix @@ -0,0 +1,28 @@ +{pkgs, ...}: { + nix.distributedBuilds = true; + nix.buildMachines = [ + { + hostName = "red"; + systems = ["aarch64-linux"]; + maxJobs = 24; + speedFactor = 30; + supportedFeatures = ["nixos-test" "benchmark" "big-parallel" "kvm"]; + protocol = "ssh-ng"; + publicHostKey = "c3NoLWVkMjU1MTkgQUFBQUMzTnphQzFsWkRJMU5URTVBQUFBSUtNNHFWdEljcTJkazhNRWRzTG85L0lDaTI2YUloalowMGgvN3ZLcml2UWogcm9vdEBuaXhvcwo="; + } + ]; + nix.settings.substituters = ["http://nixcache.trustno1.corp/"]; + nix.settings.experimental-features = ["nix-command" "flakes"]; + + services.openssh.enable = true; + users.users.oom = { + isNormalUser = true; + extraGroups = ["wheel"]; + }; + environment.systemPackages = [ + pkgs.vim + pkgs.alejandra + pkgs.mc + ]; + boot.supportedFilesystems.zfs = false; +} diff --git a/uconsole/configs/uConsole.nix b/uconsole/configs/uConsole.nix new file mode 100644 index 0000000..872e177 --- /dev/null +++ b/uconsole/configs/uConsole.nix @@ -0,0 +1,90 @@ +{pkgs, ...}: { + imports = [ + "${builtins.fetchGit {url = "https://github.com/NixOS/nixos-hardware.git";}}/raspberry-pi/4" + "${builtins.fetchGit {url = "https://github.com/robertjakub/oom-hardware.git";}}/uconsole/kernel" + "${builtins.fetchGit {url = "https://github.com/robertjakub/oom-hardware.git";}}/raspberry-pi/overlays" + "${builtins.fetchGit {url = "https://github.com/robertjakub/oom-hardware.git";}}/raspberry-pi/apply-overlays" + ]; + + nixpkgs.overlays = [ + (final: super: { + makeModulesClosure = x: + super.makeModulesClosure (x // {allowMissing = true;}); + }) + ]; + + console = { + earlySetup = true; + font = "ter-v32n"; + packages = with pkgs; [terminus_font]; + }; + + boot.kernelParams = [ + "8250.nr_uarts=1" + "vc_mem.mem_base=0x3ec00000" + "vc_mem.mem_size=0x20000000" + "console=ttyS0,115200" + "console=tty1" + "plymouth.ignore-serial-consoles" + "snd_bcm2835.enable_hdmi=1" + "snd_bcm2835.enable_headphones=1" + "psi=1" + "iommu=force" + "iomem=relaxed" + "swiotlb=131072" + ]; + + hardware.raspberry-pi."4" = { + xhci.enable = false; + dwc2.enable = true; + dwc2.dr_mode = "host"; + overlays = { + cpu-revision.enable = true; + audremap.enable = true; + vc4-kms-v3d.enable = true; + cpi-disable-pcie.enable = true; + cpi-disable-genet.enable = true; + cpi-uconsole.enable = true; + cpi-i2c1.enable = false; + cpi-spi4.enable = false; + cpi-bluetooth.enable = true; + }; + }; + + hardware.deviceTree = { + enable = true; + filter = "bcm2711-rpi-cm4.dtb"; + overlaysParams = [ + { + name = "bcm2711-rpi-cm4"; + params = { + ant2 = "on"; + audio = "on"; + spi = "off"; + i2c_arm = "on"; + }; + } + { + name = "cpu-revision"; + params = {cm4-8 = "on";}; + } + { + name = "audremap"; + params = {pins_12_13 = "on";}; + } + { + name = "vc4-kms-v3d"; + params = { + cma-384 = "on"; + nohdmi1 = "on"; + }; + } + ]; + }; + + environment.systemPackages = [ + pkgs.wirelesstools + pkgs.iw + pkgs.gitMinimal + ]; +}