diff options
Diffstat (limited to 'common/backlight_lid.c')
-rw-r--r-- | common/backlight_lid.c | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/common/backlight_lid.c b/common/backlight_lid.c index 30b8b75eb7..9f2c984ec0 100644 --- a/common/backlight_lid.c +++ b/common/backlight_lid.c @@ -11,6 +11,19 @@ #include "host_command.h" #include "lid_switch.h" + +/** + * Activate/Deactivate the backlight GPIO pin considering active high or low. + */ +void enable_backlight(int enabled) +{ +#ifdef CONFIG_BACKLIGHT_LID_ACTIVE_LOW + gpio_set_level(GPIO_ENABLE_BACKLIGHT_L, !enabled); +#else + gpio_set_level(GPIO_ENABLE_BACKLIGHT, enabled); +#endif +} + /** * Update backlight state. */ @@ -18,14 +31,14 @@ static void update_backlight(void) { #ifdef CONFIG_BACKLIGHT_REQ_GPIO /* Enable the backlight if lid is open AND requested by AP */ - gpio_set_level(GPIO_ENABLE_BACKLIGHT, lid_is_open() && - gpio_get_level(CONFIG_BACKLIGHT_REQ_GPIO)); + enable_backlight(lid_is_open() && + gpio_get_level(CONFIG_BACKLIGHT_REQ_GPIO)); #else /* * Enable backlight if lid is open; this is AND'd with the request from * the AP in hardware. */ - gpio_set_level(GPIO_ENABLE_BACKLIGHT, lid_is_open()); + enable_backlight(lid_is_open()); #endif } DECLARE_HOOK(HOOK_LID_CHANGE, update_backlight, HOOK_PRIO_DEFAULT); @@ -60,7 +73,7 @@ static int switch_command_enable_backlight(struct host_cmd_handler_args *args) { const struct ec_params_switch_enable_backlight *p = args->params; - gpio_set_level(GPIO_ENABLE_BACKLIGHT, p->enabled); + enable_backlight(p->enabled); return EC_RES_SUCCESS; } |