443 lines
10 KiB
Nix
443 lines
10 KiB
Nix
|
{ config, pkgs, lib, inputs, materusFlake, materusPkgs, ... }:
|
|||
|
|
|||
|
{
|
|||
|
virtualisation.lxc.enable = false;
|
|||
|
virtualisation.lxc.lxcfs.enable = false;
|
|||
|
virtualisation.lxd.enable = false;
|
|||
|
#virtualisation.lxd.recommendedSysctlSettings = true;
|
|||
|
|
|||
|
programs.corectrl.enable = true;
|
|||
|
programs.corectrl.gpuOverclock.enable = true;
|
|||
|
programs.corectrl.gpuOverclock.ppfeaturemask = "0xffffffff";
|
|||
|
programs.gamemode.enable = true;
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
services.teamviewer.enable = true;
|
|||
|
|
|||
|
systemd.tmpfiles.rules = [
|
|||
|
"L+ /opt/rocm/hip - - - - ${pkgs.hip}"
|
|||
|
];
|
|||
|
|
|||
|
services.flatpak.enable = true;
|
|||
|
services.gvfs.enable = true;
|
|||
|
|
|||
|
|
|||
|
|
|||
|
time.timeZone = "Europe/Warsaw";
|
|||
|
i18n.defaultLocale = "pl_PL.UTF-8";
|
|||
|
console = {
|
|||
|
font = "lat2-16";
|
|||
|
# keyMap = "pl";
|
|||
|
useXkbConfig = true; # use xkbOptions in tty.
|
|||
|
};
|
|||
|
services.xserver.layout = "pl";
|
|||
|
|
|||
|
services.xserver.enable = true;
|
|||
|
services.xserver.videoDrivers = [ "amdgpu" ];
|
|||
|
services.dbus.enable = true;
|
|||
|
services.dbus.packages = [ pkgs.gcr_4 ];
|
|||
|
|
|||
|
|
|||
|
#services.xserver.displayManager.autoLogin.user = "materus";
|
|||
|
services.xserver.displayManager.startx.enable = false;
|
|||
|
/*
|
|||
|
services.xserver.displayManager.lightdm.enable = true;
|
|||
|
services.xserver.displayManager.lightdm.greeters.enso.enable = true;
|
|||
|
services.xserver.displayManager.lightdm.greeters.enso.blur = true;
|
|||
|
*/
|
|||
|
|
|||
|
services.xserver.config = pkgs.lib.mkAfter ''
|
|||
|
Section "OutputClass"
|
|||
|
Identifier "amd-options"
|
|||
|
Option "TearFree" "True"
|
|||
|
Option "SWCursor" "True"
|
|||
|
Option "VariableRefresh" "true"
|
|||
|
Option "AsyncFlipSecondaries" "true"
|
|||
|
MatchDriver "amdgpu"
|
|||
|
EndSection
|
|||
|
|
|||
|
'';
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
services.printing.enable = true;
|
|||
|
|
|||
|
|
|||
|
sound.enable = true;
|
|||
|
security.rtkit.enable = true;
|
|||
|
services.pipewire = {
|
|||
|
enable = true;
|
|||
|
audio.enable = true;
|
|||
|
alsa.enable = true;
|
|||
|
alsa.support32Bit = true;
|
|||
|
pulse.enable = true;
|
|||
|
systemWide = false;
|
|||
|
# If you want to use JACK applications, uncomment this
|
|||
|
jack.enable = true;
|
|||
|
};
|
|||
|
hardware.pulseaudio.enable = false;
|
|||
|
|
|||
|
services.xserver.libinput.enable = true;
|
|||
|
|
|||
|
virtualisation.waydroid.enable = false;
|
|||
|
virtualisation.podman = {
|
|||
|
enable = true;
|
|||
|
#enableNvidia = true;
|
|||
|
dockerCompat = true;
|
|||
|
dockerSocket.enable = true;
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
users.users.materus = {
|
|||
|
isNormalUser = true;
|
|||
|
extraGroups = [ "audio" "video" "render" "pipewire" "wheel" "networkmanager" "input" "kvm" "libvirt-qemu" "libvirt" "libvirtd" "podman" "lxd" ]; # Enable ‘sudo’ for the user.
|
|||
|
shell = pkgs.bashInteractive;
|
|||
|
description = "Mateusz Słodkowicz";
|
|||
|
# packages = with pkgs; [
|
|||
|
# firefox
|
|||
|
# thunderbird
|
|||
|
# ];
|
|||
|
};
|
|||
|
environment.variables = {
|
|||
|
DISABLE_LAYER_AMD_SWITCHABLE_GRAPHICS_1 = "1";
|
|||
|
VK_ICD_FILENAMES = "/run/opengl-driver/share/vulkan/icd.d/radeon_icd.x86_64.json:/run/opengl-driver-32/share/vulkan/icd.d/radeon_icd.i686.json";
|
|||
|
AMD_VULKAN_ICD = "RADV";
|
|||
|
RADV_PERFTEST = "gpl,rt,sam";
|
|||
|
ALSOFT_DRIVERS = "pulse";
|
|||
|
};
|
|||
|
environment.sessionVariables = rec {
|
|||
|
XDG_CACHE_HOME = "\${HOME}/.cache";
|
|||
|
XDG_CONFIG_HOME = "\${HOME}/.config";
|
|||
|
XDG_BIN_HOME = "\${HOME}/.local/bin";
|
|||
|
XDG_DATA_HOME = "\${HOME}/.local/share";
|
|||
|
|
|||
|
SDL_AUDIODRIVER = "pipewire";
|
|||
|
|
|||
|
#SSH_ASKPASS_REQUIRE = "prefer";
|
|||
|
|
|||
|
MOZ_USE_XINPUT2 = "1";
|
|||
|
PATH = [
|
|||
|
"\${XDG_BIN_HOME}"
|
|||
|
];
|
|||
|
};
|
|||
|
environment.shellInit = ''
|
|||
|
if ! [ -z "$DISPLAY" ]; then xhost +si:localuser:root &> /dev/null; fi;
|
|||
|
if ! [ -z "$DISPLAY" ]; then xhost +si:localuser:$USER &> /dev/null; fi;
|
|||
|
'';
|
|||
|
|
|||
|
i18n.inputMethod.enabled = "fcitx5";
|
|||
|
i18n.inputMethod.fcitx5.addons = [ pkgs.fcitx5-configtool pkgs.fcitx5-lua pkgs.fcitx5-mozc pkgs.fcitx5-gtk pkgs.libsForQt5.fcitx5-qt ];
|
|||
|
|
|||
|
|
|||
|
# Some programs need SUID wrappers, can be configured further or are
|
|||
|
# started in user sessions.
|
|||
|
# programs.mtr.enable = true;
|
|||
|
services.pcscd.enable = true;
|
|||
|
services.samba-wsdd.enable = true;
|
|||
|
|
|||
|
services.samba = {
|
|||
|
enable = true;
|
|||
|
package = pkgs.sambaFull;
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
programs.gnupg.agent = {
|
|||
|
enable = true;
|
|||
|
enableSSHSupport = false;
|
|||
|
enableBrowserSocket = true;
|
|||
|
|
|||
|
};
|
|||
|
programs.ssh.startAgent = true;
|
|||
|
services.openssh.enable = true;
|
|||
|
|
|||
|
environment.enableAllTerminfo = true;
|
|||
|
environment.pathsToLink = [ "/share/zsh" "/share/bash-completion" "/share/fish" ];
|
|||
|
environment.shells = with pkgs; [ zsh bashInteractive fish ];
|
|||
|
programs = {
|
|||
|
fish.enable = true;
|
|||
|
zsh = {
|
|||
|
enable = true;
|
|||
|
interactiveShellInit = ''
|
|||
|
if [[ ''${__MATERUS_HM_ZSH:-0} == 0 ]]; then
|
|||
|
source ${pkgs.grml-zsh-config}/etc/zsh/zshrc
|
|||
|
fi
|
|||
|
'';
|
|||
|
promptInit = ''
|
|||
|
|
|||
|
'';
|
|||
|
};
|
|||
|
java.enable = true;
|
|||
|
java.package = pkgs.graalvm-ce;
|
|||
|
java.binfmt = true;
|
|||
|
command-not-found.enable = false;
|
|||
|
dconf.enable = true;
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
/*containers.test = {
|
|||
|
config = { config, pkgs, ... }: { environment.systemPackages = with pkgs; [ wayfire ]; };
|
|||
|
autoStart = false;
|
|||
|
};*/
|
|||
|
|
|||
|
environment.systemPackages = with pkgs; [
|
|||
|
firefox
|
|||
|
gamescope
|
|||
|
#(pkgs.lutris.override { extraLibraries = pkgs: with pkgs; [ pkgs.samba pkgs.jansson pkgs.tdb pkgs.libunwind pkgs.libusb1 pkgs.gnutls pkgs.gtk3 pkgs.pango ]; })
|
|||
|
materusPkgs.amdgpu-pro-libs.prefixes
|
|||
|
(pkgs.bottles.override { extraPkgs = pkgs: with pkgs; [ pkgs.libsForQt5.breeze-qt5 pkgs.libsForQt5.breeze-gtk pkgs.nss_latest ]; extraLibraries = pkgs: with pkgs; [ pkgs.samba pkgs.jansson pkgs.tdb pkgs.libunwind pkgs.libusb1 pkgs.gnutls pkgs.gtk3 pkgs.pango ]; })
|
|||
|
glibc
|
|||
|
glib
|
|||
|
gtk3
|
|||
|
gtk4
|
|||
|
gsettings-desktop-schemas
|
|||
|
libsForQt5.dolphin
|
|||
|
|
|||
|
vim # Do not forget to add an editor to edit configuration.nix! The Nano editor is also installed by default.
|
|||
|
|
|||
|
patchelf
|
|||
|
killall
|
|||
|
util-linux
|
|||
|
xorg.xhost
|
|||
|
nix-top
|
|||
|
|
|||
|
gitFull
|
|||
|
curl
|
|||
|
wget
|
|||
|
|
|||
|
config.programs.java.package
|
|||
|
|
|||
|
nss_latest
|
|||
|
|
|||
|
aspell
|
|||
|
aspellDicts.pl
|
|||
|
aspellDicts.en
|
|||
|
aspellDicts.en-computers
|
|||
|
steamtinkerlaunch
|
|||
|
distrobox
|
|||
|
|
|||
|
p7zip
|
|||
|
unrar
|
|||
|
bzip2
|
|||
|
rar
|
|||
|
unzip
|
|||
|
zstd
|
|||
|
xz
|
|||
|
zip
|
|||
|
gzip
|
|||
|
|
|||
|
tree
|
|||
|
mc
|
|||
|
lf
|
|||
|
htop
|
|||
|
nmon
|
|||
|
iftop
|
|||
|
iptraf-ng
|
|||
|
mprocs
|
|||
|
tldr
|
|||
|
bat
|
|||
|
##config.materus.profile.packages.home-manager
|
|||
|
|
|||
|
# pgcli
|
|||
|
# litecli
|
|||
|
|
|||
|
#zenmonitor
|
|||
|
|
|||
|
nix-du
|
|||
|
|
|||
|
ark
|
|||
|
kate
|
|||
|
krusader
|
|||
|
|
|||
|
wineWowPackages.stagingFull
|
|||
|
winetricks
|
|||
|
protontricks
|
|||
|
openal
|
|||
|
gnupg
|
|||
|
pinentry
|
|||
|
pinentry-gnome
|
|||
|
pinentry-curses
|
|||
|
ncurses
|
|||
|
monkeysphere
|
|||
|
gparted
|
|||
|
|
|||
|
virt-viewer
|
|||
|
|
|||
|
inkscape
|
|||
|
gimp
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
bubblewrap
|
|||
|
bindfs
|
|||
|
|
|||
|
pulseaudio
|
|||
|
|
|||
|
binutils
|
|||
|
config.materus.profile.packages.firefox
|
|||
|
];
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
environment.etc = {
|
|||
|
|
|||
|
|
|||
|
/*
|
|||
|
"libvirt/hooks/qemu.d/win11/prepare/begin/start.sh" = {
|
|||
|
text =
|
|||
|
''
|
|||
|
#!/usr/bin/env bash
|
|||
|
# Debugging
|
|||
|
exec 19>/home/materus/startlogfile
|
|||
|
BASH_XTRACEFD=19
|
|||
|
set -x
|
|||
|
|
|||
|
exec 3>&1 4>&2
|
|||
|
trap 'exec 2>&4 1>&3' 0 1 2 3
|
|||
|
exec 1>/home/materus/startlogfile.out 2>&1
|
|||
|
|
|||
|
|
|||
|
|
|||
|
# Stop display manager
|
|||
|
killall -u materus
|
|||
|
systemctl stop display-manager.service
|
|||
|
killall gdm-x-session
|
|||
|
#systemctl isolate multi-user.target
|
|||
|
sleep 1
|
|||
|
|
|||
|
|
|||
|
# Load variables we defined
|
|||
|
source "/etc/libvirt/hooks/kvm.conf"
|
|||
|
|
|||
|
# Isolate host to core 0
|
|||
|
systemctl set-property --runtime -- user.slice AllowedCPUs=0
|
|||
|
systemctl set-property --runtime -- system.slice AllowedCPUs=0
|
|||
|
systemctl set-property --runtime -- init.scope AllowedCPUs=0
|
|||
|
|
|||
|
|
|||
|
|
|||
|
# Unbind VTconsoles
|
|||
|
for (( i = 0; i < 16; i++))
|
|||
|
do
|
|||
|
if test -x /sys/class/vtconsole/vtcon"''${i}"; then
|
|||
|
if [ "$(grep -c "frame buffer" /sys/class/vtconsole/vtcon"''${i}"/name)" = 1 ]; then
|
|||
|
echo 0 > /sys/class/vtconsole/vtcon"''${i}"/bind
|
|||
|
echo "$DATE Unbinding Console ''${i}"
|
|||
|
fi
|
|||
|
fi
|
|||
|
done
|
|||
|
|
|||
|
# Unbind EFI Framebuffer
|
|||
|
echo "efi-framebuffer.0" > /sys/bus/platform/drivers/efi-framebuffer/unbind
|
|||
|
|
|||
|
# Avoid race condition
|
|||
|
sleep 1
|
|||
|
|
|||
|
# Unload NVIDIA kernel modules
|
|||
|
modprobe -r nvidia_uvm
|
|||
|
modprobe -r nvidia_drm
|
|||
|
modprobe -r nvidia_modeset
|
|||
|
modprobe -r nvidia
|
|||
|
modprobe -r i2c_nvidia_gpu
|
|||
|
modprobe -r drm_kms_helper
|
|||
|
modprobe -r drm
|
|||
|
|
|||
|
# Detach GPU devices from host
|
|||
|
#virsh nodedev-detach $VIRSH_GPU_VIDEO
|
|||
|
#virsh nodedev-detach $VIRSH_GPU_AUDIO
|
|||
|
#virsh nodedev-detach $VIRSH_GPU_USB
|
|||
|
#virsh nodedev-detach $VIRSH_GPU_SERIAL_BUS
|
|||
|
|
|||
|
# Load vfio module
|
|||
|
modprobe vfio
|
|||
|
modprobe vfio_pci
|
|||
|
modprobe vfio_iommu_type1
|
|||
|
'';
|
|||
|
mode = "0755";
|
|||
|
};
|
|||
|
|
|||
|
"libvirt/hooks/qemu.d/win11/release/end/stop.sh" = {
|
|||
|
text =
|
|||
|
''
|
|||
|
#!/usr/bin/env bash
|
|||
|
# Debugging
|
|||
|
exec 19>/home/materus/stoplogfile
|
|||
|
BASH_XTRACEFD=19
|
|||
|
set -x
|
|||
|
|
|||
|
exec 3>&1 4>&2
|
|||
|
trap 'exec 2>&4 1>&3' 0 1 2 3
|
|||
|
exec 1>/home/materus/stoplogfile.out 2>&1
|
|||
|
|
|||
|
# Load variables we defined
|
|||
|
source "/etc/libvirt/hooks/kvm.conf"
|
|||
|
|
|||
|
# Unload vfio module
|
|||
|
modprobe -r vfio-pci
|
|||
|
modprobe -r vfio_iommu_type1
|
|||
|
modprobe -r vfio
|
|||
|
|
|||
|
|
|||
|
|
|||
|
modprobe drm
|
|||
|
modprobe drm_kms_helper
|
|||
|
modprobe i2c_nvidia_gpu
|
|||
|
modprobe nvidia
|
|||
|
modprobe nvidia_modeset
|
|||
|
modprobe nvidia_drm
|
|||
|
modprobe nvidia_uvm
|
|||
|
|
|||
|
# Attach GPU devices from host
|
|||
|
#virsh nodedev-reattach $VIRSH_GPU_VIDEO
|
|||
|
#virsh nodedev-reattach $VIRSH_GPU_AUDIO
|
|||
|
#virsh nodedev-reattach $VIRSH_GPU_USB
|
|||
|
#virsh nodedev-reattach $VIRSH_GPU_SERIAL_BUS
|
|||
|
|
|||
|
#echo "0000:01:00.0" > /sys/bus/pci/drivers/nvidia/bind
|
|||
|
# Bind EFI Framebuffer
|
|||
|
echo "efi-framebuffer.0" > /sys/bus/platform/drivers/efi-framebuffer/bind
|
|||
|
|
|||
|
# Bind VTconsoles
|
|||
|
echo 1 > /sys/class/vtconsole/vtcon0/bind
|
|||
|
#echo 1 > /sys/class/vtconsole/vtcon1/bind
|
|||
|
|
|||
|
|
|||
|
# Start display manager
|
|||
|
sleep 1
|
|||
|
systemctl start display-manager.service
|
|||
|
|
|||
|
# Return host to all cores
|
|||
|
systemctl set-property --runtime -- user.slice AllowedCPUs=0-3
|
|||
|
systemctl set-property --runtime -- system.slice AllowedCPUs=0-3
|
|||
|
systemctl set-property --runtime -- init.scope AllowedCPUs=0-3
|
|||
|
'';
|
|||
|
|
|||
|
|
|||
|
|
|||
|
text = ''
|
|||
|
#!/usr/bin/env bash
|
|||
|
reboot
|
|||
|
'';*-/
|
|||
|
mode = "0755";
|
|||
|
};
|
|||
|
"libvirt/vgabios/patched.rom".source = ./vbios.rom;
|
|||
|
};
|
|||
|
};
|
|||
|
*/
|
|||
|
};
|
|||
|
}
|