summaryrefslogtreecommitdiff
path: root/util/ectool.c
diff options
context:
space:
mode:
authorHenry Hsu <Henry.Hsu@quantatw.com>2014-10-01 12:32:12 +0800
committerchrome-internal-fetch <chrome-internal-fetch@google.com>2014-12-02 01:03:17 +0000
commit82583e9a43d8a8c496c3d9adbcdb10eab68a6556 (patch)
treeea7874092681e4053a5688bd017119f4d8e06f0d /util/ectool.c
parentb82a3406f4c0fad43946e84ab69cb424700fcef6 (diff)
downloadchrome-ec-82583e9a43d8a8c496c3d9adbcdb10eab68a6556.tar.gz
CHERRY-PICK: [Swanky] lid_switch: Support forced lid openstabilize-6310.69.Brelease-R39-6310.B
Factory test process need lid switch no function or keep lid opened BUG=chrome-os-partner:33850 BRANCH=swanky TEST=Run command "ectool forcelidopen 1" and "reboot". Then lid close quickly, the system boot as lid opened. Deault value or run command "ectool forcelidopen 0" make the device normal. Change-Id: I7fc884b10a064091f8c55656795af4247934e7f5 Original-Change-Id: I94527b7ef7f9efe779c6b86f3eab651f99af6000 Signed-off-by: Henry Hsu <Henry.Hsu@quantatw.com> Reviewed-on: https://chromium-review.googlesource.com/230180 Reviewed-by: Mohammed Habibulla <moch@chromium.org> Reviewed-by: Bowgo Tsai <bowgotsai@chromium.org> Reviewed-by: Randall Spangler <rspangler@chromium.org> Commit-Queue: Shawn Nematbakhsh <shawnn@chromium.org> Tested-by: Shawn Nematbakhsh <shawnn@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/232152 Commit-Queue: Anson Tseng <anson.tseng@intel.com> Tested-by: Anson Tseng <anson.tseng@intel.com>
Diffstat (limited to 'util/ectool.c')
-rw-r--r--util/ectool.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/util/ectool.c b/util/ectool.c
index c33ebd7a74..d2e67a16cd 100644
--- a/util/ectool.c
+++ b/util/ectool.c
@@ -105,6 +105,8 @@ const char help_str[] =
" Reads from EC flash to a file\n"
" flashwrite <offset> <infile>\n"
" Writes to EC flash from a file\n"
+ " forcelidopen <enable>\n"
+ " Forces the lid switch to open position\n"
" gpioget <GPIO name>\n"
" Get the value of GPIO signal\n"
" gpioset <GPIO name>\n"
@@ -4797,6 +4799,29 @@ struct command {
int (*handler)(int argc, char *argv[]);
};
+int cmd_force_lid_open(int argc, char *argv[])
+{
+ struct ec_params_force_lid_open p;
+ char *e;
+ int rv;
+
+ if (argc != 2) {
+ fprintf(stderr, "Usage: %s <0|1>\n", argv[0]);
+ return -1;
+ }
+ p.enabled = strtol(argv[1], &e, 0);
+ if (e && *e) {
+ fprintf(stderr, "Bad value.\n");
+ return -1;
+ }
+
+ rv = ec_command(EC_CMD_FORCE_LID_OPEN, 0, &p, sizeof(p), NULL, 0);
+ if (rv < 0)
+ return rv;
+ printf("Success.\n");
+ return 0;
+}
+
/* NULL-terminated list of commands */
const struct command commands[] = {
{"extpwrcurrentlimit", cmd_ext_power_current_limit},
@@ -4830,6 +4855,7 @@ const struct command commands[] = {
{"flashwrite", cmd_flash_write},
{"flashinfo", cmd_flash_info},
{"flashpd", cmd_flash_pd},
+ {"forcelidopen", cmd_force_lid_open},
{"gpioget", cmd_gpio_get},
{"gpioset", cmd_gpio_set},
{"hangdetect", cmd_hang_detect},