From c413233d3431041a4a3021837113702408991a83 Mon Sep 17 00:00:00 2001 From: Nikita Langer Date: Mon, 6 Apr 2026 22:11:14 +0200 Subject: initial commit --- components/backlight.c | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 components/backlight.c (limited to 'components/backlight.c') diff --git a/components/backlight.c b/components/backlight.c new file mode 100644 index 0000000..74f4c08 --- /dev/null +++ b/components/backlight.c @@ -0,0 +1,59 @@ +/* See LICENSE file for copyright and license details. */ + +#include + +#include "../util.h" + +#if defined(__linux__) + #include + + #define BRIGHTNESS_MAX "/sys/class/backlight/%s/max_brightness" + #define BRIGHTNESS_CUR "/sys/class/backlight/%s/brightness" + + const char * + backlight_perc(const char *card) + { + char path[PATH_MAX]; + int max, cur; + + if (esnprintf(path, sizeof (path), BRIGHTNESS_MAX, card) < 0 || + pscanf(path, "%d", &max) != 1) { + return NULL; + } + + if (esnprintf(path, sizeof (path), BRIGHTNESS_CUR, card) < 0 || + pscanf(path, "%d", &cur) != 1) { + return NULL; + } + + if (max == 0) { + return NULL; + } + + return bprintf("%d%%", cur * 100 / max); + } +#elif defined(__OpenBSD__) + #include + #include + #include + #include + + const char * + backlight_perc(const char *unused) + { + int fd, err; + struct wsdisplay_param wsd_param = { + .param = WSDISPLAYIO_PARAM_BRIGHTNESS + }; + + if ((fd = open("/dev/ttyC0", O_RDONLY)) < 0) { + warn("could not open /dev/ttyC0"); + return NULL; + } + if ((err = ioctl(fd, WSDISPLAYIO_GETPARAM, &wsd_param)) < 0) { + warn("ioctl 'WSDISPLAYIO_GETPARAM' failed"); + return NULL; + } + return bprintf("%d", wsd_param.curval * 100 / wsd_param.max); + } +#endif -- cgit