Skip to main content

Battery Sensing

If your keyboard is using one of the boards supported in ZMK it will already be configured to sense and report battery levels. Below instructions are only intended for users defining and using a custom board.

To enable a battery sensor on a new board, add the driver for the sensor to your board's .dts file. ZMK provides two drivers for estimating the battery level using its voltage:

  • zmk,battery-voltage-divider: Reads the voltage on an analog input pin.
  • zmk,battery-nrf-vddh: Reads the power supply voltage on a Nordic nRF52's VDDH pin.

See the battery level configuration page for the configuration supported by each driver provided by ZMK.

Zephyr also provides some drivers for fuel gauge ICs such as the TI bq274xx series and Maxim MAX17xxx series. If you use a battery sensor that does not have an existing driver, you will need to write a new driver that supports the SENSOR_CHAN_GAUGE_STATE_OF_CHARGE sensor channel and contribute it to Zephyr or ZMK.

Once you have the sensor driver defined, add a zmk,battery property to the chosen node and set it to reference the sensor node. For example:

/ {
chosen {
zmk,battery = &vbatt;
};

vbatt: vbatt {
compatible = "zmk,battery-nrf-vddh";
};
}