summaryrefslogtreecommitdiff
path: root/syna_tcm2.c
diff options
context:
space:
mode:
authorYen-Chao Chen <davidycchen@google.com>2022-03-31 05:27:42 +0000
committerAndroid Partner Code Review <android-gerrit-partner@google.com>2022-03-31 05:27:42 +0000
commitc152c209831eac247f060d1d16d16ec95d2530ee (patch)
tree90563e50c75217259a37fd4e256fe2794a73a0f7 /syna_tcm2.c
parent3b8bb17ea9c03c3bd3db8202e0190630c9375b34 (diff)
parentf9a5c3b12e28273368f1521ce1e4bd0645c47e17 (diff)
downloadsynaptics_touch-c152c209831eac247f060d1d16d16ec95d2530ee.tar.gz
Merge "synaptics: trigger reset and retry when the suspend process fails" into android13-gs-pixel-5.10
Diffstat (limited to 'syna_tcm2.c')
-rw-r--r--syna_tcm2.c19
1 files changed, 17 insertions, 2 deletions
diff --git a/syna_tcm2.c b/syna_tcm2.c
index 4f571f4..2eb01ac 100644
--- a/syna_tcm2.c
+++ b/syna_tcm2.c
@@ -2025,6 +2025,7 @@ static int syna_dev_suspend(struct device *dev)
struct syna_tcm *tcm = dev_get_drvdata(dev);
struct syna_hw_interface *hw_if = tcm->hw_if;
bool irq_disabled = true;
+ unsigned char status;
/* exit directly if device is already in suspend state */
if (tcm->pwr_state != PWR_ON)
@@ -2041,8 +2042,22 @@ static int syna_dev_suspend(struct device *dev)
/* enter power saved mode if power is not off */
retval = syna_dev_enter_lowpwr_sensing(tcm);
if (retval < 0) {
- LOGE("Fail to enter suspended power mode\n");
- return retval;
+ LOGE("Fail to enter suspended power mode, reset and retry.\n");
+ if (hw_if->ops_hw_reset) {
+ hw_if->ops_hw_reset(hw_if);
+ retval = syna_tcm_get_event_data(tcm->tcm_dev,
+ &status, NULL);
+ if ((retval < 0) || (status != REPORT_IDENTIFY)) {
+ LOGE("Fail to complete hw reset, ret = %d, status = %d\n",
+ retval, status);
+ }
+ return retval;
+ }
+ retval = syna_dev_enter_lowpwr_sensing(tcm);
+ if (retval < 0) {
+ LOGE("Fail to enter suspended power mode after reset.\n");
+ return retval;
+ }
}
tcm->pwr_state = LOW_PWR;
#else