| 30 Nov 2025 |
not-jack | * aha, so it's legacy for backwards compat with grub | 14:16:48 |
mou | It is not grub specific. It is applicable to any bootloader for MBR partitioned drive. All bootloader put their initialization code into first 512K right after partition table | 14:17:51 |
not-jack | * aha, so it's legacy for backwards compat with grub MBR | 14:19:33 |
mou | But i did not refreshed my knowledge in this area for last decade, so i might mix things up. So, if you want to be sure, do additional check. | 14:19:34 |
not-jack | the check will be seeing if i can boot! | 14:19:50 |
mou | Here is more in depth explanation of the logic. https://superuser.com/questions/1566558/is-a-boot-sector-considered-to-be-a-partition | 14:22:28 |
not-jack | thanks, that helps :) | 14:26:46 |
spewdins | For those using disko for vmโs disk sizesโฆ
I wonder. Are you declaratively setting your vm .qcow2 for example, from the host system? Or from inside the vm. | 17:03:16 |
not-jack | When using disko-install, i get no space left on device | 19:59:11 |
not-jack | I've tried remounting the store with more space, but that doesn't seem to do anything | 20:00:00 |
not-jack | Anyone have tips? | 20:00:07 |
not-jack | Actually, looks like i'm oom'ing now | 20:06:19 |
| ChickenIQ joined the room. | 21:39:45 |
ChickenIQ | I've been trying to generate a disk image for my pi 4 with disko, but i keep getting an error: "Firmware not found"
Any idea on how i could fix it?
Repo: https://github.com/ChickenIQ/NixOSPI4 | 21:45:53 |
ChickenIQ | * I've been trying to generate a disk image for my pi 4 with disko, but i keep getting an error on boot: "Firmware not found"
Any idea on how i could fix it?
Repo: https://github.com/ChickenIQ/NixOSPI4 | 21:47:01 |
| 1 Dec 2025 |
ChickenIQ | this seems to be enough to get it to work
esp = {
size = "1024M";
type = "EF00";
content = {
format = "vfat";
type = "filesystem";
mountpoint = "/boot";
mountOptions = [ "umask=0077" ];
postMountHook =
let
configTxt = pkgs.writeText "config.txt" ''
[pi4]
kernel=u-boot-rpi4.bin
disable_overscan=1
enable_gic=1
arm_boost=1
[all]
avoid_warnings=1
enable_uart=1
arm_64bit=1
'';
in
toString (
pkgs.writeScript "postMountHook.sh" ''
(cd ${pkgs.raspberrypifw}/share/raspberrypi/boot && cp bootcode.bin fixup4.dat start4.elf bcm2711-*.dtb /mnt/boot/)
cp ${pkgs.ubootRaspberryPi4_64bit}/u-boot.bin /mnt/boot/u-boot-rpi4.bin
cp ${configTxt} /mnt/boot/config.txt
''
);
};
};
| 00:20:12 |
ChickenIQ | proper hack, works without disko too
{
config,
pkgs,
lib,
...
}:
let
installBootLoader =
(import (pkgs.path + "/nixos/modules/system/boot/loader/generic-extlinux-compatible") {
inherit config lib pkgs;
}).config.content.system.build.installBootLoader;
populateFirmware =
(import (pkgs.path + "/nixos/modules/installer/sd-card/sd-image-aarch64.nix") {
inherit config lib pkgs;
}).sdImage.populateFirmwareCommands;
installCmd = pkgs.writeShellScript "populate-boot.sh" ''
set -e && export PATH=${pkgs.coreutils}/bin:$PATH
${installBootLoader} "$@"
ln -s "/boot" "$NIX_BUILD_TOP/firmware"
cd "$NIX_BUILD_TOP" && ${populateFirmware}
echo "include usercfg.txt" >> /boot/config.txt
'';
in
{
system.build.installBootLoader = lib.mkForce installCmd;
}
| 03:27:03 |
ChickenIQ | * proper hack, works without disko too
{
config,
pkgs,
lib,
...
}:
let
installBootLoader =
(import (pkgs.path + "/nixos/modules/system/boot/loader/generic-extlinux-compatible") {
inherit config lib pkgs;
}).config.content.system.build.installBootLoader;
populateFirmware =
(import (pkgs.path + "/nixos/modules/installer/sd-card/sd-image-aarch64.nix") {
inherit config lib pkgs;
}).sdImage.populateFirmwareCommands;
installCmd = pkgs.writeShellScript "populate-boot.sh" ''
set -e && export PATH=${pkgs.coreutils}/bin:$PATH
${installBootLoader} "$@"
ln -s "/boot" "$NIX_BUILD_TOP/firmware"
cd "$NIX_BUILD_TOP" && ${populateFirmware}
echo "include usercfg.txt" >> /boot/config.txt
'';
in
{
system.build.installBootLoader = lib.mkForce installCmd;
}
| 03:27:14 |
| stooj joined the room. | 16:54:37 |
stooj | Redacted or Malformed Event | 17:32:21 |
stooj | Possibly a general flake question: what is the syntax for applying a flake from a non-github repo and using a specific branch?
So far I'm trying:
nix run --extra-experimental-features 'nix-command flakes' 'github:nix-community/disko/latest#disko-install' -- --write-efi-boot-entries --flake 'https://codeberg.org/higara/legacy-nix-configuration.git?ref=add-klaes#klaes' --disk nvme0 /dev/nvme0n1
And getting:
error: Failed to open archive (Unrecognizde archive format)
.disko-install-wrapped: line 234: artifacts[1]: unbound variable
| 17:39:25 |
stooj | * Possibly a general flake question: what is the syntax for applying a flake from a non-github repo and using a specific branch?
So far I'm trying:
nix run --extra-experimental-features 'nix-command flakes' \
'github:nix-community/disko/latest#disko-install' -- \
--write-efi-boot-entries \
--flake 'https://codeberg.org/higara/legacy-nix-configuration.git?ref=add-klaes#klaes' \
--disk nvme0 /dev/nvme0n1
And getting:
error: Failed to open archive (Unrecognizde archive format)
.disko-install-wrapped: line 234: artifacts[1]: unbound variable
| 17:40:32 |
BerriJ | I guess you need 'git+https://...' instead of just starting directly with 'https://' | 17:44:09 |
stooj | Thanks, I will try that. | 17:45:08 |
| Brisingr changed their display name from Brisingr05 to Brisingr. | 18:39:52 |
stooj | Thanks @berrij:fairydust.space | 19:08:31 |
BerriJ | Quick question: I want to streamline my deployment process for new machines a bit using disko, flakes and nixos-anywhere. Currently I only use disko without flakes and I crafted this disko config (https://codeberg.org/BerriJ/nixos-config/src/branch/main/hosts/common/disks/disko-luks-lvm-swap-btrfs.nix#L1-L9) which uses some variables for swap-size, etc.
Ideally, I would add this config to my flake, and be able to define things like swapsize etc. per host (maybe inside the nixosConfigurations outputs of my flake?)
Maybe someone of you has something like that, you would help me a lot ๐๐ | 20:49:57 |
BerriJ | Nevermind, I found this: https://github.com/nix-community/nixos-anywhere-examples/blob/main/flake.nix#L28, which should be exactly what I was looking for. Now I need to wrap my head around provisioning luks encryption passwords ๐ | 21:13:51 |
| 2 Dec 2025 |
ChickenIQ | * proper hack, works without disko too
{
config,
pkgs,
lib,
...
}:
let
installBootLoader =
(import (pkgs.path + "/nixos/modules/system/boot/loader/generic-extlinux-compatible") {
inherit config lib pkgs;
}).config.content.system.build.installBootLoader;
populateFirmware =
(import (pkgs.path + "/nixos/modules/installer/sd-card/sd-image-aarch64.nix") {
inherit config lib pkgs;
}).sdImage.populateFirmwareCommands;
installCommand = pkgs.writeShellScript "populate-boot.sh" ''
set -e && export PATH=${pkgs.coreutils}/bin:$PATH
${builtins.replaceStrings [ "firmware/" ] [ "boot/" ] populateFirmware}
echo "include usercfg.txt" >> boot/config.txt
${installBootLoader} "$@"
'';
in
{
system.build.installBootLoader = lib.mkForce installCommand;
}
| 00:56:06 |
sinan | How do you guys handle diffrent /dev/* paths,
i use nixos anywhere to add nodes to my cluster but some nodes will have /dev/nvme0n1 as root and some /dev/sda1 and so on
Is there way to automatically select which ever is avaialable ?
| 12:47:49 |