1
0

config.logging.persistent enables /dev/pmsg0

- whatever's written to /dev/pmsg0 appears as
/sys/fs/pstore/pmsg-ramoops-0 after reboot

- only works on devices with the relevant device tree
support (gl-ar750 and whatever has it by default)

- nothing in the system is actually writing this file yet

- or reading it at boot time, for that matter
This commit is contained in:
Daniel Barlow 2024-12-17 23:24:31 +00:00
parent b52133a28b
commit 81f5550bf0
4 changed files with 24 additions and 2 deletions

View File

@ -52,8 +52,9 @@
''; '';
module = {pkgs, config, lim, ... }: module = {pkgs, config, lim, lib, ... }:
let let
inherit (lib) mkIf;
openwrt = pkgs.openwrt; openwrt = pkgs.openwrt;
firmwareBlobs = pkgs.pkgsBuildBuild.fetchFromGitHub { firmwareBlobs = pkgs.pkgsBuildBuild.fetchFromGitHub {
owner = "kvalo"; owner = "kvalo";
@ -119,6 +120,9 @@
includePaths = [ includePaths = [
"${openwrt.src}/target/linux/ath79/dts" "${openwrt.src}/target/linux/ath79/dts"
]; ];
includes = mkIf config.logging.persistent.enable [
./pstore-ramoops.dtsi
];
}; };
networkInterfaces = networkInterfaces =

View File

@ -0,0 +1,10 @@
/ {
reserved-memory {
ramoops@03f00000 {
compatible = "ramoops";
reg = <0x03f00000 0x10000>;
record-size = <0x1000>;
pmsg-size = <0x1000>;
};
};
};

View File

@ -104,7 +104,7 @@ in
system.outputs = rec { system.outputs = rec {
dtb = liminix.builders.dtb { dtb = liminix.builders.dtb {
inherit (config.boot) commandLine; inherit (config.boot) commandLine;
dts = config.hardware.dts.includes ++ [config.hardware.dts.src]; dts = [config.hardware.dts.src] ++ config.hardware.dts.includes;
includes = config.hardware.dts.includePaths ++ [ includes = config.hardware.dts.includePaths ++ [
"${o.kernel.headers}/include" "${o.kernel.headers}/include"
]; ];

View File

@ -212,6 +212,9 @@ let
in { in {
options = { options = {
logging = { logging = {
persistent = {
enable = mkEnableOption "store logs across reboots";
};
shipping = { shipping = {
enable = mkEnableOption "unix socket for log shipping"; enable = mkEnableOption "unix socket for log shipping";
socket = mkOption { socket = mkOption {
@ -263,6 +266,11 @@ in {
)]; )];
config = { config = {
kernel.config = mkIf config.logging.persistent.enable {
PSTORE = "y";
PSTORE_PMSG = "y";
PSTORE_RAM = "y";
};
filesystem = dir { filesystem = dir {
etc = dir { etc = dir {
s6-rc = dir { s6-rc = dir {