coreboot-libre-fam15h-rdimm/3rdparty/chromeec/board/meep/led.c

127 lines
4.0 KiB
C

/* Copyright 2018 The Chromium OS Authors. All rights reserved.
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*
* Power and battery LED control for Meep/Mimrock
*/
#include "ec_commands.h"
#include "gpio.h"
#include "led_common.h"
#include "led_onoff_states.h"
#include "hooks.h"
#define LED_OFF_LVL 1
#define LED_ON_LVL 0
const int led_charge_lvl_1;
const int led_charge_lvl_2 = 100;
/* Meep: Note there is only LED for charge / power */
struct led_descriptor led_bat_state_table[LED_NUM_STATES][LED_NUM_PHASES] = {
[STATE_CHARGING_LVL_1] = {{EC_LED_COLOR_AMBER, LED_INDEFINITE} },
[STATE_CHARGING_LVL_2] = {{EC_LED_COLOR_AMBER, LED_INDEFINITE} },
[STATE_CHARGING_FULL_CHARGE] = {{EC_LED_COLOR_WHITE, LED_INDEFINITE} },
[STATE_DISCHARGE_S0] = {{LED_OFF, LED_INDEFINITE} },
[STATE_DISCHARGE_S0_BAT_LOW] = {{EC_LED_COLOR_WHITE, 1 * LED_ONE_SEC},
{LED_OFF, 1 * LED_ONE_SEC} },
/* STATE_DISCHARGE_S3 will changed if sku is clamshells */
[STATE_DISCHARGE_S3] = {{LED_OFF, LED_INDEFINITE} },
[STATE_DISCHARGE_S5] = {{LED_OFF, LED_INDEFINITE} },
[STATE_BATTERY_ERROR] = {{EC_LED_COLOR_WHITE, 0.5 * LED_ONE_SEC},
{LED_OFF, 0.5 * LED_ONE_SEC} },
[STATE_FACTORY_TEST] = {{EC_LED_COLOR_AMBER, 1 * LED_ONE_SEC},
{LED_OFF, 1 * LED_ONE_SEC} },
};
const struct led_descriptor
led_pwr_state_table[PWR_LED_NUM_STATES][LED_NUM_PHASES] = {
[PWR_LED_STATE_ON] = {{EC_LED_COLOR_WHITE, LED_INDEFINITE} },
[PWR_LED_STATE_SUSPEND_AC] = {{EC_LED_COLOR_WHITE, 1 * LED_ONE_SEC},
{LED_OFF, 1 * LED_ONE_SEC} },
[PWR_LED_STATE_SUSPEND_NO_AC] = {{EC_LED_COLOR_WHITE, 1 * LED_ONE_SEC},
{LED_OFF, 1 * LED_ONE_SEC} },
[PWR_LED_STATE_OFF] = {{LED_OFF, LED_INDEFINITE} },
};
const enum ec_led_id supported_led_ids[] = {
EC_LED_ID_BATTERY_LED,
EC_LED_ID_POWER_LED
};
static void s3_led_init(void)
{
if (!board_is_convertible()) {
led_bat_state_table[STATE_DISCHARGE_S3][LED_PHASE_0].color =
EC_LED_COLOR_WHITE;
led_bat_state_table[STATE_DISCHARGE_S3][LED_PHASE_0].time =
1 * LED_ONE_SEC;
led_bat_state_table[STATE_DISCHARGE_S3][LED_PHASE_1].color =
LED_OFF;
led_bat_state_table[STATE_DISCHARGE_S3][LED_PHASE_1].time =
1 * LED_ONE_SEC;
}
}
DECLARE_HOOK(HOOK_INIT, s3_led_init, HOOK_PRIO_DEFAULT);
const int supported_led_ids_count = ARRAY_SIZE(supported_led_ids);
void led_set_color_power(enum ec_led_colors color)
{
if (color == EC_LED_COLOR_WHITE)
gpio_set_level(GPIO_PWR_LED_WHITE_L, LED_ON_LVL);
else
/* LED_OFF and unsupported colors */
gpio_set_level(GPIO_PWR_LED_WHITE_L, LED_OFF_LVL);
}
void led_set_color_battery(enum ec_led_colors color)
{
switch (color) {
case EC_LED_COLOR_WHITE:
gpio_set_level(GPIO_BAT_LED_WHITE_L, LED_ON_LVL);
gpio_set_level(GPIO_BAT_LED_AMBER_L, LED_OFF_LVL);
break;
case EC_LED_COLOR_AMBER:
gpio_set_level(GPIO_BAT_LED_WHITE_L, LED_OFF_LVL);
gpio_set_level(GPIO_BAT_LED_AMBER_L, LED_ON_LVL);
break;
default: /* LED_OFF and other unsupported colors */
gpio_set_level(GPIO_BAT_LED_WHITE_L, LED_OFF_LVL);
gpio_set_level(GPIO_BAT_LED_AMBER_L, LED_OFF_LVL);
break;
}
}
void led_get_brightness_range(enum ec_led_id led_id, uint8_t *brightness_range)
{
if (led_id == EC_LED_ID_BATTERY_LED) {
brightness_range[EC_LED_COLOR_WHITE] = 1;
brightness_range[EC_LED_COLOR_AMBER] = 1;
} else if (led_id == EC_LED_ID_POWER_LED) {
brightness_range[EC_LED_COLOR_WHITE] = 1;
}
}
int led_set_brightness(enum ec_led_id led_id, const uint8_t *brightness)
{
if (led_id == EC_LED_ID_BATTERY_LED) {
if (brightness[EC_LED_COLOR_WHITE] != 0)
led_set_color_battery(EC_LED_COLOR_WHITE);
else if (brightness[EC_LED_COLOR_AMBER] != 0)
led_set_color_battery(EC_LED_COLOR_AMBER);
else
led_set_color_battery(LED_OFF);
} else if (led_id == EC_LED_ID_POWER_LED) {
if (brightness[EC_LED_COLOR_WHITE] != 0)
led_set_color_power(EC_LED_COLOR_WHITE);
else
led_set_color_power(LED_OFF);
}
return EC_SUCCESS;
}