aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/nfc
diff options
context:
space:
mode:
authorMark A. Greer <mgreer@animalcreek.com>2014-09-02 18:12:23 -0400
committerSamuel Ortiz <sameo@linux.intel.com>2014-09-07 17:13:43 -0400
commita08e54549e743ea3704da939f92caf3eaa8471d3 (patch)
tree519f1465b5ae0711bcd3e6056c172a145afe6f51 /drivers/nfc
parent6c08df422ede7db94776b8099a5f43597629234c (diff)
NFC: trf7970a: Initialize when enabling RF
Currently, the trf7970a is reset & initialized only when the pm_runtime resume hook is called. Instead, initialize it every time the RF is enabled to ensure that the trf7970a is quiesced and in a known state before being set up for another RF technology. Signed-off-by: Mark A. Greer <mgreer@animalcreek.com> Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
Diffstat (limited to 'drivers/nfc')
-rw-r--r--drivers/nfc/trf7970a.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/drivers/nfc/trf7970a.c b/drivers/nfc/trf7970a.c
index 9c0549d4f276..ce9686c44350 100644
--- a/drivers/nfc/trf7970a.c
+++ b/drivers/nfc/trf7970a.c
@@ -823,10 +823,18 @@ static void trf7970a_switch_rf_off(struct trf7970a *trf)
823 823
824static void trf7970a_switch_rf_on(struct trf7970a *trf) 824static void trf7970a_switch_rf_on(struct trf7970a *trf)
825{ 825{
826 int ret;
827
826 dev_dbg(trf->dev, "Switching rf on\n"); 828 dev_dbg(trf->dev, "Switching rf on\n");
827 829
828 pm_runtime_get_sync(trf->dev); 830 pm_runtime_get_sync(trf->dev);
829 831
832 ret = trf7970a_init(trf);
833 if (ret) {
834 dev_err(trf->dev, "%s - Can't initialize: %d\n", __func__, ret);
835 return;
836 }
837
830 trf->state = TRF7970A_ST_IDLE; 838 trf->state = TRF7970A_ST_IDLE;
831} 839}
832 840
@@ -1473,12 +1481,6 @@ static int trf7970a_pm_runtime_resume(struct device *dev)
1473 1481
1474 usleep_range(20000, 21000); 1482 usleep_range(20000, 21000);
1475 1483
1476 ret = trf7970a_init(trf);
1477 if (ret) {
1478 dev_err(dev, "%s - Can't initialize: %d\n", __func__, ret);
1479 return ret;
1480 }
1481
1482 pm_runtime_mark_last_busy(dev); 1484 pm_runtime_mark_last_busy(dev);
1483 1485
1484 return 0; 1486 return 0;