Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/macppc/dev listen to PMF events in order to turn of...



details:   https://anonhg.NetBSD.org/src/rev/725521eef128
branches:  trunk
changeset: 1007080:725521eef128
user:      macallan <macallan%NetBSD.org@localhost>
date:      Thu Feb 06 02:17:24 2020 +0000

description:
listen to PMF events in order to turn off keyboard lights when the lid is
closed or the screen is blanked

diffstat:

 sys/arch/macppc/dev/lmu.c |  56 ++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 51 insertions(+), 5 deletions(-)

diffs (107 lines):

diff -r 468496df6a42 -r 725521eef128 sys/arch/macppc/dev/lmu.c
--- a/sys/arch/macppc/dev/lmu.c Thu Feb 06 01:37:46 2020 +0000
+++ b/sys/arch/macppc/dev/lmu.c Thu Feb 06 02:17:24 2020 +0000
@@ -1,4 +1,4 @@
- /* $NetBSD: lmu.c,v 1.1 2020/01/10 06:24:17 macallan Exp $ */
+ /* $NetBSD: lmu.c,v 1.2 2020/02/06 02:17:24 macallan Exp $ */
 
 /*-
  * Copyright (c) 2020 Michael Lorenz
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: lmu.c,v 1.1 2020/01/10 06:24:17 macallan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lmu.c,v 1.2 2020/02/06 02:17:24 macallan Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -56,7 +56,8 @@
        struct sysmon_envsys *sc_sme;
        envsys_data_t   sc_sensors[2];
        callout_t       sc_adjust;
-       int sc_thresh, sc_hyst;
+       int sc_thresh, sc_hyst, sc_level;
+       int             sc_lid_state, sc_video_state;
 };
 
 static int     lmu_match(device_t, cfdata_t, void *);
@@ -76,6 +77,38 @@
        { NULL,                 0 }
 };
 
+static void
+lmu_lid_open(device_t dev)
+{
+       struct lmu_softc * const sc = device_private(dev);
+
+       sc->sc_lid_state = true;
+}
+
+static void
+lmu_lid_close(device_t dev)
+{
+       struct lmu_softc * const sc = device_private(dev);
+
+       sc->sc_lid_state = false;
+}
+
+static void
+lmu_video_on(device_t dev)
+{
+       struct lmu_softc * const sc = device_private(dev);
+
+       sc->sc_video_state = true;
+}
+
+static void
+lmu_video_off(device_t dev)
+{
+       struct lmu_softc * const sc = device_private(dev);
+
+       sc->sc_video_state = false;
+}
+
 static int
 lmu_match(device_t parent, cfdata_t match, void *aux)
 {
@@ -103,6 +136,17 @@
        aprint_naive("\n");
        aprint_normal(": ambient light sensor\n");
 
+       sc->sc_lid_state = true;
+       pmf_event_register(sc->sc_dev, PMFE_CHASSIS_LID_OPEN,
+           lmu_lid_open, true);
+       pmf_event_register(sc->sc_dev, PMFE_CHASSIS_LID_CLOSE,
+           lmu_lid_close, true);
+       sc->sc_video_state = true;
+       pmf_event_register(sc->sc_dev, PMFE_DISPLAY_ON,
+           lmu_video_on, true);
+       pmf_event_register(sc->sc_dev, PMFE_DISPLAY_OFF,
+           lmu_video_off, true);
+
        sc->sc_sme = sysmon_envsys_create();
        sc->sc_sme->sme_name = device_xname(self);
        sc->sc_sme->sme_cookie = sc;
@@ -127,6 +171,7 @@
        /* TODO: make this adjustable via sysctl */
        sc->sc_thresh = 300;
        sc->sc_hyst = 30;
+       sc->sc_level = 100;
 
        callout_init(&sc->sc_adjust, 0);
        callout_setfunc(&sc->sc_adjust, lmu_adjust, sc);
@@ -189,10 +234,11 @@
        right = lmu_get_brightness(sc, 0);
        b = left > right ? left : right;
 
-       if (b > (sc->sc_thresh + sc->sc_hyst)) {
+       if ((b > (sc->sc_thresh + sc->sc_hyst)) ||
+          !(sc->sc_lid_state && sc->sc_video_state)) {
                lmu_set_brightness(sc, 0);
        } else if (b < sc->sc_thresh) {
-               lmu_set_brightness(sc, 100);
+               lmu_set_brightness(sc, sc->sc_level);
        }
 
        callout_schedule(&sc->sc_adjust, hz * 2);       



Home | Main Index | Thread Index | Old Index