summaryrefslogtreecommitdiff
path: root/board
diff options
context:
space:
mode:
authorAseda Aboagye <aaboagye@google.com>2017-11-15 22:23:00 -0800
committerchrome-bot <chrome-bot@chromium.org>2017-11-17 20:18:38 -0800
commit34a97f50d5275f1fa2f1cb377683c96286b2421d (patch)
tree2ea62dc537426fb252123fb93b3b4f05db5f1443 /board
parentf587852570770564e8a94b2c3f7ad7d97883c49a (diff)
downloadchrome-ec-34a97f50d5275f1fa2f1cb377683c96286b2421d.tar.gz
buttons: Make buttons[] common.
Nearly every board had a buttons array defined in which its contents had the standard volume buttons. This commit creates a single common buttons array that can contain the standard volume buttons and recovery buttons. If a board has volume up and down buttons, they can simply define CONFIG_VOLUME_BUTTONS and it will populate the buttons array with the standard definition. The buttons are active low and have a 30 ms debounce period. Similiarly, if a board has a dedicated recovery button, defining CONFIG_DEDICATED_RECOVERY_BUTTON will also populate the buttons array with a recovery button. BUG=chromium:783371 BRANCH=None TEST=make -j buildall. TEST=Flash a device with CONFIG_VOLUME_BUTTONS, verify pressing volume buttons still work. Change-Id: Ie5d63670ca4c6b146ec8ffb64d40ea9ce437b913 Signed-off-by: Aseda Aboagye <aaboagye@google.com> Reviewed-on: https://chromium-review.googlesource.com/773794 Commit-Ready: Aseda Aboagye <aaboagye@chromium.org> Tested-by: Aseda Aboagye <aaboagye@chromium.org> Reviewed-by: Daisuke Nojiri <dnojiri@chromium.org> Reviewed-by: Shawn N <shawnn@chromium.org>
Diffstat (limited to 'board')
-rw-r--r--board/coral/board.c7
-rw-r--r--board/coral/board.h4
-rw-r--r--board/eve/board.c7
-rw-r--r--board/eve/board.h2
-rw-r--r--board/fizz/board.c10
-rw-r--r--board/fizz/board.h6
-rw-r--r--board/glados/board.c7
-rw-r--r--board/glados/board.h2
-rw-r--r--board/glkrvp/board.c18
-rw-r--r--board/glkrvp/board.h4
-rw-r--r--board/grunt/board.c7
-rw-r--r--board/grunt/board.h5
-rw-r--r--board/host/board.c10
-rw-r--r--board/host/gpio.inc4
-rw-r--r--board/kahlee/board.h1
-rw-r--r--board/kevin/board.c7
-rw-r--r--board/kevin/board.h2
-rw-r--r--board/nautilus/board.c7
-rw-r--r--board/nautilus/board.h8
-rw-r--r--board/nefario/board.c7
-rw-r--r--board/nefario/board.h2
-rw-r--r--board/poppy/board.c7
-rw-r--r--board/poppy/board.h8
-rw-r--r--board/rainier/board.c7
-rw-r--r--board/rainier/board.h8
-rw-r--r--board/reef/board.c7
-rw-r--r--board/reef/board.h4
-rw-r--r--board/reef_it8320/board.c7
-rw-r--r--board/reef_it8320/board.h4
-rw-r--r--board/rowan/board.c7
-rw-r--r--board/rowan/board.h8
-rw-r--r--board/scarlet/board.c7
-rw-r--r--board/scarlet/board.h8
-rw-r--r--board/strago/board.c8
-rw-r--r--board/strago/board.h4
-rw-r--r--board/wheatley/board.c7
-rw-r--r--board/wheatley/board.h2
37 files changed, 31 insertions, 199 deletions
diff --git a/board/coral/board.c b/board/coral/board.c
index 43ea4fca91..7ab358e912 100644
--- a/board/coral/board.c
+++ b/board/coral/board.c
@@ -501,13 +501,6 @@ const struct temp_sensor_t temp_sensors[] = {
};
BUILD_ASSERT(ARRAY_SIZE(temp_sensors) == TEMP_SENSOR_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_EC_VOLDN_BTN_ODL,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_EC_VOLUP_BTN_ODL,
- 30 * MSEC, 0},
-};
-
/* Called by APL power state machine when transitioning from G3 to S5 */
static void chipset_pre_init(void)
{
diff --git a/board/coral/board.h b/board/coral/board.h
index 3706cd4ae8..d10081f0a0 100644
--- a/board/coral/board.h
+++ b/board/coral/board.h
@@ -120,7 +120,6 @@
#define CONFIG_ADC
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_EXTPOWER_GPIO
#undef CONFIG_EXTPOWER_DEBOUNCE_MS
#define CONFIG_EXTPOWER_DEBOUNCE_MS 1000
@@ -148,6 +147,9 @@
#define CONFIG_SCI_GPIO GPIO_PCH_SCI_L
#define CONFIG_UART_HOST 0
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
+#define GPIO_VOLUME_DOWN_L GPIO_EC_VOLDN_BTN_ODL
+#define GPIO_VOLUME_UP_L GPIO_EC_VOLUP_BTN_ODL
#define CONFIG_BACKLIGHT_LID
#define CONFIG_WIRELESS
#define CONFIG_WIRELESS_SUSPEND EC_WIRELESS_SWITCH_WLAN_POWER
diff --git a/board/eve/board.c b/board/eve/board.c
index f580c30651..243bc3dc21 100644
--- a/board/eve/board.c
+++ b/board/eve/board.c
@@ -346,13 +346,6 @@ const struct temp_sensor_t temp_sensors[] = {
};
BUILD_ASSERT(ARRAY_SIZE(temp_sensors) == TEMP_SENSOR_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_VOLUME_DOWN_L,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_VOLUME_UP_L,
- 30 * MSEC, 0},
-};
-
static void board_pmic_init(void)
{
if (system_jumped_to_this_image())
diff --git a/board/eve/board.h b/board/eve/board.h
index 6182e7c2ac..12e791944f 100644
--- a/board/eve/board.h
+++ b/board/eve/board.h
@@ -27,7 +27,6 @@
#define CONFIG_BACKLIGHT_LID
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_DEVICE_EVENT
#define CONFIG_DPTF
#define CONFIG_DPTF_DEVICE_ORIENTATION
@@ -46,6 +45,7 @@
#define CONFIG_SPI_FLASH_W25X40
#define CONFIG_UART_HOST 0
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_VSTORE
#define CONFIG_VSTORE_SLOT_COUNT 1
#define CONFIG_WATCHDOG_HELP
diff --git a/board/fizz/board.c b/board/fizz/board.c
index 918d38892d..8e345c1ad4 100644
--- a/board/fizz/board.c
+++ b/board/fizz/board.c
@@ -498,16 +498,6 @@ void board_set_charge_limit(int port, int supplier, int charge_ma,
}
}
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- [BUTTON_RECOVERY] = {
- .name = "Recovery",
- .type = KEYBOARD_BUTTON_RECOVERY,
- .gpio = GPIO_RECOVERY_L,
- .debounce_us = 30 * MSEC,
- .flags = 0,
- },
-};
-
const struct button_config *recovery_buttons[] = {
&buttons[BUTTON_RECOVERY],
};
diff --git a/board/fizz/board.h b/board/fizz/board.h
index 93dce5bd49..33b4ee1741 100644
--- a/board/fizz/board.h
+++ b/board/fizz/board.h
@@ -18,7 +18,6 @@
/* EC */
#define CONFIG_ADC
#define CONFIG_BOARD_VERSION
-#define CONFIG_BUTTON_COUNT 1
#define CONFIG_BUTTON_RECOVERY
#define CONFIG_DEDICATED_RECOVERY_BUTTON
#define CONFIG_EMULATED_SYSRQ
@@ -202,11 +201,6 @@ enum adc_channel {
ADC_CH_COUNT
};
-enum button {
- BUTTON_RECOVERY = 0,
- BUTTON_COUNT
-};
-
enum pwm_channel {
PWM_CH_LED_RED,
PWM_CH_LED_GREEN,
diff --git a/board/glados/board.c b/board/glados/board.c
index e435cad8eb..1914a615ab 100644
--- a/board/glados/board.c
+++ b/board/glados/board.c
@@ -202,13 +202,6 @@ struct als_t als[] = {
};
BUILD_ASSERT(ARRAY_SIZE(als) == ALS_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_VOLUME_DOWN_L,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_VOLUME_UP_L,
- 30 * MSEC, 0},
-};
-
static void board_pmic_init(void)
{
/* No need to re-init PMIC since settings are sticky across sysjump */
diff --git a/board/glados/board.h b/board/glados/board.h
index 4ed3186b06..24f1ac1b57 100644
--- a/board/glados/board.h
+++ b/board/glados/board.h
@@ -23,7 +23,6 @@
#define CONFIG_BATTERY_PRESENT_GPIO GPIO_BAT_PRESENT_L
#define CONFIG_BATTERY_SMART
#define CONFIG_BOARD_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_CHARGE_MANAGER
#define CONFIG_CHARGE_RAMP_HW
@@ -88,6 +87,7 @@
#define CONFIG_USBC_VCONN
#define CONFIG_USBC_VCONN_SWAP
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_SPI_FLASH_PORT 1
#define CONFIG_SPI_FLASH
diff --git a/board/glkrvp/board.c b/board/glkrvp/board.c
index 9c5f22eb58..1038811f60 100644
--- a/board/glkrvp/board.c
+++ b/board/glkrvp/board.c
@@ -74,24 +74,6 @@ const enum gpio_signal hibernate_wake_pins[] = {
};
const int hibernate_wake_pins_used = ARRAY_SIZE(hibernate_wake_pins);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {
- .name = "Volume Up",
- .type = KEYBOARD_BUTTON_VOLUME_UP,
- .gpio = GPIO_EC_VOLUP_BTN_ODL,
- .debounce_us = 30 * MSEC,
- .flags = 0,
- },
- {
- .name = "Volume Down",
- .type = KEYBOARD_BUTTON_VOLUME_DOWN,
- .gpio = GPIO_EC_VOLDN_BTN_ODL,
- .debounce_us = 30 * MSEC,
- .flags = 0,
- },
-};
-BUILD_ASSERT(ARRAY_SIZE(buttons) == CONFIG_BUTTON_COUNT);
-
/* Called by APL power state machine when transitioning from G3 to S5 */
static void chipset_pre_init(void)
{
diff --git a/board/glkrvp/board.h b/board/glkrvp/board.h
index 3ff9fca52f..2115be6d3b 100644
--- a/board/glkrvp/board.h
+++ b/board/glkrvp/board.h
@@ -85,7 +85,9 @@
/* EC */
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#define CONFIG_BUTTON_COUNT 2
+#define CONFIG_VOLUME_BUTTONS
+#define GPIO_VOLUME_UP_L GPIO_EC_VOLUP_BTN_ODL
+#define GPIO_VOLUME_DOWN_L GPIO_EC_VOLDN_BTN_ODL
#define CONFIG_WP_ALWAYS
#define CONFIG_I2C
#define CONFIG_I2C_MASTER
diff --git a/board/grunt/board.c b/board/grunt/board.c
index a8755e08c2..68d765dab4 100644
--- a/board/grunt/board.c
+++ b/board/grunt/board.c
@@ -72,13 +72,6 @@ const struct i2c_port_t i2c_ports[] = {
};
const unsigned int i2c_ports_used = ARRAY_SIZE(i2c_ports);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_VOLDN_BTN_ODL,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_VOLUP_BTN_ODL,
- 30 * MSEC, 0},
-};
-
/* Keyboard scan setting */
struct keyboard_scan_config keyscan_config = {
/* Extra delay when KSO2 is tied to Cr50. */
diff --git a/board/grunt/board.h b/board/grunt/board.h
index bb15a7e0bf..8e20aaddeb 100644
--- a/board/grunt/board.h
+++ b/board/grunt/board.h
@@ -29,7 +29,6 @@
#define CONFIG_LPC
#define CONFIG_BOARD_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_CHIPSET_STONEY
#define CONFIG_CHIPSET_RESET_HOOK
@@ -46,6 +45,10 @@
#define CONFIG_KEYBOARD_COL2_INVERTED
#define CONFIG_KEYBOARD_PROTOCOL_8042
+#define CONFIG_VOLUME_BUTTONS
+#define GPIO_VOLUME_DOWN_L GPIO_VOLDN_BTN_ODL
+#define GPIO_VOLUME_UP_L GPIO_VOLUP_BTN_ODL
+
#define I2C_PORT_BATTERY I2C_PORT_POWER
#define I2C_PORT_POWER NPCX_I2C_PORT0_0
#define I2C_PORT_TCPC0 NPCX_I2C_PORT1_0
diff --git a/board/host/board.c b/board/host/board.c
index b29f6e9230..e3183fa874 100644
--- a/board/host/board.c
+++ b/board/host/board.c
@@ -45,16 +45,6 @@ test_mockable void button_interrupt(enum gpio_signal signal)
{
};
-#ifdef CONFIG_BUTTON_COUNT
-const struct button_config buttons[] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_BUTTON_VOLUME_DOWN_L,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_BUTTON_VOLUME_UP,
- 60 * MSEC, BUTTON_FLAG_ACTIVE_HIGH},
-};
-BUILD_ASSERT(ARRAY_SIZE(buttons) == CONFIG_BUTTON_COUNT);
-#endif
-
#ifdef CONFIG_I2C
/* I2C ports */
const struct i2c_port_t i2c_ports[] = {
diff --git a/board/host/gpio.inc b/board/host/gpio.inc
index 7695a6021d..73bd6c0252 100644
--- a/board/host/gpio.inc
+++ b/board/host/gpio.inc
@@ -11,8 +11,8 @@
GPIO_INT(LID_OPEN, PIN(0, 0), GPIO_INT_BOTH, lid_interrupt)
GPIO_INT(POWER_BUTTON_L, PIN(0, 1), GPIO_INT_BOTH, power_button_interrupt)
GPIO_INT(AC_PRESENT, PIN(0, 2), GPIO_INT_BOTH, extpower_interrupt)
-GPIO_INT(BUTTON_VOLUME_DOWN_L, PIN(0, 3), GPIO_INT_BOTH, button_interrupt)
-GPIO_INT(BUTTON_VOLUME_UP, PIN(0, 4), GPIO_INT_BOTH, button_interrupt)
+GPIO_INT(VOLUME_DOWN_L, PIN(0, 3), GPIO_INT_BOTH, button_interrupt)
+GPIO_INT(VOLUME_UP_L, PIN(0, 4), GPIO_INT_BOTH, button_interrupt)
GPIO_INT(CHARGE_DONE, PIN(0, 5), GPIO_INT_BOTH, inductive_charging_interrupt)
GPIO(EC_INT_L, PIN(0, 6), 0)
diff --git a/board/kahlee/board.h b/board/kahlee/board.h
index ab028983b4..d43356c8af 100644
--- a/board/kahlee/board.h
+++ b/board/kahlee/board.h
@@ -97,7 +97,6 @@
#define CONFIG_ADC
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#undef CONFIG_BUTTON_COUNT
#define CONFIG_EXTPOWER_GPIO
#undef CONFIG_EXTPOWER_DEBOUNCE_MS
#define CONFIG_EXTPOWER_DEBOUNCE_MS 1000
diff --git a/board/kevin/board.c b/board/kevin/board.c
index 6dadcd5c67..c7b0442c65 100644
--- a/board/kevin/board.c
+++ b/board/kevin/board.c
@@ -163,13 +163,6 @@ struct keyboard_scan_config keyscan_config = {
},
};
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_VOLUME_DOWN_L,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_VOLUME_UP_L,
- 30 * MSEC, 0},
-};
-
const struct tcpc_config_t tcpc_config[CONFIG_USB_PD_PORT_COUNT] = {
{I2C_PORT_TCPC0, FUSB302_I2C_SLAVE_ADDR, &fusb302_tcpm_drv},
{I2C_PORT_TCPC1, FUSB302_I2C_SLAVE_ADDR, &fusb302_tcpm_drv},
diff --git a/board/kevin/board.h b/board/kevin/board.h
index 8b0eac980f..d0306c8c26 100644
--- a/board/kevin/board.h
+++ b/board/kevin/board.h
@@ -48,7 +48,6 @@
/* Optional features */
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_FLASH_SIZE 0x00080000 /* 512KB spi flash */
#define CONFIG_HOST_COMMAND_STATUS
#define CONFIG_HOSTCMD_SECTION_SORTED /* Host commands are sorted. */
@@ -63,6 +62,7 @@
#define CONFIG_POWER_BUTTON
#define CONFIG_POWER_TRACK_HOST_SLEEP_STATE
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_CHARGER
#define CONFIG_CHARGER_BD9995X
diff --git a/board/nautilus/board.c b/board/nautilus/board.c
index 2f40113d6f..3bacf3a0e7 100644
--- a/board/nautilus/board.c
+++ b/board/nautilus/board.c
@@ -470,13 +470,6 @@ struct als_t als[] = {
};
BUILD_ASSERT(ARRAY_SIZE(als) == ALS_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- [BUTTON_VOLUME_DOWN] = {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN,
- GPIO_VOLUME_DOWN_L, 30 * MSEC, 0},
- [BUTTON_VOLUME_UP] = {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP,
- GPIO_VOLUME_UP_L, 30 * MSEC, 0},
-};
-
const struct button_config *recovery_buttons[] = {
&buttons[BUTTON_VOLUME_DOWN],
&buttons[BUTTON_VOLUME_UP],
diff --git a/board/nautilus/board.h b/board/nautilus/board.h
index afd0f45b11..a85f1d2aa3 100644
--- a/board/nautilus/board.h
+++ b/board/nautilus/board.h
@@ -18,7 +18,6 @@
#define CONFIG_ADC
#define CONFIG_BACKLIGHT_LID
#define CONFIG_BOARD_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_BUTTON_RECOVERY
#define CONFIG_CASE_CLOSED_DEBUG_EXTERNAL
#define CONFIG_DPTF
@@ -38,6 +37,7 @@
#define CONFIG_UART_HOST 0
#define CONFIG_VBOOT_HASH
#define CONFIG_SHA256_UNROLLED
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_VSTORE
#define CONFIG_VSTORE_SLOT_COUNT 1
#define CONFIG_WATCHDOG_HELP
@@ -228,12 +228,6 @@ enum adc_channel {
ADC_CH_COUNT
};
-enum button {
- BUTTON_VOLUME_DOWN = 0,
- BUTTON_VOLUME_UP = 1,
- BUTTON_COUNT
-};
-
/* TODO(crosbug.com/p/61098): Verify the numbers below. */
/*
* delay to turn on the power supply max is ~16ms.
diff --git a/board/nefario/board.c b/board/nefario/board.c
index c31cb2dc7d..71c53e2e0e 100644
--- a/board/nefario/board.c
+++ b/board/nefario/board.c
@@ -145,13 +145,6 @@ struct keyboard_scan_config keyscan_config = {
},
};
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_VOLUME_DOWN_L,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_VOLUME_UP_L,
- 30 * MSEC, 0},
-};
-
const struct tcpc_config_t tcpc_config[CONFIG_USB_PD_PORT_COUNT] = {
{I2C_PORT_TCPC0, FUSB302_I2C_SLAVE_ADDR, &fusb302_tcpm_drv},
{I2C_PORT_TCPC1, FUSB302_I2C_SLAVE_ADDR, &fusb302_tcpm_drv},
diff --git a/board/nefario/board.h b/board/nefario/board.h
index f6d24893dd..12f3816d56 100644
--- a/board/nefario/board.h
+++ b/board/nefario/board.h
@@ -51,7 +51,6 @@
/* Optional features */
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_FLASH_SIZE 0x00080000 /* 512KB spi flash */
#define CONFIG_HOST_COMMAND_STATUS
/* By default, set hcdebug to off */
@@ -66,6 +65,7 @@
#define CONFIG_POWER_TRACK_HOST_SLEEP_STATE
#define CONFIG_SOFTWARE_PANIC
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_CHARGER
#define CONFIG_CHARGER_BD9995X
diff --git a/board/poppy/board.c b/board/poppy/board.c
index 4baf488a85..a270e985e7 100644
--- a/board/poppy/board.c
+++ b/board/poppy/board.c
@@ -545,13 +545,6 @@ struct als_t als[] = {
};
BUILD_ASSERT(ARRAY_SIZE(als) == ALS_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- [BUTTON_VOLUME_DOWN] = {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN,
- GPIO_VOLUME_DOWN_L, 30 * MSEC, 0},
- [BUTTON_VOLUME_UP] = {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP,
- GPIO_VOLUME_UP_L, 30 * MSEC, 0},
-};
-
const struct button_config *recovery_buttons[] = {
&buttons[BUTTON_VOLUME_DOWN],
&buttons[BUTTON_VOLUME_UP],
diff --git a/board/poppy/board.h b/board/poppy/board.h
index 03076417d2..245f8027d0 100644
--- a/board/poppy/board.h
+++ b/board/poppy/board.h
@@ -19,7 +19,6 @@
#define CONFIG_BACKLIGHT_LID
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_BUTTON_RECOVERY
#define CONFIG_DPTF
#define CONFIG_EMULATED_SYSRQ
@@ -37,6 +36,7 @@
#define CONFIG_UART_HOST 0
#define CONFIG_VBOOT_HASH
#define CONFIG_SHA256_UNROLLED
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_VSTORE
#define CONFIG_VSTORE_SLOT_COUNT 1
#define CONFIG_WATCHDOG_HELP
@@ -232,12 +232,6 @@ enum adc_channel {
ADC_CH_COUNT
};
-enum button {
- BUTTON_VOLUME_DOWN = 0,
- BUTTON_VOLUME_UP = 1,
- BUTTON_COUNT
-};
-
/* TODO(crosbug.com/p/61098): Verify the numbers below. */
/*
* delay to turn on the power supply max is ~16ms.
diff --git a/board/rainier/board.c b/board/rainier/board.c
index 237cfcca12..b8c8627983 100644
--- a/board/rainier/board.c
+++ b/board/rainier/board.c
@@ -129,13 +129,6 @@ const enum gpio_signal hibernate_wake_pins[] = {
const int hibernate_wake_pins_used = ARRAY_SIZE(hibernate_wake_pins);
/******************************************************************************/
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- [BUTTON_VOLUME_DOWN] = {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN,
- GPIO_VOLUME_DOWN_L, 30 * MSEC, 0},
- [BUTTON_VOLUME_UP] = {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP,
- GPIO_VOLUME_UP_L, 30 * MSEC, 0},
-};
-
const struct button_config *recovery_buttons[] = {
&buttons[BUTTON_VOLUME_DOWN],
&buttons[BUTTON_VOLUME_UP],
diff --git a/board/rainier/board.h b/board/rainier/board.h
index 8c67257695..4b6e4fb97a 100644
--- a/board/rainier/board.h
+++ b/board/rainier/board.h
@@ -43,7 +43,6 @@
#define CONFIG_BOARD_PRE_INIT
#define CONFIG_BOARD_SPECIFIC_VERSION
#define CONFIG_BOARD_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_BUTTON_RECOVERY
#define CONFIG_CHARGER_ILIM_PIN_DISABLED
#define CONFIG_FORCE_CONSOLE_RESUME
@@ -59,6 +58,7 @@
#define CONFIG_POWER_TRACK_HOST_SLEEP_STATE
#define CONFIG_SOFTWARE_PANIC
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_USB_MUX_VIRTUAL
@@ -142,12 +142,6 @@ enum adc_channel {
ADC_CH_COUNT
};
-enum button {
- BUTTON_VOLUME_DOWN = 0,
- BUTTON_VOLUME_UP = 1,
- BUTTON_COUNT
-};
-
/* power signal definitions */
enum power_signal {
PP1250_S3_PWR_GOOD = 0,
diff --git a/board/reef/board.c b/board/reef/board.c
index 3e0becb255..43bee25318 100644
--- a/board/reef/board.c
+++ b/board/reef/board.c
@@ -496,13 +496,6 @@ const struct temp_sensor_t temp_sensors[] = {
};
BUILD_ASSERT(ARRAY_SIZE(temp_sensors) == TEMP_SENSOR_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_EC_VOLDN_BTN_ODL,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_EC_VOLUP_BTN_ODL,
- 30 * MSEC, 0},
-};
-
/* Called by APL power state machine when transitioning from G3 to S5 */
static void chipset_pre_init(void)
{
diff --git a/board/reef/board.h b/board/reef/board.h
index 2825bad90e..f67994c2b8 100644
--- a/board/reef/board.h
+++ b/board/reef/board.h
@@ -117,7 +117,6 @@
#define CONFIG_ADC
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_EXTPOWER_GPIO
#undef CONFIG_EXTPOWER_DEBOUNCE_MS
#define CONFIG_EXTPOWER_DEBOUNCE_MS 1000
@@ -141,6 +140,9 @@
#define CONFIG_DPTF_DEVICE_ORIENTATION
#define CONFIG_SCI_GPIO GPIO_PCH_SCI_L
#define CONFIG_UART_HOST 0
+#define CONFIG_VOLUME_BUTTONS
+#define GPIO_VOLUME_DOWN_L GPIO_EC_VOLDN_BTN_ODL
+#define GPIO_VOLUME_UP_L GPIO_EC_VOLUP_BTN_ODL
#define CONFIG_VBOOT_HASH
#define CONFIG_BACKLIGHT_LID
#define CONFIG_WIRELESS
diff --git a/board/reef_it8320/board.c b/board/reef_it8320/board.c
index c8eeb2b8ef..3cb1d49afc 100644
--- a/board/reef_it8320/board.c
+++ b/board/reef_it8320/board.c
@@ -277,13 +277,6 @@ const struct temp_sensor_t temp_sensors[] = {
};
BUILD_ASSERT(ARRAY_SIZE(temp_sensors) == TEMP_SENSOR_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_EC_VOLDN_BTN_ODL,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_EC_VOLUP_BTN_ODL,
- 30 * MSEC, 0},
-};
-
/* Called by APL power state machine when transitioning from G3 to S5 */
static void chipset_pre_init(void)
{
diff --git a/board/reef_it8320/board.h b/board/reef_it8320/board.h
index 0d86f37e4f..0fe238d043 100644
--- a/board/reef_it8320/board.h
+++ b/board/reef_it8320/board.h
@@ -101,7 +101,6 @@
#define CONFIG_ADC
#define CONFIG_BOARD_VERSION
#define CONFIG_BOARD_SPECIFIC_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_EXTPOWER_GPIO
#undef CONFIG_EXTPOWER_DEBOUNCE_MS
#define CONFIG_EXTPOWER_DEBOUNCE_MS 1000
@@ -121,6 +120,9 @@
#define CONFIG_DPTF_DEVICE_ORIENTATION
#define CONFIG_SCI_GPIO GPIO_PCH_SCI_L
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
+#define GPIO_VOLUME_DOWN_L GPIO_EC_VOLDN_BTN_ODL
+#define GPIO_VOLUME_UP_L GPIO_EC_VOLUP_BTN_ODL
#define CONFIG_BACKLIGHT_LID
#define CONFIG_WIRELESS
#define CONFIG_WIRELESS_SUSPEND EC_WIRELESS_SWITCH_WLAN_POWER
diff --git a/board/rowan/board.c b/board/rowan/board.c
index 31e0da5cea..35864a2493 100644
--- a/board/rowan/board.c
+++ b/board/rowan/board.c
@@ -156,13 +156,6 @@ const struct temp_sensor_t temp_sensors[] = {
};
BUILD_ASSERT(ARRAY_SIZE(temp_sensors) == TEMP_SENSOR_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- [BUTTON_VOLUME_DOWN] = {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN,
- GPIO_VOLUME_DOWN_L, 30 * MSEC, 0},
- [BUTTON_VOLUME_UP] = {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP,
- GPIO_VOLUME_UP_L, 30 * MSEC, 0},
-};
-
const struct button_config *recovery_buttons[] = {
&buttons[BUTTON_VOLUME_DOWN],
&buttons[BUTTON_VOLUME_UP],
diff --git a/board/rowan/board.h b/board/rowan/board.h
index 12d4e382c8..82aabcdf73 100644
--- a/board/rowan/board.h
+++ b/board/rowan/board.h
@@ -17,8 +17,8 @@
#define CONFIG_CMD_GPIO_EXTENDED
/* Button */
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_BUTTON_RECOVERY
+#define CONFIG_VOLUME_BUTTONS
/* Accelero meter and gyro sensor */
#define CONFIG_ACCELGYRO_BMI160
@@ -185,12 +185,6 @@ enum adc_channel {
ADC_CH_COUNT
};
-enum button {
- BUTTON_VOLUME_DOWN = 0,
- BUTTON_VOLUME_UP = 1,
- BUTTON_COUNT
-};
-
enum temp_sensor_id {
#ifdef CONFIG_TEMP_SENSOR_TMP432
/* TMP432 local and remote sensors */
diff --git a/board/scarlet/board.c b/board/scarlet/board.c
index 558ece8540..5a9e7db8ee 100644
--- a/board/scarlet/board.c
+++ b/board/scarlet/board.c
@@ -123,13 +123,6 @@ const struct spi_device_t spi_devices[] = {
const unsigned int spi_devices_used = ARRAY_SIZE(spi_devices);
/******************************************************************************/
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- [BUTTON_VOLUME_DOWN] = {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN,
- GPIO_VOLUME_DOWN_L, 30 * MSEC, 0},
- [BUTTON_VOLUME_UP] = {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP,
- GPIO_VOLUME_UP_L, 30 * MSEC, 0},
-};
-
const struct button_config *recovery_buttons[] = {
&buttons[BUTTON_VOLUME_DOWN],
&buttons[BUTTON_VOLUME_UP],
diff --git a/board/scarlet/board.h b/board/scarlet/board.h
index 1d45efddb0..c729de8650 100644
--- a/board/scarlet/board.h
+++ b/board/scarlet/board.h
@@ -46,7 +46,6 @@
#define CONFIG_BOARD_PRE_INIT
#define CONFIG_BOARD_SPECIFIC_VERSION
#define CONFIG_BOARD_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_BUTTON_RECOVERY
#define CONFIG_CHARGER_ILIM_PIN_DISABLED
#define CONFIG_FORCE_CONSOLE_RESUME
@@ -62,6 +61,7 @@
#define CONFIG_POWER_TRACK_HOST_SLEEP_STATE
#define CONFIG_SOFTWARE_PANIC
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_CHARGER
#define CONFIG_CHARGER_RT9467
@@ -182,12 +182,6 @@ enum adc_channel {
ADC_CH_COUNT
};
-enum button {
- BUTTON_VOLUME_DOWN = 0,
- BUTTON_VOLUME_UP = 1,
- BUTTON_COUNT
-};
-
/* power signal definitions */
enum power_signal {
PP1250_S3_PWR_GOOD = 0,
diff --git a/board/strago/board.c b/board/strago/board.c
index 98c9c2618c..38ad6f8292 100644
--- a/board/strago/board.c
+++ b/board/strago/board.c
@@ -167,14 +167,6 @@ struct als_t als[] = {
};
BUILD_ASSERT(ARRAY_SIZE(als) == ALS_COUNT);
-const struct button_config buttons[] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_VOLUME_DOWN,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_VOLUME_UP,
- 30 * MSEC, 0},
-};
-BUILD_ASSERT(ARRAY_SIZE(buttons) == CONFIG_BUTTON_COUNT);
-
/**
* Reset PD MCU
*/
diff --git a/board/strago/board.h b/board/strago/board.h
index f13e650008..7ca153ce07 100644
--- a/board/strago/board.h
+++ b/board/strago/board.h
@@ -94,7 +94,9 @@
#define CONFIG_LID_ANGLE_SENSOR_LID 1
/* Number of buttons */
-#define CONFIG_BUTTON_COUNT 2
+#define CONFIG_VOLUME_BUTTONS
+#define GPIO_VOLUME_DOWN_L GPIO_VOLUME_DOWN
+#define GPIO_VOLUME_UP_L GPIO_VOLUME_UP
#define CONFIG_ADC
diff --git a/board/wheatley/board.c b/board/wheatley/board.c
index 99d83d29f9..f67e56f45f 100644
--- a/board/wheatley/board.c
+++ b/board/wheatley/board.c
@@ -202,13 +202,6 @@ struct als_t als[] = {
};
BUILD_ASSERT(ARRAY_SIZE(als) == ALS_COUNT);
-const struct button_config buttons[CONFIG_BUTTON_COUNT] = {
- {"Volume Down", KEYBOARD_BUTTON_VOLUME_DOWN, GPIO_VOLUME_DOWN_L,
- 30 * MSEC, 0},
- {"Volume Up", KEYBOARD_BUTTON_VOLUME_UP, GPIO_VOLUME_UP_L,
- 30 * MSEC, 0},
-};
-
static void board_pmic_init(void)
{
/* No need to re-init PMIC since settings are sticky across sysjump */
diff --git a/board/wheatley/board.h b/board/wheatley/board.h
index 4c5fdbd55f..eb2e579608 100644
--- a/board/wheatley/board.h
+++ b/board/wheatley/board.h
@@ -17,7 +17,6 @@
#define CONFIG_BATTERY_PRESENT_GPIO GPIO_BAT_PRESENT_L
#define CONFIG_BATTERY_SMART
#define CONFIG_BOARD_VERSION
-#define CONFIG_BUTTON_COUNT 2
#define CONFIG_CHARGE_MANAGER
#define CONFIG_CHARGER
@@ -87,6 +86,7 @@
#define CONFIG_USBC_VCONN
#define CONFIG_USBC_VCONN_SWAP
#define CONFIG_VBOOT_HASH
+#define CONFIG_VOLUME_BUTTONS
#define CONFIG_FLASH_SIZE 0x80000 /* 512 KB Flash used for EC */
#define CONFIG_SPI_FLASH_REGS