[U-Boot] [PATCH 26/27] kc1: Power off when the power on reason is not a valid one

Paul Kocialkowski contact at paulk.fr
Sat Feb 27 19:19:14 CET 2016


Some power on reasons are not desirable (e.g. too short press on the power
button), battery plug. Thus, power off the device when one of those occurs.

Signed-off-by: Paul Kocialkowski <contact at paulk.fr>
---
 board/amazon/kc1/kc1.c | 16 ++++++++++++++++
 include/configs/kc1.h  |  6 ++++++
 2 files changed, 22 insertions(+)

diff --git a/board/amazon/kc1/kc1.c b/board/amazon/kc1/kc1.c
index 9367b50..54e3fa3 100644
--- a/board/amazon/kc1/kc1.c
+++ b/board/amazon/kc1/kc1.c
@@ -86,6 +86,7 @@ int board_init(void)
 int misc_init_r(void)
 {
 	char reboot_mode[2] = { 0 };
+	u32 data = 0;
 	u32 value;
 
 	/* Reboot mode */
@@ -101,10 +102,25 @@ int misc_init_r(void)
 		reboot_mode[0] = 'b';
 
 	if (reboot_mode[0] > 0 && isascii(reboot_mode[0])) {
+		if (reboot_mode[0] == 'o')
+			twl6030_power_off();
+
 		if (!getenv("reboot-mode"))
 			setenv("reboot-mode", (char *)reboot_mode);
 
 		omap_reboot_mode_clear();
+	} else {
+		/*
+		 * When not rebooting, valid power on reasons are either the
+		 * power button, charger plug or USB plug.
+		 */
+
+		data |= twl6030_input_power_button();
+		data |= twl6030_input_charger();
+		data |= twl6030_input_usb();
+
+		if (!data)
+			twl6030_power_off();
 	}
 
 	/* Serial number */
diff --git a/include/configs/kc1.h b/include/configs/kc1.h
index 04cb320..c2ac148 100644
--- a/include/configs/kc1.h
+++ b/include/configs/kc1.h
@@ -105,6 +105,12 @@
 #define CONFIG_TWL6030_POWER
 
 /*
+ * Input
+ */
+
+#define CONFIG_TWL6030_INPUT
+
+/*
  * Partitions
  */
 
-- 
2.6.4



More information about the U-Boot mailing list