if (!qcdev)
return -ENODEV;
+ if (!device_may_wakeup(qcdev->dev)) {
+ ret = quicki2c_set_power(qcdev, HIDI2C_SLEEP);
+ if (ret)
+ return ret;
+ }
+
/*
* As I2C is THC subsystem, no register auto save/restore support,
* need driver to do that explicitly for every D3 case.
if (ret)
return ret;
+ if (!device_may_wakeup(qcdev->dev))
+ return quicki2c_set_power(qcdev, HIDI2C_ON);
+
return 0;
}
if (!qcdev)
return -ENODEV;
+ /* Ignore the return value as platform will be poweroff soon */
+ quicki2c_set_power(qcdev, HIDI2C_SLEEP);
+
ret = thc_interrupt_quiesce(qcdev->thc_hw, true);
if (ret)
return ret;
thc_change_ltr_mode(qcdev->thc_hw, THC_LTR_MODE_ACTIVE);
- return 0;
+ return quicki2c_set_power(qcdev, HIDI2C_ON);
}
static int quicki2c_runtime_suspend(struct device *device)