return ret;
}
+ /*
+ * Programming the Long-Press shutdown delay register.
+ * Using "slave" from previous assignment as this register
+ * too belongs to PALMAS_PMU_CONTROL_BASE block.
+ */
+ if (pdata->long_press_delay != PALMAS_LONG_PRESS_KEY_TIME_DEFAULT) {
+ ret = palmas_update_bits(palmas, PALMAS_PMU_CONTROL_BASE,
+ PALMAS_LONG_PRESS_KEY,
+ PALMAS_LONG_PRESS_KEY_LPK_TIME_MASK,
+ pdata->long_press_delay <<
+ PALMAS_LONG_PRESS_KEY_LPK_TIME_SHIFT);
+ if (ret) {
+ dev_err(palmas->dev,
+ "Failed to update palmas long press delay"
+ "(hard shutdown delay), err: %d\n", ret);
+ goto err;
+ }
+ }
palmas_init_ext_control(palmas);
struct bq2419x_platform_data *charger_pdata;
int watchdog_timer_initial_period;
+
+ /* Long press delay for hard shutdown */
+ int long_press_delay;
};
struct palmas_gpadc_calibration {
#define PALMAS_LONG_PRESS_KEY_PWRON_DEBOUNCE_MASK 0x03
#define PALMAS_LONG_PRESS_KEY_PWRON_DEBOUNCE_SHIFT 0
+/* Register bit values for various Long_Press_key durations */
+#define PALMAS_LONG_PRESS_KEY_TIME_DEFAULT -1
+#define PALMAS_LONG_PRESS_KEY_TIME_6SECONDS 0
+#define PALMAS_LONG_PRESS_KEY_TIME_8SECONDS 1
+#define PALMAS_LONG_PRESS_KEY_TIME_10SECONDS 2
+#define PALMAS_LONG_PRESS_KEY_TIME_12SECONDS 3
+
/* Bit definitions for OSC_THERM_CTRL */
#define PALMAS_OSC_THERM_CTRL_VANA_ON_IN_SLEEP 0x80
#define PALMAS_OSC_THERM_CTRL_VANA_ON_IN_SLEEP_SHIFT 7