diff --git a/README.md b/README.md index 96f30ba..a6ee086 100644 --- a/README.md +++ b/README.md @@ -113,6 +113,7 @@ See code for all available configurations. | [Dell XPS 17 9710, intel only](dell/xps/17-9710/intel) | `` | | [Dell XPS E7240](dell/e7240) | `` | | [Framework](framework) | `` | +| [Framework 12th Gen Intel Core](framework/12th-gen-intel) | `` | | [FriendlyARM NanoPC-T4](friendlyarm/nanopc-t4) | `` | | [GPD MicroPC](gpd/micropc) | `` | | [Google Pixelbook](google/pixelbook) | `` | diff --git a/flake.nix b/flake.nix index b993fbb..bbe0c80 100644 --- a/flake.nix +++ b/flake.nix @@ -47,6 +47,7 @@ dell-xps-17-9700-nvidia = import ./dell/xps/17-9700/nvidia; dell-xps-17-9710-intel = import ./dell/xps/17-9710/intel; framework = import ./framework; + framework-12th-gen-intel = import ./framework/12th-gen-intel; friendlyarm-nanopc-t4 = import ./friendlyarm/nanopc-t4; google-pixelbook = import ./google/pixelbook; gpd-micropc = import ./gpd/micropc; diff --git a/framework/12th-gen-intel/README.md b/framework/12th-gen-intel/README.md new file mode 100644 index 0000000..e8d10e0 --- /dev/null +++ b/framework/12th-gen-intel/README.md @@ -0,0 +1,17 @@ +# [Framework Laptop](https://frame.work/) + +## Updating Firmware + +First put enable `fwupd` + +```nix +services.fwupd.enable = true; +``` + +Then run + +```sh + $ sudo fwupdmgr update +``` + +[Latest Update](https://fwupd.org/lvfs/devices/work.frame.Laptop.TGL.BIOS.firmware) diff --git a/framework/12th-gen-intel/default.nix b/framework/12th-gen-intel/default.nix new file mode 100644 index 0000000..63adb48 --- /dev/null +++ b/framework/12th-gen-intel/default.nix @@ -0,0 +1,51 @@ +{ lib, pkgs, ... }: { + imports = [ + ../../common/cpu/intel + ../../common/pc/laptop + ../../common/pc/laptop/ssd + ]; + + boot.kernelParams = [ + # For Power consumption + # https://kvark.github.io/linux/framework/2021/10/17/framework-nixos.html + "mem_sleep_default=deep" + # For Power consumption + # https://community.frame.work/t/linux-battery-life-tuning/6665/156 + "nvme.noacpi=1" + ]; + + # This enables the brightness keys to work + # https://community.frame.work/t/12th-gen-not-sending-xf86monbrightnessup-down/20605/11 + boot.blacklistedKernelModules = [ "hid-sensor-hub" ]; + + # Alder Lake CPUs benefit from kernel 5.18 for ThreadDirector + # https://www.tomshardware.com/news/intel-thread-director-coming-to-linux-5-18 + boot.kernelPackages = lib.mkIf (lib.versionOlder pkgs.linux.version "5.18") (lib.mkDefault pkgs.linuxPackages_latest); + + # Fix TRRS headphones missing a mic + # https://community.frame.work/t/headset-microphone-on-linux/12387/3 + boot.extraModprobeConfig = '' + options snd-hda-intel model=dell-headset-multi + ''; + + # For fingerprint support + services.fprintd.enable = lib.mkDefault true; + + # Fix headphone noise when on powersave + # https://community.frame.work/t/headphone-jack-intermittent-noise/5246/55 + services.udev.extraRules = '' + SUBSYSTEM=="pci", ATTR{vendor}=="0x8086", ATTR{device}=="0xa0e0", ATTR{power/control}="on" + ''; + + # Mis-detected by nixos-generate-config + # https://github.com/NixOS/nixpkgs/issues/171093 + # https://wiki.archlinux.org/title/Framework_Laptop#Changing_the_brightness_of_the_monitor_does_not_work + hardware.acpilight.enable = lib.mkDefault true; + + # HiDPI + # Leaving here for documentation + # hardware.video.hidpi.enable = lib.mkDefault true; + + # Fix font sizes in X + # services.xserver.dpi = 200; +}