diff options
author | Wai-Hong Tam <waihong@google.com> | 2021-07-19 18:26:23 -0700 |
---|---|---|
committer | Commit Bot <commit-bot@chromium.org> | 2021-07-20 20:56:48 +0000 |
commit | f5364070332169ea2733b750df3265f410ea8be6 (patch) | |
tree | 5a7e50d558c347fa307c706d1777cc892da1e0e7 /zephyr/projects/herobrine/herobrine_npcx9/src | |
parent | 64b6e903dd03150d255513e6f35be48aff701a58 (diff) | |
download | chrome-ec-f5364070332169ea2733b750df3265f410ea8be6.tar.gz |
zephyr: herobrine_npcx9: Initial image which uses NPCX9
This CL copies the Zephyr board/trogdor to board/herobrine_npcx9.
Modify the chip config to npcx9m3f and some related configs (simply
rename) and dts (update the UART property). The board/herobrine_npcx9
and other NPCX9 boards, like board/brya will be merged to a single
board. But the merge needs more work to remove the not-common configs
and dts to the project directories. Leave it as a future work.
This CL also copies the project trogdor/herobrine_npcx7 to
herobrine/herobrine_npcx9. Remove the dead files power.c and
hibernate.c, in the EC-OS directory. Remove the Zephyr 2.5 support
and board.cmake (needed only for 2.5).
BRANCH=None
BUG=b:192253134
TEST=Built the herobrine_npcx9 image successfully.
Change-Id: I9641768ee978920f6a8677f13ae14e0a26ad35f4
Signed-off-by: Wai-Hong Tam <waihong@google.com>
Reviewed-on: https://chromium-review.googlesource.com/c/chromiumos/platform/ec/+/2993220
Reviewed-by: Yuval Peress <peress@chromium.org>
Diffstat (limited to 'zephyr/projects/herobrine/herobrine_npcx9/src')
-rw-r--r-- | zephyr/projects/herobrine/herobrine_npcx9/src/i2c.c | 17 | ||||
-rw-r--r-- | zephyr/projects/herobrine/herobrine_npcx9/src/sensors.c | 29 |
2 files changed, 46 insertions, 0 deletions
diff --git a/zephyr/projects/herobrine/herobrine_npcx9/src/i2c.c b/zephyr/projects/herobrine/herobrine_npcx9/src/i2c.c new file mode 100644 index 0000000000..f78ea56513 --- /dev/null +++ b/zephyr/projects/herobrine/herobrine_npcx9/src/i2c.c @@ -0,0 +1,17 @@ +/* Copyright 2021 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. + */ + +#include "i2c/i2c.h" +#include "i2c.h" + +/* Herobrine-NPCX9 board specific i2c implementation */ + +#ifdef CONFIG_PLATFORM_EC_I2C_PASSTHRU_RESTRICTED +int board_allow_i2c_passthru(int port) +{ + return (i2c_get_device_for_port(port) == + i2c_get_device_for_port(I2C_PORT_VIRTUAL_BATTERY)); +} +#endif diff --git a/zephyr/projects/herobrine/herobrine_npcx9/src/sensors.c b/zephyr/projects/herobrine/herobrine_npcx9/src/sensors.c new file mode 100644 index 0000000000..dd9ce10a16 --- /dev/null +++ b/zephyr/projects/herobrine/herobrine_npcx9/src/sensors.c @@ -0,0 +1,29 @@ +/* Copyright 2021 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. + */ + +#include "chipset.h" +#include "common.h" +#include "keyboard_scan.h" + +/* Herobrine-NPCX9 board specific sensor implementation */ + +#ifdef CONFIG_LID_ANGLE_UPDATE +void lid_angle_peripheral_enable(int enable) +{ + int chipset_in_s0 = chipset_in_state(CHIPSET_STATE_ON); + + if (enable) { + keyboard_scan_enable(1, KB_SCAN_DISABLE_LID_ANGLE); + } else { + /* + * Ensure that the chipset is off before disabling the keyboard. + * When the chipset is on, the EC keeps the keyboard enabled and + * the AP decides whether to ignore input devices or not. + */ + if (!chipset_in_s0) + keyboard_scan_enable(0, KB_SCAN_DISABLE_LID_ANGLE); + } +} +#endif |