aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/i2c/busses/i2c-omap.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/i2c/busses/i2c-omap.c')
-rw-r--r--drivers/i2c/busses/i2c-omap.c85
1 files changed, 81 insertions, 4 deletions
diff --git a/drivers/i2c/busses/i2c-omap.c b/drivers/i2c/busses/i2c-omap.c
index 0e894193accf..fc9bf7f30e35 100644
--- a/drivers/i2c/busses/i2c-omap.c
+++ b/drivers/i2c/busses/i2c-omap.c
@@ -38,6 +38,7 @@
38#include <linux/slab.h> 38#include <linux/slab.h>
39#include <linux/i2c-omap.h> 39#include <linux/i2c-omap.h>
40#include <linux/pm_runtime.h> 40#include <linux/pm_runtime.h>
41#include <linux/pinctrl/consumer.h>
41 42
42/* I2C controller revisions */ 43/* I2C controller revisions */
43#define OMAP_I2C_OMAP1_REV_2 0x20 44#define OMAP_I2C_OMAP1_REV_2 0x20
@@ -481,10 +482,8 @@ static int omap_i2c_wait_for_bb(struct omap_i2c_dev *dev)
481 482
482 timeout = jiffies + OMAP_I2C_TIMEOUT; 483 timeout = jiffies + OMAP_I2C_TIMEOUT;
483 while (omap_i2c_read_reg(dev, OMAP_I2C_STAT_REG) & OMAP_I2C_STAT_BB) { 484 while (omap_i2c_read_reg(dev, OMAP_I2C_STAT_REG) & OMAP_I2C_STAT_BB) {
484 if (time_after(jiffies, timeout)) { 485 if (time_after(jiffies, timeout))
485 dev_warn(dev->dev, "timeout waiting for bus ready\n"); 486 return i2c_recover_bus(&dev->adapter);
486 return -ETIMEDOUT;
487 }
488 msleep(1); 487 msleep(1);
489 } 488 }
490 489
@@ -1209,6 +1208,79 @@ MODULE_DEVICE_TABLE(of, omap_i2c_of_match);
1209#define OMAP_I2C_SCHEME_0 0 1208#define OMAP_I2C_SCHEME_0 0
1210#define OMAP_I2C_SCHEME_1 1 1209#define OMAP_I2C_SCHEME_1 1
1211 1210
1211static int omap_i2c_get_scl(struct i2c_adapter *adap)
1212{
1213 struct omap_i2c_dev *dev = i2c_get_adapdata(adap);
1214 u32 reg;
1215
1216 reg = omap_i2c_read_reg(dev, OMAP_I2C_SYSTEST_REG);
1217
1218 return reg & OMAP_I2C_SYSTEST_SCL_I_FUNC;
1219}
1220
1221static int omap_i2c_get_sda(struct i2c_adapter *adap)
1222{
1223 struct omap_i2c_dev *dev = i2c_get_adapdata(adap);
1224 u32 reg;
1225
1226 reg = omap_i2c_read_reg(dev, OMAP_I2C_SYSTEST_REG);
1227
1228 return reg & OMAP_I2C_SYSTEST_SDA_I_FUNC;
1229}
1230
1231static void omap_i2c_set_scl(struct i2c_adapter *adap, int val)
1232{
1233 struct omap_i2c_dev *dev = i2c_get_adapdata(adap);
1234 u32 reg;
1235
1236 reg = omap_i2c_read_reg(dev, OMAP_I2C_SYSTEST_REG);
1237 if (val)
1238 reg |= OMAP_I2C_SYSTEST_SCL_O;
1239 else
1240 reg &= ~OMAP_I2C_SYSTEST_SCL_O;
1241 omap_i2c_write_reg(dev, OMAP_I2C_SYSTEST_REG, reg);
1242}
1243
1244static void omap_i2c_prepare_recovery(struct i2c_adapter *adap)
1245{
1246 struct omap_i2c_dev *dev = i2c_get_adapdata(adap);
1247 u32 reg;
1248
1249 reg = omap_i2c_read_reg(dev, OMAP_I2C_SYSTEST_REG);
1250 /* enable test mode */
1251 reg |= OMAP_I2C_SYSTEST_ST_EN;
1252 /* select SDA/SCL IO mode */
1253 reg |= 3 << OMAP_I2C_SYSTEST_TMODE_SHIFT;
1254 /* set SCL to high-impedance state (reset value is 0) */
1255 reg |= OMAP_I2C_SYSTEST_SCL_O;
1256 /* set SDA to high-impedance state (reset value is 0) */
1257 reg |= OMAP_I2C_SYSTEST_SDA_O;
1258 omap_i2c_write_reg(dev, OMAP_I2C_SYSTEST_REG, reg);
1259}
1260
1261static void omap_i2c_unprepare_recovery(struct i2c_adapter *adap)
1262{
1263 struct omap_i2c_dev *dev = i2c_get_adapdata(adap);
1264 u32 reg;
1265
1266 reg = omap_i2c_read_reg(dev, OMAP_I2C_SYSTEST_REG);
1267 /* restore reset values */
1268 reg &= ~OMAP_I2C_SYSTEST_ST_EN;
1269 reg &= ~OMAP_I2C_SYSTEST_TMODE_MASK;
1270 reg &= ~OMAP_I2C_SYSTEST_SCL_O;
1271 reg &= ~OMAP_I2C_SYSTEST_SDA_O;
1272 omap_i2c_write_reg(dev, OMAP_I2C_SYSTEST_REG, reg);
1273}
1274
1275static struct i2c_bus_recovery_info omap_i2c_bus_recovery_info = {
1276 .get_scl = omap_i2c_get_scl,
1277 .get_sda = omap_i2c_get_sda,
1278 .set_scl = omap_i2c_set_scl,
1279 .prepare_recovery = omap_i2c_prepare_recovery,
1280 .unprepare_recovery = omap_i2c_unprepare_recovery,
1281 .recover_bus = i2c_generic_scl_recovery,
1282};
1283
1212static int 1284static int
1213omap_i2c_probe(struct platform_device *pdev) 1285omap_i2c_probe(struct platform_device *pdev)
1214{ 1286{
@@ -1358,6 +1430,7 @@ omap_i2c_probe(struct platform_device *pdev)
1358 adap->algo = &omap_i2c_algo; 1430 adap->algo = &omap_i2c_algo;
1359 adap->dev.parent = &pdev->dev; 1431 adap->dev.parent = &pdev->dev;
1360 adap->dev.of_node = pdev->dev.of_node; 1432 adap->dev.of_node = pdev->dev.of_node;
1433 adap->bus_recovery_info = &omap_i2c_bus_recovery_info;
1361 1434
1362 /* i2c device drivers may be active on return from add_adapter() */ 1435 /* i2c device drivers may be active on return from add_adapter() */
1363 adap->nr = pdev->id; 1436 adap->nr = pdev->id;
@@ -1423,6 +1496,8 @@ static int omap_i2c_runtime_suspend(struct device *dev)
1423 omap_i2c_read_reg(_dev, OMAP_I2C_STAT_REG); 1496 omap_i2c_read_reg(_dev, OMAP_I2C_STAT_REG);
1424 } 1497 }
1425 1498
1499 pinctrl_pm_select_sleep_state(dev);
1500
1426 return 0; 1501 return 0;
1427} 1502}
1428 1503
@@ -1431,6 +1506,8 @@ static int omap_i2c_runtime_resume(struct device *dev)
1431 struct platform_device *pdev = to_platform_device(dev); 1506 struct platform_device *pdev = to_platform_device(dev);
1432 struct omap_i2c_dev *_dev = platform_get_drvdata(pdev); 1507 struct omap_i2c_dev *_dev = platform_get_drvdata(pdev);
1433 1508
1509 pinctrl_pm_select_default_state(dev);
1510
1434 if (!_dev->regs) 1511 if (!_dev->regs)
1435 return 0; 1512 return 0;
1436 1513