diff options
author | Ben Lok <ben.lok@mediatek.com> | 2015-07-31 17:38:38 +0800 |
---|---|---|
committer | ChromeOS Commit Bot <chromeos-commit-bot@chromium.org> | 2015-08-05 13:32:56 +0000 |
commit | f0b33ea803acda8239526a14b090ab208a9c3ab7 (patch) | |
tree | b2dbb4bf79dcdab0d4ccca9ece7bbafd20504cee | |
parent | b147dd7fa69c6daa351589c21aeb22720c00dfa5 (diff) | |
download | chrome-ec-f0b33ea803acda8239526a14b090ab208a9c3ab7.tar.gz |
oak: Add LED control for rev3
Oak rev3 has 2 dual-color LEDs to indicate the AP power & battery
status. The behavior has been redefined and distinguish from rev2
by board version API.
BRANCH=none
BUG=none
TEST=manual
1. define CONFIG_BOARD_OAK_REV_2 in board.h
make -j BOARD=oak
2. define CONFIG_BOARD_OAK_REV_3 in board.h
make -j BOARD=oak
both cases should be built successfully.
And Check the PWR & BAT LED.
Change-Id: Ic60d6f91002c3534e4c12a27e5c89bc2d0a1ecfd
Signed-off-by: Ben Lok <ben.lok@mediatek.com>
Reviewed-on: https://chromium-review.googlesource.com/290061
Reviewed-by: Rong Chang <rongchang@chromium.org>
-rw-r--r-- | board/oak/led.c | 221 |
1 files changed, 162 insertions, 59 deletions
diff --git a/board/oak/led.c b/board/oak/led.c index 7c11ff2155..063f454ce8 100644 --- a/board/oak/led.c +++ b/board/oak/led.c @@ -12,6 +12,7 @@ #include "hooks.h" #include "led_common.h" #include "util.h" +#include "system.h" const enum ec_led_id supported_led_ids[] = { EC_LED_ID_BATTERY_LED @@ -20,20 +21,40 @@ const enum ec_led_id supported_led_ids[] = { const int supported_led_ids_count = ARRAY_SIZE(supported_led_ids); enum led_color { - LED_GREEN = 0, - LED_ORANGE, + BAT_LED_GREEN = 0, + BAT_LED_ORANGE, + BAT_LED_RED, + BAT_LED_AMBER, + PWR_LED_GREEN, + PWR_LED_ORANGE, LED_COLOR_COUNT /* Number of colors, not a color itself */ }; static int bat_led_set(enum led_color color, int on) { switch (color) { - case LED_GREEN: - gpio_set_level(GPIO_BAT_LED0, on ? 0 : 1); + case BAT_LED_GREEN: + gpio_set_level(GPIO_BAT_LED0, on ? 0 : 1); /* BAT_LED_GREEN */ break; - case LED_ORANGE: + case BAT_LED_ORANGE: + /* for rev2 or before */ + gpio_set_level(GPIO_BAT_LED1, on ? 0 : 1); /* BAT_LED_ORANGE */ + break; + case BAT_LED_RED: + /* for rev3 or later */ + gpio_set_level(GPIO_BAT_LED1, on ? 0 : 1); /* BAT_LED_RED */ + break; + case BAT_LED_AMBER: + /* for rev3 or later */ + gpio_set_level(GPIO_BAT_LED0, on ? 0 : 1); /* BAT_LED_AMBER */ gpio_set_level(GPIO_BAT_LED1, on ? 0 : 1); break; + case PWR_LED_GREEN: + gpio_set_level(GPIO_PWR_LED0, on ? 0 : 1); /* PWR_LED_GREEN */ + break; + case PWR_LED_ORANGE: + gpio_set_level(GPIO_PWR_LED1, on ? 0 : 1); /* PWR_LED_ORANGE */ + break; default: return EC_ERROR_UNKNOWN; } @@ -43,6 +64,7 @@ static int bat_led_set(enum led_color color, int on) void led_get_brightness_range(enum ec_led_id led_id, uint8_t *brightness_range) { /* Ignoring led_id as both leds support the same colors */ + brightness_range[EC_LED_COLOR_RED] = 1; brightness_range[EC_LED_COLOR_GREEN] = 1; brightness_range[EC_LED_COLOR_YELLOW] = 1; } @@ -51,14 +73,29 @@ int led_set_brightness(enum ec_led_id led_id, const uint8_t *brightness) { if (EC_LED_ID_BATTERY_LED == led_id) { if (brightness[EC_LED_COLOR_GREEN] != 0) { - bat_led_set(LED_GREEN, 1); - bat_led_set(LED_ORANGE, 0); + bat_led_set(BAT_LED_GREEN, 1); + bat_led_set(BAT_LED_ORANGE, 0); + } else if (brightness[EC_LED_COLOR_YELLOW] != 0) { + bat_led_set(BAT_LED_GREEN, 1); + bat_led_set(BAT_LED_ORANGE, 1); + } else if (brightness[EC_LED_COLOR_RED] != 0) { + bat_led_set(BAT_LED_GREEN, 0); + bat_led_set(BAT_LED_RED, 1); + } else { + bat_led_set(BAT_LED_GREEN, 0); + bat_led_set(BAT_LED_ORANGE, 0); + } + return EC_SUCCESS; + } else if (EC_LED_ID_POWER_LED == led_id) { + if (brightness[EC_LED_COLOR_GREEN] != 0) { + bat_led_set(PWR_LED_GREEN, 1); + bat_led_set(PWR_LED_ORANGE, 0); } else if (brightness[EC_LED_COLOR_YELLOW] != 0) { - bat_led_set(LED_GREEN, 1); - bat_led_set(LED_ORANGE, 1); + bat_led_set(PWR_LED_GREEN, 1); + bat_led_set(PWR_LED_ORANGE, 1); } else { - bat_led_set(LED_GREEN, 0); - bat_led_set(LED_ORANGE, 0); + bat_led_set(PWR_LED_GREEN, 0); + bat_led_set(PWR_LED_ORANGE, 0); } return EC_SUCCESS; } else { @@ -66,72 +103,138 @@ int led_set_brightness(enum ec_led_id led_id, const uint8_t *brightness) } } -static void oak_led_set_power(void) +static void oak_led_set_power(int board_version) { static int power_second; power_second++; - /* PWR LED behavior: - * Power on: Green - * Suspend: Green in breeze mode ( 1 sec on/ 3 sec off) - * Power off: OFF - */ - if (chipset_in_state(CHIPSET_STATE_ANY_OFF)) - bat_led_set(LED_GREEN, 0); - else if (chipset_in_state(CHIPSET_STATE_ON)) - bat_led_set(LED_GREEN, 1); - else if (chipset_in_state(CHIPSET_STATE_SUSPEND)) - bat_led_set(LED_GREEN, (power_second & 3) ? 0 : 1); + if (board_version < 3) { + /* PWR LED behavior: + * Power on: Green + * Suspend: Green in breeze mode ( 1 sec on/ 3 sec off) + * Power off: OFF + */ + if (chipset_in_state(CHIPSET_STATE_ANY_OFF)) + bat_led_set(BAT_LED_GREEN, 0); + else if (chipset_in_state(CHIPSET_STATE_ON)) + bat_led_set(BAT_LED_GREEN, 1); + else if (chipset_in_state(CHIPSET_STATE_SUSPEND)) + bat_led_set(BAT_LED_GREEN, (power_second & 3) ? 0 : 1); + } else { + /* + * For Rev3 or later version: + * PWR LED behavior: + * Power on: Green ON + * Suspend: Orange in breeze mode ( 1 sec on/ 3 sec off) + * Power off: OFF + */ + if (chipset_in_state(CHIPSET_STATE_ANY_OFF)) { + bat_led_set(PWR_LED_GREEN, 0); + bat_led_set(PWR_LED_ORANGE, 0); + } else if (chipset_in_state(CHIPSET_STATE_ON)) { + bat_led_set(PWR_LED_GREEN, 1); + bat_led_set(PWR_LED_ORANGE, 0); + } else if (chipset_in_state(CHIPSET_STATE_SUSPEND)) { + bat_led_set(PWR_LED_GREEN, 0); + bat_led_set(PWR_LED_ORANGE, (power_second & 3) ? 0 : 1); + } + } } -static void oak_led_set_battery(void) +static void oak_led_set_battery(int board_version) { static int battery_second; battery_second++; - /* BAT LED behavior: - * Fully charged / idle: Off - * Under charging: Orange - * Battery low (10%): Orange in breeze mode (1 sec on, 3 sec off) - * Battery critical low (less than 3%) or abnormal battery - * situation: Orange in blinking mode (1 sec on, 1 sec off) - * Using battery or not connected to AC power: OFF - */ - switch (charge_get_state()) { - case PWR_STATE_CHARGE: - bat_led_set(LED_ORANGE, 1); - break; - case PWR_STATE_CHARGE_NEAR_FULL: - bat_led_set(LED_ORANGE, 1); - break; - case PWR_STATE_DISCHARGE: - if (charge_get_percent() < 3) - bat_led_set(LED_ORANGE, (battery_second & 1) ? 0 : 1); - else if (charge_get_percent() < 10) - bat_led_set(LED_ORANGE, (battery_second & 3) ? 0 : 1); - else - bat_led_set(LED_ORANGE, 0); - break; - case PWR_STATE_ERROR: - bat_led_set(LED_ORANGE, (battery_second & 1) ? 0 : 1); - break; - case PWR_STATE_IDLE: /* External power connected in IDLE. */ - bat_led_set(LED_ORANGE, 0); - break; - default: - /* Other states don't alter LED behavior */ - break; + if (board_version < 3) { + /* BAT LED behavior: + * Fully charged / idle: Off + * Under charging: Orange + * Battery low (10%): Orange in breeze mode(1 sec on, 3 sec off) + * Battery critical low (less than 3%) or abnormal battery + * situation: Orange in blinking mode (1 sec on, 1 sec off) + * Using battery or not connected to AC power: OFF + */ + switch (charge_get_state()) { + case PWR_STATE_CHARGE: + bat_led_set(BAT_LED_ORANGE, 1); + break; + case PWR_STATE_CHARGE_NEAR_FULL: + bat_led_set(BAT_LED_ORANGE, 1); + break; + case PWR_STATE_DISCHARGE: + if (charge_get_percent() < 3) + bat_led_set(BAT_LED_ORANGE, + (battery_second & 1) ? 0 : 1); + else if (charge_get_percent() < 10) + bat_led_set(BAT_LED_ORANGE, + (battery_second & 3) ? 0 : 1); + else + bat_led_set(BAT_LED_ORANGE, 0); + break; + case PWR_STATE_ERROR: + bat_led_set(BAT_LED_ORANGE, + (battery_second & 1) ? 0 : 1); + break; + case PWR_STATE_IDLE: /* External power connected in IDLE. */ + bat_led_set(BAT_LED_ORANGE, 0); + break; + default: + /* Other states don't alter LED behavior */ + break; + } + } else { + /* + * For Rev3 or later version: + * BAT LED behavior: + * - Fully charged / idle: Green ON + * - Charging: Amber ON (BAT_LED_RED && BAT_LED_GREEN) + * - Battery discharging capacity<10%, red blink + * - Battery error: Red ON + */ + switch (charge_get_state()) { + case PWR_STATE_CHARGE: + bat_led_set(BAT_LED_AMBER, 1); + break; + case PWR_STATE_CHARGE_NEAR_FULL: + bat_led_set(BAT_LED_GREEN, 1); + bat_led_set(BAT_LED_RED, 0); + break; + case PWR_STATE_DISCHARGE: + bat_led_set(BAT_LED_GREEN, 0); + if (charge_get_percent() < 3) + bat_led_set(BAT_LED_RED, + (battery_second & 1) ? 0 : 1); + else if (charge_get_percent() < 10) + bat_led_set(BAT_LED_RED, + (battery_second & 3) ? 0 : 1); + else + bat_led_set(BAT_LED_RED, 0); + break; + case PWR_STATE_ERROR: + bat_led_set(BAT_LED_RED, 1); + break; + case PWR_STATE_IDLE: /* External power connected in IDLE. */ + bat_led_set(BAT_LED_GREEN, 1); + bat_led_set(BAT_LED_RED, 0); + break; + default: + /* Other states don't alter LED behavior */ + break; + } } } -/** * Called by hook task every 1 sec */ +/** + * Called by hook task every 1 sec + */ static void led_second(void) { if (led_auto_control_is_enabled(EC_LED_ID_POWER_LED)) - oak_led_set_power(); + oak_led_set_power(system_get_board_version()); if (led_auto_control_is_enabled(EC_LED_ID_BATTERY_LED)) - oak_led_set_battery(); + oak_led_set_battery(system_get_board_version()); } DECLARE_HOOK(HOOK_SECOND, led_second, HOOK_PRIO_DEFAULT); |