summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorElthan_Huang <elthan_huang@compal.corp-partner.google.com>2018-03-05 21:58:46 +0800
committerchrome-bot <chrome-bot@chromium.org>2018-03-28 23:23:47 -0700
commitc00837e9a380fc4c3a0d05fc30fdb332686f28e2 (patch)
treea166ec45a2ec11d1ec7bc7d50df52205af713b58
parented13cb82b64732132db6007320325b3bc51dcee2 (diff)
downloadchrome-ec-c00837e9a380fc4c3a0d05fc30fdb332686f28e2.tar.gz
Nami: Multiple configurations of motion sensors
Nami and Vayne share the same EC image but with different configuration of motion sensors . Nami is w/ ALS, but Vayne is w/o ALS. Create board_set_motion_sensor_count function to update montion sensor count by oem id. BUG=b:74608262 BRANCH=none TEST=Change oem id to check the ALS function whether disable in Vayne. Change-Id: I86481f8313adaf2585a781e5ad2dafe38008d2ab Signed-off-by: Elthan_Huang <elthan_huang@compal.corp-partner.google.com> Reviewed-on: https://chromium-review.googlesource.com/948882 Commit-Ready: Elthan Huang <elthan_huang@compal.corp-partner.google.com> Tested-by: Elthan Huang <elthan_huang@compal.corp-partner.google.com> Reviewed-by: Daisuke Nojiri <dnojiri@chromium.org>
-rw-r--r--board/nami/board.c93
-rw-r--r--board/nami/board.h8
2 files changed, 65 insertions, 36 deletions
diff --git a/board/nami/board.c b/board/nami/board.c
index 83fbaf52b5..e6c9439d23 100644
--- a/board/nami/board.c
+++ b/board/nami/board.c
@@ -429,41 +429,6 @@ static void chipset_pre_init(void)
}
DECLARE_HOOK(HOOK_CHIPSET_PRE_INIT, chipset_pre_init, HOOK_PRIO_DEFAULT);
-/* Initialize board. */
-static void board_init(void)
-{
- uint32_t version;
-
- if (cbi_get_board_version(&version) == EC_SUCCESS)
- CPRINTS("Board Version: 0x%04x", version);
-
- /*
- * This enables pull-down on F_DIO1 (SPI MISO), and F_DIO0 (SPI MOSI),
- * whenever the EC is not doing SPI flash transactions. This avoids
- * floating SPI buffer input (MISO), which causes power leakage (see
- * b/64797021).
- */
- NPCX_PUPD_EN1 |= (1 << NPCX_DEVPU1_F_SPI_PUD_EN);
-
- /* Provide AC status to the PCH */
- gpio_set_level(GPIO_PCH_ACPRESENT, extpower_is_present());
-
- /* Enable sensors power supply */
- /* dnojiri: how do we enable it? */
-
- /* Enable VBUS interrupt */
- gpio_enable_interrupt(GPIO_USB_C0_VBUS_WAKE_L);
- //gpio_enable_interrupt(GPIO_USB_C1_VBUS_WAKE_L);
-
- /* Enable pericom BC1.2 interrupts */
- gpio_enable_interrupt(GPIO_USB_C0_BC12_INT_L);
- gpio_enable_interrupt(GPIO_USB_C1_BC12_INT_L);
-
- /* Enable Gyro interrupt for BMI160 */
- gpio_enable_interrupt(GPIO_ACCELGYRO3_INT_L);
-}
-DECLARE_HOOK(HOOK_INIT, board_init, HOOK_PRIO_DEFAULT);
-
/**
* Buffer the AC present GPIO to the PCH.
*/
@@ -659,8 +624,11 @@ struct motion_sensor_t motion_sensors[] = {
},
},
},
+ /* Please make sure the LID_ALS is the last device in
+ * motion_sensors array.
+ */
};
-const unsigned int motion_sensor_count = ARRAY_SIZE(motion_sensors);
+unsigned int motion_sensor_count = ARRAY_SIZE(motion_sensors);
/* ALS instances when LPC mapping is needed. Each entry directs to a sensor. */
const struct motion_sensor_t *motion_als_sensors[] = {
@@ -707,3 +675,56 @@ static void lm3509_kblight_lid_change(void)
lm3509_poweroff();
}
DECLARE_HOOK(HOOK_LID_CHANGE, lm3509_kblight_lid_change, HOOK_PRIO_DEFAULT);
+
+static void board_set_motion_sensor_count(void)
+{
+ /* There are two possible sensor configurations.
+ * Vayne(Dell) is without ALS sensor
+ * Nami is with ALS sensor
+ * Use the oem id to different them.
+ */
+ uint32_t oem_id;
+
+ if (cbi_get_oem_id(&oem_id) == EC_SUCCESS) {
+ if (oem_id == PROJECT_VAYNE)
+ motion_sensor_count = ARRAY_SIZE(motion_sensors) - 1;
+ }
+}
+
+/* Initialize board. */
+static void board_init(void)
+{
+ uint32_t version;
+
+ if (cbi_get_board_version(&version) == EC_SUCCESS)
+ CPRINTS("Board Version: 0x%04x", version);
+
+ /*
+ * This enables pull-down on F_DIO1 (SPI MISO), and F_DIO0 (SPI MOSI),
+ * whenever the EC is not doing SPI flash transactions. This avoids
+ * floating SPI buffer input (MISO), which causes power leakage (see
+ * b/64797021).
+ */
+ NPCX_PUPD_EN1 |= (1 << NPCX_DEVPU1_F_SPI_PUD_EN);
+
+ /* Provide AC status to the PCH */
+ gpio_set_level(GPIO_PCH_ACPRESENT, extpower_is_present());
+
+ /* Enable sensors power supply */
+ /* dnojiri: how do we enable it? */
+
+ /* Enable VBUS interrupt */
+ gpio_enable_interrupt(GPIO_USB_C0_VBUS_WAKE_L);
+ //gpio_enable_interrupt(GPIO_USB_C1_VBUS_WAKE_L);
+
+ /* Enable pericom BC1.2 interrupts */
+ gpio_enable_interrupt(GPIO_USB_C0_BC12_INT_L);
+ gpio_enable_interrupt(GPIO_USB_C1_BC12_INT_L);
+
+ /* Enable Gyro interrupt for BMI160 */
+ gpio_enable_interrupt(GPIO_ACCELGYRO3_INT_L);
+
+ /* Update motion_sensor_count */
+ board_set_motion_sensor_count();
+}
+DECLARE_HOOK(HOOK_INIT, board_init, HOOK_PRIO_DEFAULT);
diff --git a/board/nami/board.h b/board/nami/board.h
index 620fb9f936..7311adb2b1 100644
--- a/board/nami/board.h
+++ b/board/nami/board.h
@@ -125,6 +125,7 @@
#define CONFIG_LID_ANGLE_UPDATE
#define CONFIG_LID_ANGLE_TABLET_MODE
#define CONFIG_LID_ANGLE_INVALID_CHECK
+#define CONFIG_DYNAMIC_MOTION_SENSOR_COUNT
/* KB backlight driver */
#define CONFIG_LED_DRIVER_LM3509
@@ -253,6 +254,13 @@ enum mft_channel {
MFT_CH_COUNT,
};
+enum oem_id {
+ PROJECT_VAYNE = 3, /* Vayne */
+ PROJECT_SONA, /* Sona */
+ PROJECT_PANTHEON, /* Pantheon */
+ PROJECT_NAMI, /* Nami */
+};
+
/* TODO(crosbug.com/p/61098): Verify the numbers below. */
/*
* delay to turn on the power supply max is ~16ms.