new file mode 100644
@@ -0,0 +1,74 @@
+What: /sys/kernel/pscrr/reason
+Date: April 2025
+KernelVersion: 6.16
+Contact: Oleksij Rempel <o.rempel@pengutronix.de>
+Description:
+ This file provides access to the current power state
+ change reason. If supported, the reason may be stored
+ persistently in an NVMEM cell or another backend.
+
+ Reading this file returns an integer representing the
+ current shutdown or reboot cause.
+
+ Writing an integer value to this file sets the reason
+ to be stored for system analysis on next reboot.
+
+ Example usage:
+ Read:
+ $ cat /sys/kernel/pscrr/reason
+ 1 # (Example: Under-voltage shutdown)
+
+ Write:
+ $ echo 4 > /sys/kernel/pscrr/reason
+ # Sets the reason to 4 (Example: Over-temperature shutdown)
+
+ Note:
+ Not all systems support all reason values. Hardware or
+ configuration may limit which reasons are applicable.
+
+ Values are defined in:
+ - include/linux/reboot.h (enum psc_reason)
+
+ Supported Values:
+ (from include/linux/reboot.h)
+
+ +-------+---------------------------+--------------------------+
+ | Value | Symbol | Description |
+ +-------+---------------------------+--------------------------+
+ | 0 | PSCR_UNKNOWN | Unknown or unspecified |
+ | | | power state change reason|
+ +-------+---------------------------+--------------------------+
+ | 1 | PSCR_UNDER_VOLTAGE | Supply voltage dropped |
+ | | | below safe threshold |
+ +-------+---------------------------+--------------------------+
+ | 2 | PSCR_OVER_CURRENT | Excessive current draw or|
+ | | | potential short circuit |
+ +-------+---------------------------+--------------------------+
+ | 3 | PSCR_REGULATOR_FAILURE | Voltage regulator failure|
+ | | | preventing stable supply |
+ +-------+---------------------------+--------------------------+
+ | 4 | PSCR_OVER_TEMPERATURE | Unsafe system temperature|
+ | | | detected by sensors |
+ +-------+---------------------------+--------------------------+
+ | 5 | PSCR_EC_PANIC | Reboot triggered by EC |
+ | | | (Embedded Controller) |
+ +-------+---------------------------+--------------------------+
+
+What: /sys/kernel/pscrr/reason_boot
+Date: April 2025
+KernelVersion: 6.16
+Contact: Oleksij Rempel <o.rempel@pengutronix.de>
+Description:
+ This file provides the last recorded power state change
+ reason from before the current boot. If a supported backend
+ is configured (e.g., NVMEM), the value is retained across
+ reboots.
+
+ Example usage:
+ Read:
+ $ cat /sys/kernel/pscrr/reason_boot
+ 4 # (Example: Over-temperature shutdown)
+
+ Supported values:
+ Same as /sys/kernel/pscrr/reason (see above).
+