diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-07-28 16:43:12 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-07-28 16:43:12 -0400 |
commit | a410963ba4c0c768302f0298e258b1ee940e8316 (patch) | |
tree | f262f101a5bf752ce14775da080aed5fbaf73f0e /drivers/i2c | |
parent | f7da9cdf45cbbad5029d4858dcbc0134e06084ed (diff) | |
parent | 5db20c49e2d6581797c17057e068d89d6677aa24 (diff) |
Merge branch 'i2c-embedded/for-next' of git://git.pengutronix.de/git/wsa/linux
Pull embedded i2c changes from Wolfram Sang:
"Changes for the "embedded" part of the I2C subsystem:
- lots of devicetree conversions of drivers (and preparations for
that)
- big cleanups for drivers for OMAP, Tegra, Nomadik, Blackfin
- Rafael's struct dev_pm_ops conversion patches for I2C
- usual driver cleanups and fixes
All patches have been in linux-next for an apropriate time and all
patches touching files outside of i2c-folders should have proper acks
from the maintainers."
* 'i2c-embedded/for-next' of git://git.pengutronix.de/git/wsa/linux: (60 commits)
Revert "i2c: tegra: convert normal suspend/resume to *_noirq"
I2C: MV64XYZ: Add Device Tree support
i2c: stu300: use devm managed resources
i2c: i2c-ocores: support for 16bit and 32bit IO
V4L/DVB: mfd: use reg_shift instead of regstep
i2c: i2c-ocores: Use reg-shift property
i2c: i2c-ocores: DT bindings and minor fixes.
i2c: mv64xxxx: remove EXPERIMENTAL tag
i2c-s3c2410: Use plain pm_runtime_put()
i2c: s3c2410: Fix pointer type passed to of_match_node()
i2c: mxs: Set I2C timing registers for mxs-i2c
i2c: i2c-bfin-twi: Move blackfin TWI register access Macro to head file.
i2c: i2c-bfin-twi: Move TWI peripheral pin request array to platform data.
i2c:i2c-bfin-twi: include twi head file
i2c:i2c-bfin-twi: TWI fails to restart next transfer in high system load.
i2c: i2c-bfin-twi: Tighten condition when failing I2C transfer if MEN bit is reset unexpectedly.
i2c: i2c-bfin-twi: Break dead waiting loop if i2c device misbehaves.
i2c: i2c-bfin-twi: Improve the patch for bug "Illegal i2c bus lock upon certain transfer scenarios".
i2c: i2c-bfin-twi: Illegal i2c bus lock upon certain transfer scenarios.
i2c-mv64xxxx: allow more than one driver instance
...
Conflicts:
drivers/i2c/busses/i2c-nomadik.c
Diffstat (limited to 'drivers/i2c')
-rw-r--r-- | drivers/i2c/busses/Kconfig | 7 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-at91.c | 13 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-bfin-twi.c | 147 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-imx.c | 75 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-mv64xxx.c | 133 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-mxs.c | 68 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-nomadik.c | 189 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-ocores.c | 113 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-omap.c | 155 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-pnx.c | 19 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-puv3.c | 15 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-s3c2410.c | 6 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-stu300.c | 102 | ||||
-rw-r--r-- | drivers/i2c/busses/i2c-tegra.c | 122 |
14 files changed, 623 insertions, 541 deletions
diff --git a/drivers/i2c/busses/Kconfig b/drivers/i2c/busses/Kconfig index 2e7530a4e7b8..b4aaa1bd6728 100644 --- a/drivers/i2c/busses/Kconfig +++ b/drivers/i2c/busses/Kconfig | |||
@@ -462,7 +462,7 @@ config I2C_MPC | |||
462 | 462 | ||
463 | config I2C_MV64XXX | 463 | config I2C_MV64XXX |
464 | tristate "Marvell mv64xxx I2C Controller" | 464 | tristate "Marvell mv64xxx I2C Controller" |
465 | depends on (MV64X60 || PLAT_ORION) && EXPERIMENTAL | 465 | depends on (MV64X60 || PLAT_ORION) |
466 | help | 466 | help |
467 | If you say yes to this option, support will be included for the | 467 | If you say yes to this option, support will be included for the |
468 | built-in I2C interface on the Marvell 64xxx line of host bridges. | 468 | built-in I2C interface on the Marvell 64xxx line of host bridges. |
@@ -483,10 +483,11 @@ config I2C_MXS | |||
483 | 483 | ||
484 | config I2C_NOMADIK | 484 | config I2C_NOMADIK |
485 | tristate "ST-Ericsson Nomadik/Ux500 I2C Controller" | 485 | tristate "ST-Ericsson Nomadik/Ux500 I2C Controller" |
486 | depends on PLAT_NOMADIK | 486 | depends on ARM_AMBA |
487 | help | 487 | help |
488 | If you say yes to this option, support will be included for the | 488 | If you say yes to this option, support will be included for the |
489 | I2C interface from ST-Ericsson's Nomadik and Ux500 architectures. | 489 | I2C interface from ST-Ericsson's Nomadik and Ux500 architectures, |
490 | as well as the STA2X11 PCIe I/O HUB. | ||
490 | 491 | ||
491 | config I2C_NUC900 | 492 | config I2C_NUC900 |
492 | tristate "NUC900 I2C Driver" | 493 | tristate "NUC900 I2C Driver" |
diff --git a/drivers/i2c/busses/i2c-at91.c b/drivers/i2c/busses/i2c-at91.c index 1679deef9c89..e24484beef07 100644 --- a/drivers/i2c/busses/i2c-at91.c +++ b/drivers/i2c/busses/i2c-at91.c | |||
@@ -279,30 +279,31 @@ static int __devexit at91_i2c_remove(struct platform_device *pdev) | |||
279 | 279 | ||
280 | /* NOTE: could save a few mA by keeping clock off outside of at91_xfer... */ | 280 | /* NOTE: could save a few mA by keeping clock off outside of at91_xfer... */ |
281 | 281 | ||
282 | static int at91_i2c_suspend(struct platform_device *pdev, pm_message_t mesg) | 282 | static int at91_i2c_suspend(struct device *dev) |
283 | { | 283 | { |
284 | clk_disable(twi_clk); | 284 | clk_disable(twi_clk); |
285 | return 0; | 285 | return 0; |
286 | } | 286 | } |
287 | 287 | ||
288 | static int at91_i2c_resume(struct platform_device *pdev) | 288 | static int at91_i2c_resume(struct device *dev) |
289 | { | 289 | { |
290 | return clk_enable(twi_clk); | 290 | return clk_enable(twi_clk); |
291 | } | 291 | } |
292 | 292 | ||
293 | static SIMPLE_DEV_PM_OPS(at91_i2c_pm, at91_i2c_suspend, at91_i2c_resume); | ||
294 | #define AT91_I2C_PM (&at91_i2c_pm) | ||
295 | |||
293 | #else | 296 | #else |
294 | #define at91_i2c_suspend NULL | 297 | #define AT91_I2C_PM NULL |
295 | #define at91_i2c_resume NULL | ||
296 | #endif | 298 | #endif |
297 | 299 | ||
298 | static struct platform_driver at91_i2c_driver = { | 300 | static struct platform_driver at91_i2c_driver = { |
299 | .probe = at91_i2c_probe, | 301 | .probe = at91_i2c_probe, |
300 | .remove = __devexit_p(at91_i2c_remove), | 302 | .remove = __devexit_p(at91_i2c_remove), |
301 | .suspend = at91_i2c_suspend, | ||
302 | .resume = at91_i2c_resume, | ||
303 | .driver = { | 303 | .driver = { |
304 | .name = "at91_i2c", | 304 | .name = "at91_i2c", |
305 | .owner = THIS_MODULE, | 305 | .owner = THIS_MODULE, |
306 | .pm = AT91_I2C_PM, | ||
306 | }, | 307 | }, |
307 | }; | 308 | }; |
308 | 309 | ||
diff --git a/drivers/i2c/busses/i2c-bfin-twi.c b/drivers/i2c/busses/i2c-bfin-twi.c index cdb59e5b23f7..0cf780fd6ef1 100644 --- a/drivers/i2c/busses/i2c-bfin-twi.c +++ b/drivers/i2c/busses/i2c-bfin-twi.c | |||
@@ -25,6 +25,7 @@ | |||
25 | #include <asm/blackfin.h> | 25 | #include <asm/blackfin.h> |
26 | #include <asm/portmux.h> | 26 | #include <asm/portmux.h> |
27 | #include <asm/irq.h> | 27 | #include <asm/irq.h> |
28 | #include <asm/bfin_twi.h> | ||
28 | 29 | ||
29 | /* SMBus mode*/ | 30 | /* SMBus mode*/ |
30 | #define TWI_I2C_MODE_STANDARD 1 | 31 | #define TWI_I2C_MODE_STANDARD 1 |
@@ -32,56 +33,6 @@ | |||
32 | #define TWI_I2C_MODE_COMBINED 3 | 33 | #define TWI_I2C_MODE_COMBINED 3 |
33 | #define TWI_I2C_MODE_REPEAT 4 | 34 | #define TWI_I2C_MODE_REPEAT 4 |
34 | 35 | ||
35 | struct bfin_twi_iface { | ||
36 | int irq; | ||
37 | spinlock_t lock; | ||
38 | char read_write; | ||
39 | u8 command; | ||
40 | u8 *transPtr; | ||
41 | int readNum; | ||
42 | int writeNum; | ||
43 | int cur_mode; | ||
44 | int manual_stop; | ||
45 | int result; | ||
46 | struct i2c_adapter adap; | ||
47 | struct completion complete; | ||
48 | struct i2c_msg *pmsg; | ||
49 | int msg_num; | ||
50 | int cur_msg; | ||
51 | u16 saved_clkdiv; | ||
52 | u16 saved_control; | ||
53 | void __iomem *regs_base; | ||
54 | }; | ||
55 | |||
56 | |||
57 | #define DEFINE_TWI_REG(reg, off) \ | ||
58 | static inline u16 read_##reg(struct bfin_twi_iface *iface) \ | ||
59 | { return bfin_read16(iface->regs_base + (off)); } \ | ||
60 | static inline void write_##reg(struct bfin_twi_iface *iface, u16 v) \ | ||
61 | { bfin_write16(iface->regs_base + (off), v); } | ||
62 | |||
63 | DEFINE_TWI_REG(CLKDIV, 0x00) | ||
64 | DEFINE_TWI_REG(CONTROL, 0x04) | ||
65 | DEFINE_TWI_REG(SLAVE_CTL, 0x08) | ||
66 | DEFINE_TWI_REG(SLAVE_STAT, 0x0C) | ||
67 | DEFINE_TWI_REG(SLAVE_ADDR, 0x10) | ||
68 | DEFINE_TWI_REG(MASTER_CTL, 0x14) | ||
69 | DEFINE_TWI_REG(MASTER_STAT, 0x18) | ||
70 | DEFINE_TWI_REG(MASTER_ADDR, 0x1C) | ||
71 | DEFINE_TWI_REG(INT_STAT, 0x20) | ||
72 | DEFINE_TWI_REG(INT_MASK, 0x24) | ||
73 | DEFINE_TWI_REG(FIFO_CTL, 0x28) | ||
74 | DEFINE_TWI_REG(FIFO_STAT, 0x2C) | ||
75 | DEFINE_TWI_REG(XMT_DATA8, 0x80) | ||
76 | DEFINE_TWI_REG(XMT_DATA16, 0x84) | ||
77 | DEFINE_TWI_REG(RCV_DATA8, 0x88) | ||
78 | DEFINE_TWI_REG(RCV_DATA16, 0x8C) | ||
79 | |||
80 | static const u16 pin_req[2][3] = { | ||
81 | {P_TWI0_SCL, P_TWI0_SDA, 0}, | ||
82 | {P_TWI1_SCL, P_TWI1_SDA, 0}, | ||
83 | }; | ||
84 | |||
85 | static void bfin_twi_handle_interrupt(struct bfin_twi_iface *iface, | 36 | static void bfin_twi_handle_interrupt(struct bfin_twi_iface *iface, |
86 | unsigned short twi_int_status) | 37 | unsigned short twi_int_status) |
87 | { | 38 | { |
@@ -99,7 +50,7 @@ static void bfin_twi_handle_interrupt(struct bfin_twi_iface *iface, | |||
99 | */ | 50 | */ |
100 | else if (iface->cur_mode == TWI_I2C_MODE_COMBINED) | 51 | else if (iface->cur_mode == TWI_I2C_MODE_COMBINED) |
101 | write_MASTER_CTL(iface, | 52 | write_MASTER_CTL(iface, |
102 | read_MASTER_CTL(iface) | MDIR | RSTART); | 53 | read_MASTER_CTL(iface) | MDIR); |
103 | else if (iface->manual_stop) | 54 | else if (iface->manual_stop) |
104 | write_MASTER_CTL(iface, | 55 | write_MASTER_CTL(iface, |
105 | read_MASTER_CTL(iface) | STOP); | 56 | read_MASTER_CTL(iface) | STOP); |
@@ -107,10 +58,10 @@ static void bfin_twi_handle_interrupt(struct bfin_twi_iface *iface, | |||
107 | iface->cur_msg + 1 < iface->msg_num) { | 58 | iface->cur_msg + 1 < iface->msg_num) { |
108 | if (iface->pmsg[iface->cur_msg + 1].flags & I2C_M_RD) | 59 | if (iface->pmsg[iface->cur_msg + 1].flags & I2C_M_RD) |
109 | write_MASTER_CTL(iface, | 60 | write_MASTER_CTL(iface, |
110 | read_MASTER_CTL(iface) | RSTART | MDIR); | 61 | read_MASTER_CTL(iface) | MDIR); |
111 | else | 62 | else |
112 | write_MASTER_CTL(iface, | 63 | write_MASTER_CTL(iface, |
113 | (read_MASTER_CTL(iface) | RSTART) & ~MDIR); | 64 | read_MASTER_CTL(iface) & ~MDIR); |
114 | } | 65 | } |
115 | } | 66 | } |
116 | if (twi_int_status & RCVSERV) { | 67 | if (twi_int_status & RCVSERV) { |
@@ -130,17 +81,25 @@ static void bfin_twi_handle_interrupt(struct bfin_twi_iface *iface, | |||
130 | } | 81 | } |
131 | iface->transPtr++; | 82 | iface->transPtr++; |
132 | iface->readNum--; | 83 | iface->readNum--; |
133 | } else if (iface->manual_stop) { | 84 | } |
134 | write_MASTER_CTL(iface, | 85 | |
135 | read_MASTER_CTL(iface) | STOP); | 86 | if (iface->readNum == 0) { |
136 | } else if (iface->cur_mode == TWI_I2C_MODE_REPEAT && | 87 | if (iface->manual_stop) { |
137 | iface->cur_msg + 1 < iface->msg_num) { | 88 | /* Temporary workaround to avoid possible bus stall - |
138 | if (iface->pmsg[iface->cur_msg + 1].flags & I2C_M_RD) | 89 | * Flush FIFO before issuing the STOP condition |
139 | write_MASTER_CTL(iface, | 90 | */ |
140 | read_MASTER_CTL(iface) | RSTART | MDIR); | 91 | read_RCV_DATA16(iface); |
141 | else | ||
142 | write_MASTER_CTL(iface, | 92 | write_MASTER_CTL(iface, |
143 | (read_MASTER_CTL(iface) | RSTART) & ~MDIR); | 93 | read_MASTER_CTL(iface) | STOP); |
94 | } else if (iface->cur_mode == TWI_I2C_MODE_REPEAT && | ||
95 | iface->cur_msg + 1 < iface->msg_num) { | ||
96 | if (iface->pmsg[iface->cur_msg + 1].flags & I2C_M_RD) | ||
97 | write_MASTER_CTL(iface, | ||
98 | read_MASTER_CTL(iface) | MDIR); | ||
99 | else | ||
100 | write_MASTER_CTL(iface, | ||
101 | read_MASTER_CTL(iface) & ~MDIR); | ||
102 | } | ||
144 | } | 103 | } |
145 | } | 104 | } |
146 | if (twi_int_status & MERR) { | 105 | if (twi_int_status & MERR) { |
@@ -193,7 +152,8 @@ static void bfin_twi_handle_interrupt(struct bfin_twi_iface *iface, | |||
193 | return; | 152 | return; |
194 | } | 153 | } |
195 | if (twi_int_status & MCOMP) { | 154 | if (twi_int_status & MCOMP) { |
196 | if ((read_MASTER_CTL(iface) & MEN) == 0 && | 155 | if (twi_int_status & (XMTSERV | RCVSERV) && |
156 | (read_MASTER_CTL(iface) & MEN) == 0 && | ||
197 | (iface->cur_mode == TWI_I2C_MODE_REPEAT || | 157 | (iface->cur_mode == TWI_I2C_MODE_REPEAT || |
198 | iface->cur_mode == TWI_I2C_MODE_COMBINED)) { | 158 | iface->cur_mode == TWI_I2C_MODE_COMBINED)) { |
199 | iface->result = -1; | 159 | iface->result = -1; |
@@ -221,7 +181,7 @@ static void bfin_twi_handle_interrupt(struct bfin_twi_iface *iface, | |||
221 | write_MASTER_CTL(iface, | 181 | write_MASTER_CTL(iface, |
222 | read_MASTER_CTL(iface) & ~RSTART); | 182 | read_MASTER_CTL(iface) & ~RSTART); |
223 | } else if (iface->cur_mode == TWI_I2C_MODE_REPEAT && | 183 | } else if (iface->cur_mode == TWI_I2C_MODE_REPEAT && |
224 | iface->cur_msg+1 < iface->msg_num) { | 184 | iface->cur_msg + 1 < iface->msg_num) { |
225 | iface->cur_msg++; | 185 | iface->cur_msg++; |
226 | iface->transPtr = iface->pmsg[iface->cur_msg].buf; | 186 | iface->transPtr = iface->pmsg[iface->cur_msg].buf; |
227 | iface->writeNum = iface->readNum = | 187 | iface->writeNum = iface->readNum = |
@@ -241,27 +201,29 @@ static void bfin_twi_handle_interrupt(struct bfin_twi_iface *iface, | |||
241 | } | 201 | } |
242 | } | 202 | } |
243 | 203 | ||
244 | if (iface->pmsg[iface->cur_msg].len <= 255) | 204 | if (iface->pmsg[iface->cur_msg].len <= 255) { |
245 | write_MASTER_CTL(iface, | 205 | write_MASTER_CTL(iface, |
246 | (read_MASTER_CTL(iface) & | 206 | (read_MASTER_CTL(iface) & |
247 | (~(0xff << 6))) | | 207 | (~(0xff << 6))) | |
248 | (iface->pmsg[iface->cur_msg].len << 6)); | 208 | (iface->pmsg[iface->cur_msg].len << 6)); |
249 | else { | 209 | iface->manual_stop = 0; |
210 | } else { | ||
250 | write_MASTER_CTL(iface, | 211 | write_MASTER_CTL(iface, |
251 | (read_MASTER_CTL(iface) | | 212 | (read_MASTER_CTL(iface) | |
252 | (0xff << 6))); | 213 | (0xff << 6))); |
253 | iface->manual_stop = 1; | 214 | iface->manual_stop = 1; |
254 | } | 215 | } |
255 | /* remove restart bit and enable master receive */ | 216 | /* remove restart bit before last message */ |
256 | write_MASTER_CTL(iface, | 217 | if (iface->cur_msg + 1 == iface->msg_num) |
257 | read_MASTER_CTL(iface) & ~RSTART); | 218 | write_MASTER_CTL(iface, |
219 | read_MASTER_CTL(iface) & ~RSTART); | ||
258 | } else { | 220 | } else { |
259 | iface->result = 1; | 221 | iface->result = 1; |
260 | write_INT_MASK(iface, 0); | 222 | write_INT_MASK(iface, 0); |
261 | write_MASTER_CTL(iface, 0); | 223 | write_MASTER_CTL(iface, 0); |
262 | } | 224 | } |
225 | complete(&iface->complete); | ||
263 | } | 226 | } |
264 | complete(&iface->complete); | ||
265 | } | 227 | } |
266 | 228 | ||
267 | /* Interrupt handler */ | 229 | /* Interrupt handler */ |
@@ -298,8 +260,8 @@ static int bfin_twi_do_master_xfer(struct i2c_adapter *adap, | |||
298 | if (!(read_CONTROL(iface) & TWI_ENA)) | 260 | if (!(read_CONTROL(iface) & TWI_ENA)) |
299 | return -ENXIO; | 261 | return -ENXIO; |
300 | 262 | ||
301 | while (read_MASTER_STAT(iface) & BUSBUSY) | 263 | if (read_MASTER_STAT(iface) & BUSBUSY) |
302 | yield(); | 264 | return -EAGAIN; |
303 | 265 | ||
304 | iface->pmsg = msgs; | 266 | iface->pmsg = msgs; |
305 | iface->msg_num = num; | 267 | iface->msg_num = num; |
@@ -311,7 +273,8 @@ static int bfin_twi_do_master_xfer(struct i2c_adapter *adap, | |||
311 | return -EINVAL; | 273 | return -EINVAL; |
312 | } | 274 | } |
313 | 275 | ||
314 | iface->cur_mode = TWI_I2C_MODE_REPEAT; | 276 | if (iface->msg_num > 1) |
277 | iface->cur_mode = TWI_I2C_MODE_REPEAT; | ||
315 | iface->manual_stop = 0; | 278 | iface->manual_stop = 0; |
316 | iface->transPtr = pmsg->buf; | 279 | iface->transPtr = pmsg->buf; |
317 | iface->writeNum = iface->readNum = pmsg->len; | 280 | iface->writeNum = iface->readNum = pmsg->len; |
@@ -356,6 +319,7 @@ static int bfin_twi_do_master_xfer(struct i2c_adapter *adap, | |||
356 | 319 | ||
357 | /* Master enable */ | 320 | /* Master enable */ |
358 | write_MASTER_CTL(iface, read_MASTER_CTL(iface) | MEN | | 321 | write_MASTER_CTL(iface, read_MASTER_CTL(iface) | MEN | |
322 | (iface->msg_num > 1 ? RSTART : 0) | | ||
359 | ((iface->read_write == I2C_SMBUS_READ) ? MDIR : 0) | | 323 | ((iface->read_write == I2C_SMBUS_READ) ? MDIR : 0) | |
360 | ((CONFIG_I2C_BLACKFIN_TWI_CLK_KHZ > 100) ? FAST : 0)); | 324 | ((CONFIG_I2C_BLACKFIN_TWI_CLK_KHZ > 100) ? FAST : 0)); |
361 | SSYNC(); | 325 | SSYNC(); |
@@ -398,8 +362,8 @@ int bfin_twi_do_smbus_xfer(struct i2c_adapter *adap, u16 addr, | |||
398 | if (!(read_CONTROL(iface) & TWI_ENA)) | 362 | if (!(read_CONTROL(iface) & TWI_ENA)) |
399 | return -ENXIO; | 363 | return -ENXIO; |
400 | 364 | ||
401 | while (read_MASTER_STAT(iface) & BUSBUSY) | 365 | if (read_MASTER_STAT(iface) & BUSBUSY) |
402 | yield(); | 366 | return -EAGAIN; |
403 | 367 | ||
404 | iface->writeNum = 0; | 368 | iface->writeNum = 0; |
405 | iface->readNum = 0; | 369 | iface->readNum = 0; |
@@ -520,7 +484,7 @@ int bfin_twi_do_smbus_xfer(struct i2c_adapter *adap, u16 addr, | |||
520 | else | 484 | else |
521 | write_MASTER_CTL(iface, 0x1 << 6); | 485 | write_MASTER_CTL(iface, 0x1 << 6); |
522 | /* Master enable */ | 486 | /* Master enable */ |
523 | write_MASTER_CTL(iface, read_MASTER_CTL(iface) | MEN | | 487 | write_MASTER_CTL(iface, read_MASTER_CTL(iface) | MEN | RSTART | |
524 | ((CONFIG_I2C_BLACKFIN_TWI_CLK_KHZ>100) ? FAST : 0)); | 488 | ((CONFIG_I2C_BLACKFIN_TWI_CLK_KHZ>100) ? FAST : 0)); |
525 | break; | 489 | break; |
526 | default: | 490 | default: |
@@ -611,9 +575,9 @@ static struct i2c_algorithm bfin_twi_algorithm = { | |||
611 | .functionality = bfin_twi_functionality, | 575 | .functionality = bfin_twi_functionality, |
612 | }; | 576 | }; |
613 | 577 | ||
614 | static int i2c_bfin_twi_suspend(struct platform_device *pdev, pm_message_t state) | 578 | static int i2c_bfin_twi_suspend(struct device *dev) |
615 | { | 579 | { |
616 | struct bfin_twi_iface *iface = platform_get_drvdata(pdev); | 580 | struct bfin_twi_iface *iface = dev_get_drvdata(dev); |
617 | 581 | ||
618 | iface->saved_clkdiv = read_CLKDIV(iface); | 582 | iface->saved_clkdiv = read_CLKDIV(iface); |
619 | iface->saved_control = read_CONTROL(iface); | 583 | iface->saved_control = read_CONTROL(iface); |
@@ -626,14 +590,14 @@ static int i2c_bfin_twi_suspend(struct platform_device *pdev, pm_message_t state | |||
626 | return 0; | 590 | return 0; |
627 | } | 591 | } |
628 | 592 | ||
629 | static int i2c_bfin_twi_resume(struct platform_device *pdev) | 593 | static int i2c_bfin_twi_resume(struct device *dev) |
630 | { | 594 | { |
631 | struct bfin_twi_iface *iface = platform_get_drvdata(pdev); | 595 | struct bfin_twi_iface *iface = dev_get_drvdata(dev); |
632 | 596 | ||
633 | int rc = request_irq(iface->irq, bfin_twi_interrupt_entry, | 597 | int rc = request_irq(iface->irq, bfin_twi_interrupt_entry, |
634 | 0, pdev->name, iface); | 598 | 0, to_platform_device(dev)->name, iface); |
635 | if (rc) { | 599 | if (rc) { |
636 | dev_err(&pdev->dev, "Can't get IRQ %d !\n", iface->irq); | 600 | dev_err(dev, "Can't get IRQ %d !\n", iface->irq); |
637 | return -ENODEV; | 601 | return -ENODEV; |
638 | } | 602 | } |
639 | 603 | ||
@@ -646,6 +610,9 @@ static int i2c_bfin_twi_resume(struct platform_device *pdev) | |||
646 | return 0; | 610 | return 0; |
647 | } | 611 | } |
648 | 612 | ||
613 | static SIMPLE_DEV_PM_OPS(i2c_bfin_twi_pm, | ||
614 | i2c_bfin_twi_suspend, i2c_bfin_twi_resume); | ||
615 | |||
649 | static int i2c_bfin_twi_probe(struct platform_device *pdev) | 616 | static int i2c_bfin_twi_probe(struct platform_device *pdev) |
650 | { | 617 | { |
651 | struct bfin_twi_iface *iface; | 618 | struct bfin_twi_iface *iface; |
@@ -695,7 +662,8 @@ static int i2c_bfin_twi_probe(struct platform_device *pdev) | |||
695 | p_adap->timeout = 5 * HZ; | 662 | p_adap->timeout = 5 * HZ; |
696 | p_adap->retries = 3; | 663 | p_adap->retries = 3; |
697 | 664 | ||
698 | rc = peripheral_request_list(pin_req[pdev->id], "i2c-bfin-twi"); | 665 | rc = peripheral_request_list((unsigned short *)pdev->dev.platform_data, |
666 | "i2c-bfin-twi"); | ||
699 | if (rc) { | 667 | if (rc) { |
700 | dev_err(&pdev->dev, "Can't setup pin mux!\n"); | 668 | dev_err(&pdev->dev, "Can't setup pin mux!\n"); |
701 | goto out_error_pin_mux; | 669 | goto out_error_pin_mux; |
@@ -742,7 +710,7 @@ out_error_add_adapter: | |||
742 | free_irq(iface->irq, iface); | 710 | free_irq(iface->irq, iface); |
743 | out_error_req_irq: | 711 | out_error_req_irq: |
744 | out_error_no_irq: | 712 | out_error_no_irq: |
745 | peripheral_free_list(pin_req[pdev->id]); | 713 | peripheral_free_list((unsigned short *)pdev->dev.platform_data); |
746 | out_error_pin_mux: | 714 | out_error_pin_mux: |
747 | iounmap(iface->regs_base); | 715 | iounmap(iface->regs_base); |
748 | out_error_ioremap: | 716 | out_error_ioremap: |
@@ -760,7 +728,7 @@ static int i2c_bfin_twi_remove(struct platform_device *pdev) | |||
760 | 728 | ||
761 | i2c_del_adapter(&(iface->adap)); | 729 | i2c_del_adapter(&(iface->adap)); |
762 | free_irq(iface->irq, iface); | 730 | free_irq(iface->irq, iface); |
763 | peripheral_free_list(pin_req[pdev->id]); | 731 | peripheral_free_list((unsigned short *)pdev->dev.platform_data); |
764 | iounmap(iface->regs_base); | 732 | iounmap(iface->regs_base); |
765 | kfree(iface); | 733 | kfree(iface); |
766 | 734 | ||
@@ -770,11 +738,10 @@ static int i2c_bfin_twi_remove(struct platform_device *pdev) | |||
770 | static struct platform_driver i2c_bfin_twi_driver = { | 738 | static struct platform_driver i2c_bfin_twi_driver = { |
771 | .probe = i2c_bfin_twi_probe, | 739 | .probe = i2c_bfin_twi_probe, |
772 | .remove = i2c_bfin_twi_remove, | 740 | .remove = i2c_bfin_twi_remove, |
773 | .suspend = i2c_bfin_twi_suspend, | ||
774 | .resume = i2c_bfin_twi_resume, | ||
775 | .driver = { | 741 | .driver = { |
776 | .name = "i2c-bfin-twi", | 742 | .name = "i2c-bfin-twi", |
777 | .owner = THIS_MODULE, | 743 | .owner = THIS_MODULE, |
744 | .pm = &i2c_bfin_twi_pm, | ||
778 | }, | 745 | }, |
779 | }; | 746 | }; |
780 | 747 | ||
diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c index 370031ac8200..0722f869465c 100644 --- a/drivers/i2c/busses/i2c-imx.c +++ b/drivers/i2c/busses/i2c-imx.c | |||
@@ -117,10 +117,8 @@ static u16 __initdata i2c_clk_div[50][2] = { | |||
117 | 117 | ||
118 | struct imx_i2c_struct { | 118 | struct imx_i2c_struct { |
119 | struct i2c_adapter adapter; | 119 | struct i2c_adapter adapter; |
120 | struct resource *res; | ||
121 | struct clk *clk; | 120 | struct clk *clk; |
122 | void __iomem *base; | 121 | void __iomem *base; |
123 | int irq; | ||
124 | wait_queue_head_t queue; | 122 | wait_queue_head_t queue; |
125 | unsigned long i2csr; | 123 | unsigned long i2csr; |
126 | unsigned int disable_delay; | 124 | unsigned int disable_delay; |
@@ -472,9 +470,8 @@ static int __init i2c_imx_probe(struct platform_device *pdev) | |||
472 | struct imxi2c_platform_data *pdata = pdev->dev.platform_data; | 470 | struct imxi2c_platform_data *pdata = pdev->dev.platform_data; |
473 | struct pinctrl *pinctrl; | 471 | struct pinctrl *pinctrl; |
474 | void __iomem *base; | 472 | void __iomem *base; |
475 | resource_size_t res_size; | 473 | int irq, ret; |
476 | int irq, bitrate; | 474 | u32 bitrate; |
477 | int ret; | ||
478 | 475 | ||
479 | dev_dbg(&pdev->dev, "<%s>\n", __func__); | 476 | dev_dbg(&pdev->dev, "<%s>\n", __func__); |
480 | 477 | ||
@@ -489,25 +486,15 @@ static int __init i2c_imx_probe(struct platform_device *pdev) | |||
489 | return -ENOENT; | 486 | return -ENOENT; |
490 | } | 487 | } |
491 | 488 | ||
492 | res_size = resource_size(res); | 489 | base = devm_request_and_ioremap(&pdev->dev, res); |
493 | 490 | if (!base) | |
494 | if (!request_mem_region(res->start, res_size, DRIVER_NAME)) { | ||
495 | dev_err(&pdev->dev, "request_mem_region failed\n"); | ||
496 | return -EBUSY; | 491 | return -EBUSY; |
497 | } | ||
498 | |||
499 | base = ioremap(res->start, res_size); | ||
500 | if (!base) { | ||
501 | dev_err(&pdev->dev, "ioremap failed\n"); | ||
502 | ret = -EIO; | ||
503 | goto fail1; | ||
504 | } | ||
505 | 492 | ||
506 | i2c_imx = kzalloc(sizeof(struct imx_i2c_struct), GFP_KERNEL); | 493 | i2c_imx = devm_kzalloc(&pdev->dev, sizeof(struct imx_i2c_struct), |
494 | GFP_KERNEL); | ||
507 | if (!i2c_imx) { | 495 | if (!i2c_imx) { |
508 | dev_err(&pdev->dev, "can't allocate interface\n"); | 496 | dev_err(&pdev->dev, "can't allocate interface\n"); |
509 | ret = -ENOMEM; | 497 | return -ENOMEM; |
510 | goto fail2; | ||
511 | } | 498 | } |
512 | 499 | ||
513 | /* Setup i2c_imx driver structure */ | 500 | /* Setup i2c_imx driver structure */ |
@@ -517,29 +504,27 @@ static int __init i2c_imx_probe(struct platform_device *pdev) | |||
517 | i2c_imx->adapter.dev.parent = &pdev->dev; | 504 | i2c_imx->adapter.dev.parent = &pdev->dev; |
518 | i2c_imx->adapter.nr = pdev->id; | 505 | i2c_imx->adapter.nr = pdev->id; |
519 | i2c_imx->adapter.dev.of_node = pdev->dev.of_node; | 506 | i2c_imx->adapter.dev.of_node = pdev->dev.of_node; |
520 | i2c_imx->irq = irq; | ||
521 | i2c_imx->base = base; | 507 | i2c_imx->base = base; |
522 | i2c_imx->res = res; | ||
523 | 508 | ||
524 | pinctrl = devm_pinctrl_get_select_default(&pdev->dev); | 509 | pinctrl = devm_pinctrl_get_select_default(&pdev->dev); |
525 | if (IS_ERR(pinctrl)) { | 510 | if (IS_ERR(pinctrl)) { |
526 | ret = PTR_ERR(pinctrl); | 511 | dev_err(&pdev->dev, "can't get/select pinctrl\n"); |
527 | goto fail3; | 512 | return PTR_ERR(pinctrl); |
528 | } | 513 | } |
529 | 514 | ||
530 | /* Get I2C clock */ | 515 | /* Get I2C clock */ |
531 | i2c_imx->clk = clk_get(&pdev->dev, "i2c_clk"); | 516 | i2c_imx->clk = devm_clk_get(&pdev->dev, NULL); |
532 | if (IS_ERR(i2c_imx->clk)) { | 517 | if (IS_ERR(i2c_imx->clk)) { |
533 | ret = PTR_ERR(i2c_imx->clk); | ||
534 | dev_err(&pdev->dev, "can't get I2C clock\n"); | 518 | dev_err(&pdev->dev, "can't get I2C clock\n"); |
535 | goto fail3; | 519 | return PTR_ERR(i2c_imx->clk); |
536 | } | 520 | } |
537 | 521 | ||
538 | /* Request IRQ */ | 522 | /* Request IRQ */ |
539 | ret = request_irq(i2c_imx->irq, i2c_imx_isr, 0, pdev->name, i2c_imx); | 523 | ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0, |
524 | pdev->name, i2c_imx); | ||
540 | if (ret) { | 525 | if (ret) { |
541 | dev_err(&pdev->dev, "can't claim irq %d\n", i2c_imx->irq); | 526 | dev_err(&pdev->dev, "can't claim irq %d\n", irq); |
542 | goto fail4; | 527 | return ret; |
543 | } | 528 | } |
544 | 529 | ||
545 | /* Init queue */ | 530 | /* Init queue */ |
@@ -564,7 +549,7 @@ static int __init i2c_imx_probe(struct platform_device *pdev) | |||
564 | ret = i2c_add_numbered_adapter(&i2c_imx->adapter); | 549 | ret = i2c_add_numbered_adapter(&i2c_imx->adapter); |
565 | if (ret < 0) { | 550 | if (ret < 0) { |
566 | dev_err(&pdev->dev, "registration failed\n"); | 551 | dev_err(&pdev->dev, "registration failed\n"); |
567 | goto fail5; | 552 | return ret; |
568 | } | 553 | } |
569 | 554 | ||
570 | of_i2c_register_devices(&i2c_imx->adapter); | 555 | of_i2c_register_devices(&i2c_imx->adapter); |
@@ -572,28 +557,16 @@ static int __init i2c_imx_probe(struct platform_device *pdev) | |||
572 | /* Set up platform driver data */ | 557 | /* Set up platform driver data */ |
573 | platform_set_drvdata(pdev, i2c_imx); | 558 | platform_set_drvdata(pdev, i2c_imx); |
574 | 559 | ||
575 | dev_dbg(&i2c_imx->adapter.dev, "claimed irq %d\n", i2c_imx->irq); | 560 | dev_dbg(&i2c_imx->adapter.dev, "claimed irq %d\n", irq); |
576 | dev_dbg(&i2c_imx->adapter.dev, "device resources from 0x%x to 0x%x\n", | 561 | dev_dbg(&i2c_imx->adapter.dev, "device resources from 0x%x to 0x%x\n", |
577 | i2c_imx->res->start, i2c_imx->res->end); | 562 | res->start, res->end); |
578 | dev_dbg(&i2c_imx->adapter.dev, "allocated %d bytes at 0x%x \n", | 563 | dev_dbg(&i2c_imx->adapter.dev, "allocated %d bytes at 0x%x\n", |
579 | res_size, i2c_imx->res->start); | 564 | resource_size(res), res->start); |
580 | dev_dbg(&i2c_imx->adapter.dev, "adapter name: \"%s\"\n", | 565 | dev_dbg(&i2c_imx->adapter.dev, "adapter name: \"%s\"\n", |
581 | i2c_imx->adapter.name); | 566 | i2c_imx->adapter.name); |
582 | dev_dbg(&i2c_imx->adapter.dev, "IMX I2C adapter registered\n"); | 567 | dev_dbg(&i2c_imx->adapter.dev, "IMX I2C adapter registered\n"); |
583 | 568 | ||
584 | return 0; /* Return OK */ | 569 | return 0; /* Return OK */ |
585 | |||
586 | fail5: | ||
587 | free_irq(i2c_imx->irq, i2c_imx); | ||
588 | fail4: | ||
589 | clk_put(i2c_imx->clk); | ||
590 | fail3: | ||
591 | kfree(i2c_imx); | ||
592 | fail2: | ||
593 | iounmap(base); | ||
594 | fail1: | ||
595 | release_mem_region(res->start, resource_size(res)); | ||
596 | return ret; /* Return error number */ | ||
597 | } | 570 | } |
598 | 571 | ||
599 | static int __exit i2c_imx_remove(struct platform_device *pdev) | 572 | static int __exit i2c_imx_remove(struct platform_device *pdev) |
@@ -605,20 +578,12 @@ static int __exit i2c_imx_remove(struct platform_device *pdev) | |||
605 | i2c_del_adapter(&i2c_imx->adapter); | 578 | i2c_del_adapter(&i2c_imx->adapter); |
606 | platform_set_drvdata(pdev, NULL); | 579 | platform_set_drvdata(pdev, NULL); |
607 | 580 | ||
608 | /* free interrupt */ | ||
609 | free_irq(i2c_imx->irq, i2c_imx); | ||
610 | |||
611 | /* setup chip registers to defaults */ | 581 | /* setup chip registers to defaults */ |
612 | writeb(0, i2c_imx->base + IMX_I2C_IADR); | 582 | writeb(0, i2c_imx->base + IMX_I2C_IADR); |
613 | writeb(0, i2c_imx->base + IMX_I2C_IFDR); | 583 | writeb(0, i2c_imx->base + IMX_I2C_IFDR); |
614 | writeb(0, i2c_imx->base + IMX_I2C_I2CR); | 584 | writeb(0, i2c_imx->base + IMX_I2C_I2CR); |
615 | writeb(0, i2c_imx->base + IMX_I2C_I2SR); | 585 | writeb(0, i2c_imx->base + IMX_I2C_I2SR); |
616 | 586 | ||
617 | clk_put(i2c_imx->clk); | ||
618 | |||
619 | iounmap(i2c_imx->base); | ||
620 | release_mem_region(i2c_imx->res->start, resource_size(i2c_imx->res)); | ||
621 | kfree(i2c_imx); | ||
622 | return 0; | 587 | return 0; |
623 | } | 588 | } |
624 | 589 | ||
diff --git a/drivers/i2c/busses/i2c-mv64xxx.c b/drivers/i2c/busses/i2c-mv64xxx.c index 4f44a33017b0..2e9d56719e99 100644 --- a/drivers/i2c/busses/i2c-mv64xxx.c +++ b/drivers/i2c/busses/i2c-mv64xxx.c | |||
@@ -18,6 +18,11 @@ | |||
18 | #include <linux/mv643xx_i2c.h> | 18 | #include <linux/mv643xx_i2c.h> |
19 | #include <linux/platform_device.h> | 19 | #include <linux/platform_device.h> |
20 | #include <linux/io.h> | 20 | #include <linux/io.h> |
21 | #include <linux/of.h> | ||
22 | #include <linux/of_irq.h> | ||
23 | #include <linux/of_i2c.h> | ||
24 | #include <linux/clk.h> | ||
25 | #include <linux/err.h> | ||
21 | 26 | ||
22 | /* Register defines */ | 27 | /* Register defines */ |
23 | #define MV64XXX_I2C_REG_SLAVE_ADDR 0x00 | 28 | #define MV64XXX_I2C_REG_SLAVE_ADDR 0x00 |
@@ -98,6 +103,9 @@ struct mv64xxx_i2c_data { | |||
98 | int rc; | 103 | int rc; |
99 | u32 freq_m; | 104 | u32 freq_m; |
100 | u32 freq_n; | 105 | u32 freq_n; |
106 | #if defined(CONFIG_HAVE_CLK) | ||
107 | struct clk *clk; | ||
108 | #endif | ||
101 | wait_queue_head_t waitq; | 109 | wait_queue_head_t waitq; |
102 | spinlock_t lock; | 110 | spinlock_t lock; |
103 | struct i2c_msg *msg; | 111 | struct i2c_msg *msg; |
@@ -521,6 +529,82 @@ mv64xxx_i2c_unmap_regs(struct mv64xxx_i2c_data *drv_data) | |||
521 | drv_data->reg_base_p = 0; | 529 | drv_data->reg_base_p = 0; |
522 | } | 530 | } |
523 | 531 | ||
532 | #ifdef CONFIG_OF | ||
533 | static int __devinit | ||
534 | mv64xxx_calc_freq(const int tclk, const int n, const int m) | ||
535 | { | ||
536 | return tclk / (10 * (m + 1) * (2 << n)); | ||
537 | } | ||
538 | |||
539 | static bool __devinit | ||
540 | mv64xxx_find_baud_factors(const u32 req_freq, const u32 tclk, u32 *best_n, | ||
541 | u32 *best_m) | ||
542 | { | ||
543 | int freq, delta, best_delta = INT_MAX; | ||
544 | int m, n; | ||
545 | |||
546 | for (n = 0; n <= 7; n++) | ||
547 | for (m = 0; m <= 15; m++) { | ||
548 | freq = mv64xxx_calc_freq(tclk, n, m); | ||
549 | delta = req_freq - freq; | ||
550 | if (delta >= 0 && delta < best_delta) { | ||
551 | *best_m = m; | ||
552 | *best_n = n; | ||
553 | best_delta = delta; | ||
554 | } | ||
555 | if (best_delta == 0) | ||
556 | return true; | ||
557 | } | ||
558 | if (best_delta == INT_MAX) | ||
559 | return false; | ||
560 | return true; | ||
561 | } | ||
562 | |||
563 | static int __devinit | ||
564 | mv64xxx_of_config(struct mv64xxx_i2c_data *drv_data, | ||
565 | struct device_node *np) | ||
566 | { | ||
567 | u32 bus_freq, tclk; | ||
568 | int rc = 0; | ||
569 | |||
570 | /* CLK is mandatory when using DT to describe the i2c bus. We | ||
571 | * need to know tclk in order to calculate bus clock | ||
572 | * factors. | ||
573 | */ | ||
574 | #if !defined(CONFIG_HAVE_CLK) | ||
575 | /* Have OF but no CLK */ | ||
576 | return -ENODEV; | ||
577 | #else | ||
578 | if (IS_ERR(drv_data->clk)) { | ||
579 | rc = -ENODEV; | ||
580 | goto out; | ||
581 | } | ||
582 | tclk = clk_get_rate(drv_data->clk); | ||
583 | of_property_read_u32(np, "clock-frequency", &bus_freq); | ||
584 | if (!mv64xxx_find_baud_factors(bus_freq, tclk, | ||
585 | &drv_data->freq_n, &drv_data->freq_m)) { | ||
586 | rc = -EINVAL; | ||
587 | goto out; | ||
588 | } | ||
589 | drv_data->irq = irq_of_parse_and_map(np, 0); | ||
590 | |||
591 | /* Its not yet defined how timeouts will be specified in device tree. | ||
592 | * So hard code the value to 1 second. | ||
593 | */ | ||
594 | drv_data->adapter.timeout = HZ; | ||
595 | out: | ||
596 | return rc; | ||
597 | #endif | ||
598 | } | ||
599 | #else /* CONFIG_OF */ | ||
600 | static int __devinit | ||
601 | mv64xxx_of_config(struct mv64xxx_i2c_data *drv_data, | ||
602 | struct device_node *np) | ||
603 | { | ||
604 | return -ENODEV; | ||
605 | } | ||
606 | #endif /* CONFIG_OF */ | ||
607 | |||
524 | static int __devinit | 608 | static int __devinit |
525 | mv64xxx_i2c_probe(struct platform_device *pd) | 609 | mv64xxx_i2c_probe(struct platform_device *pd) |
526 | { | 610 | { |
@@ -528,7 +612,7 @@ mv64xxx_i2c_probe(struct platform_device *pd) | |||
528 | struct mv64xxx_i2c_pdata *pdata = pd->dev.platform_data; | 612 | struct mv64xxx_i2c_pdata *pdata = pd->dev.platform_data; |
529 | int rc; | 613 | int rc; |
530 | 614 | ||
531 | if ((pd->id != 0) || !pdata) | 615 | if ((!pdata && !pd->dev.of_node)) |
532 | return -ENODEV; | 616 | return -ENODEV; |
533 | 617 | ||
534 | drv_data = kzalloc(sizeof(struct mv64xxx_i2c_data), GFP_KERNEL); | 618 | drv_data = kzalloc(sizeof(struct mv64xxx_i2c_data), GFP_KERNEL); |
@@ -546,19 +630,35 @@ mv64xxx_i2c_probe(struct platform_device *pd) | |||
546 | init_waitqueue_head(&drv_data->waitq); | 630 | init_waitqueue_head(&drv_data->waitq); |
547 | spin_lock_init(&drv_data->lock); | 631 | spin_lock_init(&drv_data->lock); |
548 | 632 | ||
549 | drv_data->freq_m = pdata->freq_m; | 633 | #if defined(CONFIG_HAVE_CLK) |
550 | drv_data->freq_n = pdata->freq_n; | 634 | /* Not all platforms have a clk */ |
551 | drv_data->irq = platform_get_irq(pd, 0); | 635 | drv_data->clk = clk_get(&pd->dev, NULL); |
636 | if (!IS_ERR(drv_data->clk)) { | ||
637 | clk_prepare(drv_data->clk); | ||
638 | clk_enable(drv_data->clk); | ||
639 | } | ||
640 | #endif | ||
641 | if (pdata) { | ||
642 | drv_data->freq_m = pdata->freq_m; | ||
643 | drv_data->freq_n = pdata->freq_n; | ||
644 | drv_data->irq = platform_get_irq(pd, 0); | ||
645 | drv_data->adapter.timeout = msecs_to_jiffies(pdata->timeout); | ||
646 | } else if (pd->dev.of_node) { | ||
647 | rc = mv64xxx_of_config(drv_data, pd->dev.of_node); | ||
648 | if (rc) | ||
649 | goto exit_unmap_regs; | ||
650 | } | ||
552 | if (drv_data->irq < 0) { | 651 | if (drv_data->irq < 0) { |
553 | rc = -ENXIO; | 652 | rc = -ENXIO; |
554 | goto exit_unmap_regs; | 653 | goto exit_unmap_regs; |
555 | } | 654 | } |
655 | |||
556 | drv_data->adapter.dev.parent = &pd->dev; | 656 | drv_data->adapter.dev.parent = &pd->dev; |
557 | drv_data->adapter.algo = &mv64xxx_i2c_algo; | 657 | drv_data->adapter.algo = &mv64xxx_i2c_algo; |
558 | drv_data->adapter.owner = THIS_MODULE; | 658 | drv_data->adapter.owner = THIS_MODULE; |
559 | drv_data->adapter.class = I2C_CLASS_HWMON | I2C_CLASS_SPD; | 659 | drv_data->adapter.class = I2C_CLASS_HWMON | I2C_CLASS_SPD; |
560 | drv_data->adapter.timeout = msecs_to_jiffies(pdata->timeout); | ||
561 | drv_data->adapter.nr = pd->id; | 660 | drv_data->adapter.nr = pd->id; |
661 | drv_data->adapter.dev.of_node = pd->dev.of_node; | ||
562 | platform_set_drvdata(pd, drv_data); | 662 | platform_set_drvdata(pd, drv_data); |
563 | i2c_set_adapdata(&drv_data->adapter, drv_data); | 663 | i2c_set_adapdata(&drv_data->adapter, drv_data); |
564 | 664 | ||
@@ -577,11 +677,20 @@ mv64xxx_i2c_probe(struct platform_device *pd) | |||
577 | goto exit_free_irq; | 677 | goto exit_free_irq; |
578 | } | 678 | } |
579 | 679 | ||
680 | of_i2c_register_devices(&drv_data->adapter); | ||
681 | |||
580 | return 0; | 682 | return 0; |
581 | 683 | ||
582 | exit_free_irq: | 684 | exit_free_irq: |
583 | free_irq(drv_data->irq, drv_data); | 685 | free_irq(drv_data->irq, drv_data); |
584 | exit_unmap_regs: | 686 | exit_unmap_regs: |
687 | #if defined(CONFIG_HAVE_CLK) | ||
688 | /* Not all platforms have a clk */ | ||
689 | if (!IS_ERR(drv_data->clk)) { | ||
690 | clk_disable(drv_data->clk); | ||
691 | clk_unprepare(drv_data->clk); | ||
692 | } | ||
693 | #endif | ||
585 | mv64xxx_i2c_unmap_regs(drv_data); | 694 | mv64xxx_i2c_unmap_regs(drv_data); |
586 | exit_kfree: | 695 | exit_kfree: |
587 | kfree(drv_data); | 696 | kfree(drv_data); |
@@ -597,17 +706,31 @@ mv64xxx_i2c_remove(struct platform_device *dev) | |||
597 | rc = i2c_del_adapter(&drv_data->adapter); | 706 | rc = i2c_del_adapter(&drv_data->adapter); |
598 | free_irq(drv_data->irq, drv_data); | 707 | free_irq(drv_data->irq, drv_data); |
599 | mv64xxx_i2c_unmap_regs(drv_data); | 708 | mv64xxx_i2c_unmap_regs(drv_data); |
709 | #if defined(CONFIG_HAVE_CLK) | ||
710 | /* Not all platforms have a clk */ | ||
711 | if (!IS_ERR(drv_data->clk)) { | ||
712 | clk_disable(drv_data->clk); | ||
713 | clk_unprepare(drv_data->clk); | ||
714 | } | ||
715 | #endif | ||
600 | kfree(drv_data); | 716 | kfree(drv_data); |
601 | 717 | ||
602 | return rc; | 718 | return rc; |
603 | } | 719 | } |
604 | 720 | ||
721 | static const struct of_device_id mv64xxx_i2c_of_match_table[] __devinitdata = { | ||
722 | { .compatible = "marvell,mv64xxx-i2c", }, | ||
723 | {} | ||
724 | }; | ||
725 | MODULE_DEVICE_TABLE(of, mv64xxx_i2c_of_match_table); | ||
726 | |||
605 | static struct platform_driver mv64xxx_i2c_driver = { | 727 | static struct platform_driver mv64xxx_i2c_driver = { |
606 | .probe = mv64xxx_i2c_probe, | 728 | .probe = mv64xxx_i2c_probe, |
607 | .remove = __devexit_p(mv64xxx_i2c_remove), | 729 | .remove = __devexit_p(mv64xxx_i2c_remove), |
608 | .driver = { | 730 | .driver = { |
609 | .owner = THIS_MODULE, | 731 | .owner = THIS_MODULE, |
610 | .name = MV64XXX_I2C_CTLR_NAME, | 732 | .name = MV64XXX_I2C_CTLR_NAME, |
733 | .of_match_table = of_match_ptr(mv64xxx_i2c_of_match_table), | ||
611 | }, | 734 | }, |
612 | }; | 735 | }; |
613 | 736 | ||
diff --git a/drivers/i2c/busses/i2c-mxs.c b/drivers/i2c/busses/i2c-mxs.c index 04eb441b6ce1..088c5c1ed17d 100644 --- a/drivers/i2c/busses/i2c-mxs.c +++ b/drivers/i2c/busses/i2c-mxs.c | |||
@@ -46,6 +46,10 @@ | |||
46 | #define MXS_I2C_CTRL0_DIRECTION 0x00010000 | 46 | #define MXS_I2C_CTRL0_DIRECTION 0x00010000 |
47 | #define MXS_I2C_CTRL0_XFER_COUNT(v) ((v) & 0x0000FFFF) | 47 | #define MXS_I2C_CTRL0_XFER_COUNT(v) ((v) & 0x0000FFFF) |
48 | 48 | ||
49 | #define MXS_I2C_TIMING0 (0x10) | ||
50 | #define MXS_I2C_TIMING1 (0x20) | ||
51 | #define MXS_I2C_TIMING2 (0x30) | ||
52 | |||
49 | #define MXS_I2C_CTRL1 (0x40) | 53 | #define MXS_I2C_CTRL1 (0x40) |
50 | #define MXS_I2C_CTRL1_SET (0x44) | 54 | #define MXS_I2C_CTRL1_SET (0x44) |
51 | #define MXS_I2C_CTRL1_CLR (0x48) | 55 | #define MXS_I2C_CTRL1_CLR (0x48) |
@@ -97,6 +101,35 @@ | |||
97 | #define MXS_CMD_I2C_READ (MXS_I2C_CTRL0_SEND_NAK_ON_LAST | \ | 101 | #define MXS_CMD_I2C_READ (MXS_I2C_CTRL0_SEND_NAK_ON_LAST | \ |
98 | MXS_I2C_CTRL0_MASTER_MODE) | 102 | MXS_I2C_CTRL0_MASTER_MODE) |
99 | 103 | ||
104 | struct mxs_i2c_speed_config { | ||
105 | uint32_t timing0; | ||
106 | uint32_t timing1; | ||
107 | uint32_t timing2; | ||
108 | }; | ||
109 | |||
110 | /* | ||
111 | * Timing values for the default 24MHz clock supplied into the i2c block. | ||
112 | * | ||
113 | * The bus can operate at 95kHz or at 400kHz with the following timing | ||
114 | * register configurations. The 100kHz mode isn't present because it's | ||
115 | * values are not stated in the i.MX233/i.MX28 datasheet. The 95kHz mode | ||
116 | * shall be close enough replacement. Therefore when the bus is configured | ||
117 | * for 100kHz operation, 95kHz timing settings are actually loaded. | ||
118 | * | ||
119 | * For details, see i.MX233 [25.4.2 - 25.4.4] and i.MX28 [27.5.2 - 27.5.4]. | ||
120 | */ | ||
121 | static const struct mxs_i2c_speed_config mxs_i2c_95kHz_config = { | ||
122 | .timing0 = 0x00780030, | ||
123 | .timing1 = 0x00800030, | ||
124 | .timing2 = 0x00300030, | ||
125 | }; | ||
126 | |||
127 | static const struct mxs_i2c_speed_config mxs_i2c_400kHz_config = { | ||
128 | .timing0 = 0x000f0007, | ||
129 | .timing1 = 0x001f000f, | ||
130 | .timing2 = 0x00300030, | ||
131 | }; | ||
132 | |||
100 | /** | 133 | /** |
101 | * struct mxs_i2c_dev - per device, private MXS-I2C data | 134 | * struct mxs_i2c_dev - per device, private MXS-I2C data |
102 | * | 135 | * |
@@ -112,11 +145,17 @@ struct mxs_i2c_dev { | |||
112 | struct completion cmd_complete; | 145 | struct completion cmd_complete; |
113 | u32 cmd_err; | 146 | u32 cmd_err; |
114 | struct i2c_adapter adapter; | 147 | struct i2c_adapter adapter; |
148 | const struct mxs_i2c_speed_config *speed; | ||
115 | }; | 149 | }; |
116 | 150 | ||
117 | static void mxs_i2c_reset(struct mxs_i2c_dev *i2c) | 151 | static void mxs_i2c_reset(struct mxs_i2c_dev *i2c) |
118 | { | 152 | { |
119 | stmp_reset_block(i2c->regs); | 153 | stmp_reset_block(i2c->regs); |
154 | |||
155 | writel(i2c->speed->timing0, i2c->regs + MXS_I2C_TIMING0); | ||
156 | writel(i2c->speed->timing1, i2c->regs + MXS_I2C_TIMING1); | ||
157 | writel(i2c->speed->timing2, i2c->regs + MXS_I2C_TIMING2); | ||
158 | |||
120 | writel(MXS_I2C_IRQ_MASK << 8, i2c->regs + MXS_I2C_CTRL1_SET); | 159 | writel(MXS_I2C_IRQ_MASK << 8, i2c->regs + MXS_I2C_CTRL1_SET); |
121 | writel(MXS_I2C_QUEUECTRL_PIO_QUEUE_MODE, | 160 | writel(MXS_I2C_QUEUECTRL_PIO_QUEUE_MODE, |
122 | i2c->regs + MXS_I2C_QUEUECTRL_SET); | 161 | i2c->regs + MXS_I2C_QUEUECTRL_SET); |
@@ -193,7 +232,7 @@ static int mxs_i2c_wait_for_data(struct mxs_i2c_dev *i2c) | |||
193 | 232 | ||
194 | static int mxs_i2c_finish_read(struct mxs_i2c_dev *i2c, u8 *buf, int len) | 233 | static int mxs_i2c_finish_read(struct mxs_i2c_dev *i2c, u8 *buf, int len) |
195 | { | 234 | { |
196 | u32 data; | 235 | u32 uninitialized_var(data); |
197 | int i; | 236 | int i; |
198 | 237 | ||
199 | for (i = 0; i < len; i++) { | 238 | for (i = 0; i < len; i++) { |
@@ -319,6 +358,28 @@ static const struct i2c_algorithm mxs_i2c_algo = { | |||
319 | .functionality = mxs_i2c_func, | 358 | .functionality = mxs_i2c_func, |
320 | }; | 359 | }; |
321 | 360 | ||
361 | static int mxs_i2c_get_ofdata(struct mxs_i2c_dev *i2c) | ||
362 | { | ||
363 | uint32_t speed; | ||
364 | struct device *dev = i2c->dev; | ||
365 | struct device_node *node = dev->of_node; | ||
366 | int ret; | ||
367 | |||
368 | if (!node) | ||
369 | return -EINVAL; | ||
370 | |||
371 | i2c->speed = &mxs_i2c_95kHz_config; | ||
372 | ret = of_property_read_u32(node, "clock-frequency", &speed); | ||
373 | if (ret) | ||
374 | dev_warn(dev, "No I2C speed selected, using 100kHz\n"); | ||
375 | else if (speed == 400000) | ||
376 | i2c->speed = &mxs_i2c_400kHz_config; | ||
377 | else if (speed != 100000) | ||
378 | dev_warn(dev, "Unsupported I2C speed selected, using 100kHz\n"); | ||
379 | |||
380 | return 0; | ||
381 | } | ||
382 | |||
322 | static int __devinit mxs_i2c_probe(struct platform_device *pdev) | 383 | static int __devinit mxs_i2c_probe(struct platform_device *pdev) |
323 | { | 384 | { |
324 | struct device *dev = &pdev->dev; | 385 | struct device *dev = &pdev->dev; |
@@ -358,6 +419,11 @@ static int __devinit mxs_i2c_probe(struct platform_device *pdev) | |||
358 | return err; | 419 | return err; |
359 | 420 | ||
360 | i2c->dev = dev; | 421 | i2c->dev = dev; |
422 | |||
423 | err = mxs_i2c_get_ofdata(i2c); | ||
424 | if (err) | ||
425 | return err; | ||
426 | |||
361 | platform_set_drvdata(pdev, i2c); | 427 | platform_set_drvdata(pdev, i2c); |
362 | 428 | ||
363 | /* Do reset to enforce correct startup after pinmuxing */ | 429 | /* Do reset to enforce correct startup after pinmuxing */ |
diff --git a/drivers/i2c/busses/i2c-nomadik.c b/drivers/i2c/busses/i2c-nomadik.c index a92440dbef07..5e6f1eed4f83 100644 --- a/drivers/i2c/busses/i2c-nomadik.c +++ b/drivers/i2c/busses/i2c-nomadik.c | |||
@@ -14,7 +14,8 @@ | |||
14 | */ | 14 | */ |
15 | #include <linux/init.h> | 15 | #include <linux/init.h> |
16 | #include <linux/module.h> | 16 | #include <linux/module.h> |
17 | #include <linux/platform_device.h> | 17 | #include <linux/amba/bus.h> |
18 | #include <linux/atomic.h> | ||
18 | #include <linux/slab.h> | 19 | #include <linux/slab.h> |
19 | #include <linux/interrupt.h> | 20 | #include <linux/interrupt.h> |
20 | #include <linux/i2c.h> | 21 | #include <linux/i2c.h> |
@@ -23,8 +24,7 @@ | |||
23 | #include <linux/io.h> | 24 | #include <linux/io.h> |
24 | #include <linux/regulator/consumer.h> | 25 | #include <linux/regulator/consumer.h> |
25 | #include <linux/pm_runtime.h> | 26 | #include <linux/pm_runtime.h> |
26 | 27 | #include <linux/platform_data/i2c-nomadik.h> | |
27 | #include <plat/i2c.h> | ||
28 | 28 | ||
29 | #define DRIVER_NAME "nmk-i2c" | 29 | #define DRIVER_NAME "nmk-i2c" |
30 | 30 | ||
@@ -136,7 +136,7 @@ struct i2c_nmk_client { | |||
136 | 136 | ||
137 | /** | 137 | /** |
138 | * struct nmk_i2c_dev - private data structure of the controller. | 138 | * struct nmk_i2c_dev - private data structure of the controller. |
139 | * @pdev: parent platform device. | 139 | * @adev: parent amba device. |
140 | * @adap: corresponding I2C adapter. | 140 | * @adap: corresponding I2C adapter. |
141 | * @irq: interrupt line for the controller. | 141 | * @irq: interrupt line for the controller. |
142 | * @virtbase: virtual io memory area. | 142 | * @virtbase: virtual io memory area. |
@@ -150,7 +150,7 @@ struct i2c_nmk_client { | |||
150 | * @busy: Busy doing transfer. | 150 | * @busy: Busy doing transfer. |
151 | */ | 151 | */ |
152 | struct nmk_i2c_dev { | 152 | struct nmk_i2c_dev { |
153 | struct platform_device *pdev; | 153 | struct amba_device *adev; |
154 | struct i2c_adapter adap; | 154 | struct i2c_adapter adap; |
155 | int irq; | 155 | int irq; |
156 | void __iomem *virtbase; | 156 | void __iomem *virtbase; |
@@ -217,7 +217,7 @@ static int flush_i2c_fifo(struct nmk_i2c_dev *dev) | |||
217 | } | 217 | } |
218 | } | 218 | } |
219 | 219 | ||
220 | dev_err(&dev->pdev->dev, | 220 | dev_err(&dev->adev->dev, |
221 | "flushing operation timed out giving up after %d attempts", | 221 | "flushing operation timed out giving up after %d attempts", |
222 | LOOP_ATTEMPTS); | 222 | LOOP_ATTEMPTS); |
223 | 223 | ||
@@ -276,15 +276,32 @@ exit: | |||
276 | /** | 276 | /** |
277 | * load_i2c_mcr_reg() - load the MCR register | 277 | * load_i2c_mcr_reg() - load the MCR register |
278 | * @dev: private data of controller | 278 | * @dev: private data of controller |
279 | * @flags: message flags | ||
279 | */ | 280 | */ |
280 | static u32 load_i2c_mcr_reg(struct nmk_i2c_dev *dev) | 281 | static u32 load_i2c_mcr_reg(struct nmk_i2c_dev *dev, u16 flags) |
281 | { | 282 | { |
282 | u32 mcr = 0; | 283 | u32 mcr = 0; |
284 | unsigned short slave_adr_3msb_bits; | ||
283 | 285 | ||
284 | /* 7-bit address transaction */ | ||
285 | mcr |= GEN_MASK(1, I2C_MCR_AM, 12); | ||
286 | mcr |= GEN_MASK(dev->cli.slave_adr, I2C_MCR_A7, 1); | 286 | mcr |= GEN_MASK(dev->cli.slave_adr, I2C_MCR_A7, 1); |
287 | 287 | ||
288 | if (unlikely(flags & I2C_M_TEN)) { | ||
289 | /* 10-bit address transaction */ | ||
290 | mcr |= GEN_MASK(2, I2C_MCR_AM, 12); | ||
291 | /* | ||
292 | * Get the top 3 bits. | ||
293 | * EA10 represents extended address in MCR. This includes | ||
294 | * the extension (MSB bits) of the 7 bit address loaded | ||
295 | * in A7 | ||
296 | */ | ||
297 | slave_adr_3msb_bits = (dev->cli.slave_adr >> 7) & 0x7; | ||
298 | |||
299 | mcr |= GEN_MASK(slave_adr_3msb_bits, I2C_MCR_EA10, 8); | ||
300 | } else { | ||
301 | /* 7-bit address transaction */ | ||
302 | mcr |= GEN_MASK(1, I2C_MCR_AM, 12); | ||
303 | } | ||
304 | |||
288 | /* start byte procedure not applied */ | 305 | /* start byte procedure not applied */ |
289 | mcr |= GEN_MASK(0, I2C_MCR_SB, 11); | 306 | mcr |= GEN_MASK(0, I2C_MCR_SB, 11); |
290 | 307 | ||
@@ -364,7 +381,7 @@ static void setup_i2c_controller(struct nmk_i2c_dev *dev) | |||
364 | * and high speed (up to 3.4 Mb/s) | 381 | * and high speed (up to 3.4 Mb/s) |
365 | */ | 382 | */ |
366 | if (dev->cfg.sm > I2C_FREQ_MODE_FAST) { | 383 | if (dev->cfg.sm > I2C_FREQ_MODE_FAST) { |
367 | dev_err(&dev->pdev->dev, | 384 | dev_err(&dev->adev->dev, |
368 | "do not support this mode defaulting to std. mode\n"); | 385 | "do not support this mode defaulting to std. mode\n"); |
369 | brcr2 = i2c_clk/(100000 * 2) & 0xffff; | 386 | brcr2 = i2c_clk/(100000 * 2) & 0xffff; |
370 | writel((brcr1 | brcr2), dev->virtbase + I2C_BRCR); | 387 | writel((brcr1 | brcr2), dev->virtbase + I2C_BRCR); |
@@ -381,19 +398,20 @@ static void setup_i2c_controller(struct nmk_i2c_dev *dev) | |||
381 | /** | 398 | /** |
382 | * read_i2c() - Read from I2C client device | 399 | * read_i2c() - Read from I2C client device |
383 | * @dev: private data of I2C Driver | 400 | * @dev: private data of I2C Driver |
401 | * @flags: message flags | ||
384 | * | 402 | * |
385 | * This function reads from i2c client device when controller is in | 403 | * This function reads from i2c client device when controller is in |
386 | * master mode. There is a completion timeout. If there is no transfer | 404 | * master mode. There is a completion timeout. If there is no transfer |
387 | * before timeout error is returned. | 405 | * before timeout error is returned. |
388 | */ | 406 | */ |
389 | static int read_i2c(struct nmk_i2c_dev *dev) | 407 | static int read_i2c(struct nmk_i2c_dev *dev, u16 flags) |
390 | { | 408 | { |
391 | u32 status = 0; | 409 | u32 status = 0; |
392 | u32 mcr; | 410 | u32 mcr; |
393 | u32 irq_mask = 0; | 411 | u32 irq_mask = 0; |
394 | int timeout; | 412 | int timeout; |
395 | 413 | ||
396 | mcr = load_i2c_mcr_reg(dev); | 414 | mcr = load_i2c_mcr_reg(dev, flags); |
397 | writel(mcr, dev->virtbase + I2C_MCR); | 415 | writel(mcr, dev->virtbase + I2C_MCR); |
398 | 416 | ||
399 | /* load the current CR value */ | 417 | /* load the current CR value */ |
@@ -423,7 +441,7 @@ static int read_i2c(struct nmk_i2c_dev *dev) | |||
423 | &dev->xfer_complete, dev->adap.timeout); | 441 | &dev->xfer_complete, dev->adap.timeout); |
424 | 442 | ||
425 | if (timeout < 0) { | 443 | if (timeout < 0) { |
426 | dev_err(&dev->pdev->dev, | 444 | dev_err(&dev->adev->dev, |
427 | "wait_for_completion_timeout " | 445 | "wait_for_completion_timeout " |
428 | "returned %d waiting for event\n", timeout); | 446 | "returned %d waiting for event\n", timeout); |
429 | status = timeout; | 447 | status = timeout; |
@@ -431,7 +449,7 @@ static int read_i2c(struct nmk_i2c_dev *dev) | |||
431 | 449 | ||
432 | if (timeout == 0) { | 450 | if (timeout == 0) { |
433 | /* Controller timed out */ | 451 | /* Controller timed out */ |
434 | dev_err(&dev->pdev->dev, "read from slave 0x%x timed out\n", | 452 | dev_err(&dev->adev->dev, "read from slave 0x%x timed out\n", |
435 | dev->cli.slave_adr); | 453 | dev->cli.slave_adr); |
436 | status = -ETIMEDOUT; | 454 | status = -ETIMEDOUT; |
437 | } | 455 | } |
@@ -459,17 +477,18 @@ static void fill_tx_fifo(struct nmk_i2c_dev *dev, int no_bytes) | |||
459 | /** | 477 | /** |
460 | * write_i2c() - Write data to I2C client. | 478 | * write_i2c() - Write data to I2C client. |
461 | * @dev: private data of I2C Driver | 479 | * @dev: private data of I2C Driver |
480 | * @flags: message flags | ||
462 | * | 481 | * |
463 | * This function writes data to I2C client | 482 | * This function writes data to I2C client |
464 | */ | 483 | */ |
465 | static int write_i2c(struct nmk_i2c_dev *dev) | 484 | static int write_i2c(struct nmk_i2c_dev *dev, u16 flags) |
466 | { | 485 | { |
467 | u32 status = 0; | 486 | u32 status = 0; |
468 | u32 mcr; | 487 | u32 mcr; |
469 | u32 irq_mask = 0; | 488 | u32 irq_mask = 0; |
470 | int timeout; | 489 | int timeout; |
471 | 490 | ||
472 | mcr = load_i2c_mcr_reg(dev); | 491 | mcr = load_i2c_mcr_reg(dev, flags); |
473 | 492 | ||
474 | writel(mcr, dev->virtbase + I2C_MCR); | 493 | writel(mcr, dev->virtbase + I2C_MCR); |
475 | 494 | ||
@@ -510,7 +529,7 @@ static int write_i2c(struct nmk_i2c_dev *dev) | |||
510 | &dev->xfer_complete, dev->adap.timeout); | 529 | &dev->xfer_complete, dev->adap.timeout); |
511 | 530 | ||
512 | if (timeout < 0) { | 531 | if (timeout < 0) { |
513 | dev_err(&dev->pdev->dev, | 532 | dev_err(&dev->adev->dev, |
514 | "wait_for_completion_timeout " | 533 | "wait_for_completion_timeout " |
515 | "returned %d waiting for event\n", timeout); | 534 | "returned %d waiting for event\n", timeout); |
516 | status = timeout; | 535 | status = timeout; |
@@ -518,7 +537,7 @@ static int write_i2c(struct nmk_i2c_dev *dev) | |||
518 | 537 | ||
519 | if (timeout == 0) { | 538 | if (timeout == 0) { |
520 | /* Controller timed out */ | 539 | /* Controller timed out */ |
521 | dev_err(&dev->pdev->dev, "write to slave 0x%x timed out\n", | 540 | dev_err(&dev->adev->dev, "write to slave 0x%x timed out\n", |
522 | dev->cli.slave_adr); | 541 | dev->cli.slave_adr); |
523 | status = -ETIMEDOUT; | 542 | status = -ETIMEDOUT; |
524 | } | 543 | } |
@@ -538,11 +557,11 @@ static int nmk_i2c_xfer_one(struct nmk_i2c_dev *dev, u16 flags) | |||
538 | if (flags & I2C_M_RD) { | 557 | if (flags & I2C_M_RD) { |
539 | /* read operation */ | 558 | /* read operation */ |
540 | dev->cli.operation = I2C_READ; | 559 | dev->cli.operation = I2C_READ; |
541 | status = read_i2c(dev); | 560 | status = read_i2c(dev, flags); |
542 | } else { | 561 | } else { |
543 | /* write operation */ | 562 | /* write operation */ |
544 | dev->cli.operation = I2C_WRITE; | 563 | dev->cli.operation = I2C_WRITE; |
545 | status = write_i2c(dev); | 564 | status = write_i2c(dev, flags); |
546 | } | 565 | } |
547 | 566 | ||
548 | if (status || (dev->result)) { | 567 | if (status || (dev->result)) { |
@@ -557,7 +576,7 @@ static int nmk_i2c_xfer_one(struct nmk_i2c_dev *dev, u16 flags) | |||
557 | if (((i2c_sr >> 2) & 0x3) == 0x3) { | 576 | if (((i2c_sr >> 2) & 0x3) == 0x3) { |
558 | /* get the abort cause */ | 577 | /* get the abort cause */ |
559 | cause = (i2c_sr >> 4) & 0x7; | 578 | cause = (i2c_sr >> 4) & 0x7; |
560 | dev_err(&dev->pdev->dev, "%s\n", | 579 | dev_err(&dev->adev->dev, "%s\n", |
561 | cause >= ARRAY_SIZE(abort_causes) ? | 580 | cause >= ARRAY_SIZE(abort_causes) ? |
562 | "unknown reason" : | 581 | "unknown reason" : |
563 | abort_causes[cause]); | 582 | abort_causes[cause]); |
@@ -630,7 +649,7 @@ static int nmk_i2c_xfer(struct i2c_adapter *i2c_adap, | |||
630 | 649 | ||
631 | if (dev->regulator) | 650 | if (dev->regulator) |
632 | regulator_enable(dev->regulator); | 651 | regulator_enable(dev->regulator); |
633 | pm_runtime_get_sync(&dev->pdev->dev); | 652 | pm_runtime_get_sync(&dev->adev->dev); |
634 | 653 | ||
635 | clk_enable(dev->clk); | 654 | clk_enable(dev->clk); |
636 | 655 | ||
@@ -644,13 +663,6 @@ static int nmk_i2c_xfer(struct i2c_adapter *i2c_adap, | |||
644 | setup_i2c_controller(dev); | 663 | setup_i2c_controller(dev); |
645 | 664 | ||
646 | for (i = 0; i < num_msgs; i++) { | 665 | for (i = 0; i < num_msgs; i++) { |
647 | if (unlikely(msgs[i].flags & I2C_M_TEN)) { | ||
648 | dev_err(&dev->pdev->dev, | ||
649 | "10 bit addressing not supported\n"); | ||
650 | |||
651 | status = -EINVAL; | ||
652 | goto out; | ||
653 | } | ||
654 | dev->cli.slave_adr = msgs[i].addr; | 666 | dev->cli.slave_adr = msgs[i].addr; |
655 | dev->cli.buffer = msgs[i].buf; | 667 | dev->cli.buffer = msgs[i].buf; |
656 | dev->cli.count = msgs[i].len; | 668 | dev->cli.count = msgs[i].len; |
@@ -667,7 +679,7 @@ static int nmk_i2c_xfer(struct i2c_adapter *i2c_adap, | |||
667 | 679 | ||
668 | out: | 680 | out: |
669 | clk_disable(dev->clk); | 681 | clk_disable(dev->clk); |
670 | pm_runtime_put_sync(&dev->pdev->dev); | 682 | pm_runtime_put_sync(&dev->adev->dev); |
671 | if (dev->regulator) | 683 | if (dev->regulator) |
672 | regulator_disable(dev->regulator); | 684 | regulator_disable(dev->regulator); |
673 | 685 | ||
@@ -790,7 +802,7 @@ static irqreturn_t i2c_irq_handler(int irq, void *arg) | |||
790 | 802 | ||
791 | if (dev->cli.count) { | 803 | if (dev->cli.count) { |
792 | dev->result = -EIO; | 804 | dev->result = -EIO; |
793 | dev_err(&dev->pdev->dev, | 805 | dev_err(&dev->adev->dev, |
794 | "%lu bytes still remain to be xfered\n", | 806 | "%lu bytes still remain to be xfered\n", |
795 | dev->cli.count); | 807 | dev->cli.count); |
796 | (void) init_hw(dev); | 808 | (void) init_hw(dev); |
@@ -834,7 +846,7 @@ static irqreturn_t i2c_irq_handler(int irq, void *arg) | |||
834 | dev->result = -EIO; | 846 | dev->result = -EIO; |
835 | (void) init_hw(dev); | 847 | (void) init_hw(dev); |
836 | 848 | ||
837 | dev_err(&dev->pdev->dev, "Tx Fifo Over run\n"); | 849 | dev_err(&dev->adev->dev, "Tx Fifo Over run\n"); |
838 | complete(&dev->xfer_complete); | 850 | complete(&dev->xfer_complete); |
839 | 851 | ||
840 | break; | 852 | break; |
@@ -847,10 +859,10 @@ static irqreturn_t i2c_irq_handler(int irq, void *arg) | |||
847 | case I2C_IT_RFSE: | 859 | case I2C_IT_RFSE: |
848 | case I2C_IT_WTSR: | 860 | case I2C_IT_WTSR: |
849 | case I2C_IT_STD: | 861 | case I2C_IT_STD: |
850 | dev_err(&dev->pdev->dev, "unhandled Interrupt\n"); | 862 | dev_err(&dev->adev->dev, "unhandled Interrupt\n"); |
851 | break; | 863 | break; |
852 | default: | 864 | default: |
853 | dev_err(&dev->pdev->dev, "spurious Interrupt..\n"); | 865 | dev_err(&dev->adev->dev, "spurious Interrupt..\n"); |
854 | break; | 866 | break; |
855 | } | 867 | } |
856 | 868 | ||
@@ -861,8 +873,8 @@ static irqreturn_t i2c_irq_handler(int irq, void *arg) | |||
861 | #ifdef CONFIG_PM | 873 | #ifdef CONFIG_PM |
862 | static int nmk_i2c_suspend(struct device *dev) | 874 | static int nmk_i2c_suspend(struct device *dev) |
863 | { | 875 | { |
864 | struct platform_device *pdev = to_platform_device(dev); | 876 | struct amba_device *adev = to_amba_device(dev); |
865 | struct nmk_i2c_dev *nmk_i2c = platform_get_drvdata(pdev); | 877 | struct nmk_i2c_dev *nmk_i2c = amba_get_drvdata(adev); |
866 | 878 | ||
867 | if (nmk_i2c->busy) | 879 | if (nmk_i2c->busy) |
868 | return -EBUSY; | 880 | return -EBUSY; |
@@ -891,7 +903,7 @@ static const struct dev_pm_ops nmk_i2c_pm = { | |||
891 | 903 | ||
892 | static unsigned int nmk_i2c_functionality(struct i2c_adapter *adap) | 904 | static unsigned int nmk_i2c_functionality(struct i2c_adapter *adap) |
893 | { | 905 | { |
894 | return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL; | 906 | return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL | I2C_FUNC_10BIT_ADDR; |
895 | } | 907 | } |
896 | 908 | ||
897 | static const struct i2c_algorithm nmk_i2c_algo = { | 909 | static const struct i2c_algorithm nmk_i2c_algo = { |
@@ -899,78 +911,69 @@ static const struct i2c_algorithm nmk_i2c_algo = { | |||
899 | .functionality = nmk_i2c_functionality | 911 | .functionality = nmk_i2c_functionality |
900 | }; | 912 | }; |
901 | 913 | ||
902 | static int __devinit nmk_i2c_probe(struct platform_device *pdev) | 914 | static atomic_t adapter_id = ATOMIC_INIT(0); |
915 | |||
916 | static int nmk_i2c_probe(struct amba_device *adev, const struct amba_id *id) | ||
903 | { | 917 | { |
904 | int ret = 0; | 918 | int ret = 0; |
905 | struct resource *res; | ||
906 | struct nmk_i2c_controller *pdata = | 919 | struct nmk_i2c_controller *pdata = |
907 | pdev->dev.platform_data; | 920 | adev->dev.platform_data; |
908 | struct nmk_i2c_dev *dev; | 921 | struct nmk_i2c_dev *dev; |
909 | struct i2c_adapter *adap; | 922 | struct i2c_adapter *adap; |
910 | 923 | ||
924 | if (!pdata) { | ||
925 | dev_warn(&adev->dev, "no platform data\n"); | ||
926 | return -ENODEV; | ||
927 | } | ||
911 | dev = kzalloc(sizeof(struct nmk_i2c_dev), GFP_KERNEL); | 928 | dev = kzalloc(sizeof(struct nmk_i2c_dev), GFP_KERNEL); |
912 | if (!dev) { | 929 | if (!dev) { |
913 | dev_err(&pdev->dev, "cannot allocate memory\n"); | 930 | dev_err(&adev->dev, "cannot allocate memory\n"); |
914 | ret = -ENOMEM; | 931 | ret = -ENOMEM; |
915 | goto err_no_mem; | 932 | goto err_no_mem; |
916 | } | 933 | } |
917 | dev->busy = false; | 934 | dev->busy = false; |
918 | dev->pdev = pdev; | 935 | dev->adev = adev; |
919 | platform_set_drvdata(pdev, dev); | 936 | amba_set_drvdata(adev, dev); |
920 | 937 | ||
921 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 938 | dev->virtbase = ioremap(adev->res.start, resource_size(&adev->res)); |
922 | if (!res) { | ||
923 | ret = -ENOENT; | ||
924 | goto err_no_resource; | ||
925 | } | ||
926 | |||
927 | if (request_mem_region(res->start, resource_size(res), | ||
928 | DRIVER_NAME "I/O region") == NULL) { | ||
929 | ret = -EBUSY; | ||
930 | goto err_no_region; | ||
931 | } | ||
932 | |||
933 | dev->virtbase = ioremap(res->start, resource_size(res)); | ||
934 | if (!dev->virtbase) { | 939 | if (!dev->virtbase) { |
935 | ret = -ENOMEM; | 940 | ret = -ENOMEM; |
936 | goto err_no_ioremap; | 941 | goto err_no_ioremap; |
937 | } | 942 | } |
938 | 943 | ||
939 | dev->irq = platform_get_irq(pdev, 0); | 944 | dev->irq = adev->irq[0]; |
940 | ret = request_irq(dev->irq, i2c_irq_handler, 0, | 945 | ret = request_irq(dev->irq, i2c_irq_handler, 0, |
941 | DRIVER_NAME, dev); | 946 | DRIVER_NAME, dev); |
942 | if (ret) { | 947 | if (ret) { |
943 | dev_err(&pdev->dev, "cannot claim the irq %d\n", dev->irq); | 948 | dev_err(&adev->dev, "cannot claim the irq %d\n", dev->irq); |
944 | goto err_irq; | 949 | goto err_irq; |
945 | } | 950 | } |
946 | 951 | ||
947 | dev->regulator = regulator_get(&pdev->dev, "v-i2c"); | 952 | dev->regulator = regulator_get(&adev->dev, "v-i2c"); |
948 | if (IS_ERR(dev->regulator)) { | 953 | if (IS_ERR(dev->regulator)) { |
949 | dev_warn(&pdev->dev, "could not get i2c regulator\n"); | 954 | dev_warn(&adev->dev, "could not get i2c regulator\n"); |
950 | dev->regulator = NULL; | 955 | dev->regulator = NULL; |
951 | } | 956 | } |
952 | 957 | ||
953 | pm_suspend_ignore_children(&pdev->dev, true); | 958 | pm_suspend_ignore_children(&adev->dev, true); |
954 | pm_runtime_enable(&pdev->dev); | ||
955 | 959 | ||
956 | dev->clk = clk_get(&pdev->dev, NULL); | 960 | dev->clk = clk_get(&adev->dev, NULL); |
957 | if (IS_ERR(dev->clk)) { | 961 | if (IS_ERR(dev->clk)) { |
958 | dev_err(&pdev->dev, "could not get i2c clock\n"); | 962 | dev_err(&adev->dev, "could not get i2c clock\n"); |
959 | ret = PTR_ERR(dev->clk); | 963 | ret = PTR_ERR(dev->clk); |
960 | goto err_no_clk; | 964 | goto err_no_clk; |
961 | } | 965 | } |
962 | 966 | ||
963 | adap = &dev->adap; | 967 | adap = &dev->adap; |
964 | adap->dev.parent = &pdev->dev; | 968 | adap->dev.parent = &adev->dev; |
965 | adap->owner = THIS_MODULE; | 969 | adap->owner = THIS_MODULE; |
966 | adap->class = I2C_CLASS_HWMON | I2C_CLASS_SPD; | 970 | adap->class = I2C_CLASS_HWMON | I2C_CLASS_SPD; |
967 | adap->algo = &nmk_i2c_algo; | 971 | adap->algo = &nmk_i2c_algo; |
968 | adap->timeout = msecs_to_jiffies(pdata->timeout); | 972 | adap->timeout = msecs_to_jiffies(pdata->timeout); |
973 | adap->nr = atomic_read(&adapter_id); | ||
969 | snprintf(adap->name, sizeof(adap->name), | 974 | snprintf(adap->name, sizeof(adap->name), |
970 | "Nomadik I2C%d at %lx", pdev->id, (unsigned long)res->start); | 975 | "Nomadik I2C%d at %pR", adap->nr, &adev->res); |
971 | 976 | atomic_inc(&adapter_id); | |
972 | /* fetch the controller id */ | ||
973 | adap->nr = pdev->id; | ||
974 | 977 | ||
975 | /* fetch the controller configuration from machine */ | 978 | /* fetch the controller configuration from machine */ |
976 | dev->cfg.clk_freq = pdata->clk_freq; | 979 | dev->cfg.clk_freq = pdata->clk_freq; |
@@ -981,16 +984,18 @@ static int __devinit nmk_i2c_probe(struct platform_device *pdev) | |||
981 | 984 | ||
982 | i2c_set_adapdata(adap, dev); | 985 | i2c_set_adapdata(adap, dev); |
983 | 986 | ||
984 | dev_info(&pdev->dev, | 987 | dev_info(&adev->dev, |
985 | "initialize %s on virtual base %p\n", | 988 | "initialize %s on virtual base %p\n", |
986 | adap->name, dev->virtbase); | 989 | adap->name, dev->virtbase); |
987 | 990 | ||
988 | ret = i2c_add_numbered_adapter(adap); | 991 | ret = i2c_add_numbered_adapter(adap); |
989 | if (ret) { | 992 | if (ret) { |
990 | dev_err(&pdev->dev, "failed to add adapter\n"); | 993 | dev_err(&adev->dev, "failed to add adapter\n"); |
991 | goto err_add_adap; | 994 | goto err_add_adap; |
992 | } | 995 | } |
993 | 996 | ||
997 | pm_runtime_put(&adev->dev); | ||
998 | |||
994 | return 0; | 999 | return 0; |
995 | 1000 | ||
996 | err_add_adap: | 1001 | err_add_adap: |
@@ -998,25 +1003,21 @@ static int __devinit nmk_i2c_probe(struct platform_device *pdev) | |||
998 | err_no_clk: | 1003 | err_no_clk: |
999 | if (dev->regulator) | 1004 | if (dev->regulator) |
1000 | regulator_put(dev->regulator); | 1005 | regulator_put(dev->regulator); |
1001 | pm_runtime_disable(&pdev->dev); | ||
1002 | free_irq(dev->irq, dev); | 1006 | free_irq(dev->irq, dev); |
1003 | err_irq: | 1007 | err_irq: |
1004 | iounmap(dev->virtbase); | 1008 | iounmap(dev->virtbase); |
1005 | err_no_ioremap: | 1009 | err_no_ioremap: |
1006 | release_mem_region(res->start, resource_size(res)); | 1010 | amba_set_drvdata(adev, NULL); |
1007 | err_no_region: | ||
1008 | platform_set_drvdata(pdev, NULL); | ||
1009 | err_no_resource: | ||
1010 | kfree(dev); | 1011 | kfree(dev); |
1011 | err_no_mem: | 1012 | err_no_mem: |
1012 | 1013 | ||
1013 | return ret; | 1014 | return ret; |
1014 | } | 1015 | } |
1015 | 1016 | ||
1016 | static int __devexit nmk_i2c_remove(struct platform_device *pdev) | 1017 | static int nmk_i2c_remove(struct amba_device *adev) |
1017 | { | 1018 | { |
1018 | struct resource *res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 1019 | struct resource *res = &adev->res; |
1019 | struct nmk_i2c_dev *dev = platform_get_drvdata(pdev); | 1020 | struct nmk_i2c_dev *dev = amba_get_drvdata(adev); |
1020 | 1021 | ||
1021 | i2c_del_adapter(&dev->adap); | 1022 | i2c_del_adapter(&dev->adap); |
1022 | flush_i2c_fifo(dev); | 1023 | flush_i2c_fifo(dev); |
@@ -1031,31 +1032,46 @@ static int __devexit nmk_i2c_remove(struct platform_device *pdev) | |||
1031 | clk_put(dev->clk); | 1032 | clk_put(dev->clk); |
1032 | if (dev->regulator) | 1033 | if (dev->regulator) |
1033 | regulator_put(dev->regulator); | 1034 | regulator_put(dev->regulator); |
1034 | pm_runtime_disable(&pdev->dev); | 1035 | pm_runtime_disable(&adev->dev); |
1035 | platform_set_drvdata(pdev, NULL); | 1036 | amba_set_drvdata(adev, NULL); |
1036 | kfree(dev); | 1037 | kfree(dev); |
1037 | 1038 | ||
1038 | return 0; | 1039 | return 0; |
1039 | } | 1040 | } |
1040 | 1041 | ||
1041 | static struct platform_driver nmk_i2c_driver = { | 1042 | static struct amba_id nmk_i2c_ids[] = { |
1042 | .driver = { | 1043 | { |
1044 | .id = 0x00180024, | ||
1045 | .mask = 0x00ffffff, | ||
1046 | }, | ||
1047 | { | ||
1048 | .id = 0x00380024, | ||
1049 | .mask = 0x00ffffff, | ||
1050 | }, | ||
1051 | {}, | ||
1052 | }; | ||
1053 | |||
1054 | MODULE_DEVICE_TABLE(amba, nmk_i2c_ids); | ||
1055 | |||
1056 | static struct amba_driver nmk_i2c_driver = { | ||
1057 | .drv = { | ||
1043 | .owner = THIS_MODULE, | 1058 | .owner = THIS_MODULE, |
1044 | .name = DRIVER_NAME, | 1059 | .name = DRIVER_NAME, |
1045 | .pm = &nmk_i2c_pm, | 1060 | .pm = &nmk_i2c_pm, |
1046 | }, | 1061 | }, |
1062 | .id_table = nmk_i2c_ids, | ||
1047 | .probe = nmk_i2c_probe, | 1063 | .probe = nmk_i2c_probe, |
1048 | .remove = __devexit_p(nmk_i2c_remove), | 1064 | .remove = nmk_i2c_remove, |
1049 | }; | 1065 | }; |
1050 | 1066 | ||
1051 | static int __init nmk_i2c_init(void) | 1067 | static int __init nmk_i2c_init(void) |
1052 | { | 1068 | { |
1053 | return platform_driver_register(&nmk_i2c_driver); | 1069 | return amba_driver_register(&nmk_i2c_driver); |
1054 | } | 1070 | } |
1055 | 1071 | ||
1056 | static void __exit nmk_i2c_exit(void) | 1072 | static void __exit nmk_i2c_exit(void) |
1057 | { | 1073 | { |
1058 | platform_driver_unregister(&nmk_i2c_driver); | 1074 | amba_driver_unregister(&nmk_i2c_driver); |
1059 | } | 1075 | } |
1060 | 1076 | ||
1061 | subsys_initcall(nmk_i2c_init); | 1077 | subsys_initcall(nmk_i2c_init); |
@@ -1064,4 +1080,3 @@ module_exit(nmk_i2c_exit); | |||
1064 | MODULE_AUTHOR("Sachin Verma, Srinidhi KASAGAR"); | 1080 | MODULE_AUTHOR("Sachin Verma, Srinidhi KASAGAR"); |
1065 | MODULE_DESCRIPTION("Nomadik/Ux500 I2C driver"); | 1081 | MODULE_DESCRIPTION("Nomadik/Ux500 I2C driver"); |
1066 | MODULE_LICENSE("GPL"); | 1082 | MODULE_LICENSE("GPL"); |
1067 | MODULE_ALIAS("platform:" DRIVER_NAME); | ||
diff --git a/drivers/i2c/busses/i2c-ocores.c b/drivers/i2c/busses/i2c-ocores.c index 75194c579b6d..bffd5501ac2d 100644 --- a/drivers/i2c/busses/i2c-ocores.c +++ b/drivers/i2c/busses/i2c-ocores.c | |||
@@ -10,40 +10,9 @@ | |||
10 | */ | 10 | */ |
11 | 11 | ||
12 | /* | 12 | /* |
13 | * Device tree configuration: | 13 | * This driver can be used from the device tree, see |
14 | * | 14 | * Documentation/devicetree/bindings/i2c/ocore-i2c.txt |
15 | * Required properties: | ||
16 | * - compatible : "opencores,i2c-ocores" | ||
17 | * - reg : bus address start and address range size of device | ||
18 | * - interrupts : interrupt number | ||
19 | * - regstep : size of device registers in bytes | ||
20 | * - clock-frequency : frequency of bus clock in Hz | ||
21 | * | ||
22 | * Example: | ||
23 | * | ||
24 | * i2c0: ocores@a0000000 { | ||
25 | * compatible = "opencores,i2c-ocores"; | ||
26 | * reg = <0xa0000000 0x8>; | ||
27 | * interrupts = <10>; | ||
28 | * | ||
29 | * regstep = <1>; | ||
30 | * clock-frequency = <20000000>; | ||
31 | * | ||
32 | * -- Devices connected on this I2C bus get | ||
33 | * -- defined here; address- and size-cells | ||
34 | * -- apply to these child devices | ||
35 | * | ||
36 | * #address-cells = <1>; | ||
37 | * #size-cells = <0>; | ||
38 | * | ||
39 | * dummy@60 { | ||
40 | * compatible = "dummy"; | ||
41 | * reg = <60>; | ||
42 | * }; | ||
43 | * }; | ||
44 | * | ||
45 | */ | 15 | */ |
46 | |||
47 | #include <linux/kernel.h> | 16 | #include <linux/kernel.h> |
48 | #include <linux/module.h> | 17 | #include <linux/module.h> |
49 | #include <linux/init.h> | 18 | #include <linux/init.h> |
@@ -56,10 +25,12 @@ | |||
56 | #include <linux/slab.h> | 25 | #include <linux/slab.h> |
57 | #include <linux/io.h> | 26 | #include <linux/io.h> |
58 | #include <linux/of_i2c.h> | 27 | #include <linux/of_i2c.h> |
28 | #include <linux/log2.h> | ||
59 | 29 | ||
60 | struct ocores_i2c { | 30 | struct ocores_i2c { |
61 | void __iomem *base; | 31 | void __iomem *base; |
62 | int regstep; | 32 | u32 reg_shift; |
33 | u32 reg_io_width; | ||
63 | wait_queue_head_t wait; | 34 | wait_queue_head_t wait; |
64 | struct i2c_adapter adap; | 35 | struct i2c_adapter adap; |
65 | struct i2c_msg *msg; | 36 | struct i2c_msg *msg; |
@@ -102,12 +73,22 @@ struct ocores_i2c { | |||
102 | 73 | ||
103 | static inline void oc_setreg(struct ocores_i2c *i2c, int reg, u8 value) | 74 | static inline void oc_setreg(struct ocores_i2c *i2c, int reg, u8 value) |
104 | { | 75 | { |
105 | iowrite8(value, i2c->base + reg * i2c->regstep); | 76 | if (i2c->reg_io_width == 4) |
77 | iowrite32(value, i2c->base + (reg << i2c->reg_shift)); | ||
78 | else if (i2c->reg_io_width == 2) | ||
79 | iowrite16(value, i2c->base + (reg << i2c->reg_shift)); | ||
80 | else | ||
81 | iowrite8(value, i2c->base + (reg << i2c->reg_shift)); | ||
106 | } | 82 | } |
107 | 83 | ||
108 | static inline u8 oc_getreg(struct ocores_i2c *i2c, int reg) | 84 | static inline u8 oc_getreg(struct ocores_i2c *i2c, int reg) |
109 | { | 85 | { |
110 | return ioread8(i2c->base + reg * i2c->regstep); | 86 | if (i2c->reg_io_width == 4) |
87 | return ioread32(i2c->base + (reg << i2c->reg_shift)); | ||
88 | else if (i2c->reg_io_width == 2) | ||
89 | return ioread16(i2c->base + (reg << i2c->reg_shift)); | ||
90 | else | ||
91 | return ioread8(i2c->base + (reg << i2c->reg_shift)); | ||
111 | } | 92 | } |
112 | 93 | ||
113 | static void ocores_process(struct ocores_i2c *i2c) | 94 | static void ocores_process(struct ocores_i2c *i2c) |
@@ -247,26 +228,35 @@ static struct i2c_adapter ocores_adapter = { | |||
247 | }; | 228 | }; |
248 | 229 | ||
249 | #ifdef CONFIG_OF | 230 | #ifdef CONFIG_OF |
250 | static int ocores_i2c_of_probe(struct platform_device* pdev, | 231 | static int ocores_i2c_of_probe(struct platform_device *pdev, |
251 | struct ocores_i2c* i2c) | 232 | struct ocores_i2c *i2c) |
252 | { | 233 | { |
253 | const __be32* val; | 234 | struct device_node *np = pdev->dev.of_node; |
254 | 235 | u32 val; | |
255 | val = of_get_property(pdev->dev.of_node, "regstep", NULL); | 236 | |
256 | if (!val) { | 237 | if (of_property_read_u32(np, "reg-shift", &i2c->reg_shift)) { |
257 | dev_err(&pdev->dev, "Missing required parameter 'regstep'"); | 238 | /* no 'reg-shift', check for deprecated 'regstep' */ |
258 | return -ENODEV; | 239 | if (!of_property_read_u32(np, "regstep", &val)) { |
240 | if (!is_power_of_2(val)) { | ||
241 | dev_err(&pdev->dev, "invalid regstep %d\n", | ||
242 | val); | ||
243 | return -EINVAL; | ||
244 | } | ||
245 | i2c->reg_shift = ilog2(val); | ||
246 | dev_warn(&pdev->dev, | ||
247 | "regstep property deprecated, use reg-shift\n"); | ||
248 | } | ||
259 | } | 249 | } |
260 | i2c->regstep = be32_to_cpup(val); | ||
261 | 250 | ||
262 | val = of_get_property(pdev->dev.of_node, "clock-frequency", NULL); | 251 | if (of_property_read_u32(np, "clock-frequency", &val)) { |
263 | if (!val) { | ||
264 | dev_err(&pdev->dev, | 252 | dev_err(&pdev->dev, |
265 | "Missing required parameter 'clock-frequency'"); | 253 | "Missing required parameter 'clock-frequency'\n"); |
266 | return -ENODEV; | 254 | return -ENODEV; |
267 | } | 255 | } |
268 | i2c->clock_khz = be32_to_cpup(val) / 1000; | 256 | i2c->clock_khz = val / 1000; |
269 | 257 | ||
258 | of_property_read_u32(pdev->dev.of_node, "reg-io-width", | ||
259 | &i2c->reg_io_width); | ||
270 | return 0; | 260 | return 0; |
271 | } | 261 | } |
272 | #else | 262 | #else |
@@ -308,7 +298,8 @@ static int __devinit ocores_i2c_probe(struct platform_device *pdev) | |||
308 | 298 | ||
309 | pdata = pdev->dev.platform_data; | 299 | pdata = pdev->dev.platform_data; |
310 | if (pdata) { | 300 | if (pdata) { |
311 | i2c->regstep = pdata->regstep; | 301 | i2c->reg_shift = pdata->reg_shift; |
302 | i2c->reg_io_width = pdata->reg_io_width; | ||
312 | i2c->clock_khz = pdata->clock_khz; | 303 | i2c->clock_khz = pdata->clock_khz; |
313 | } else { | 304 | } else { |
314 | ret = ocores_i2c_of_probe(pdev, i2c); | 305 | ret = ocores_i2c_of_probe(pdev, i2c); |
@@ -316,6 +307,9 @@ static int __devinit ocores_i2c_probe(struct platform_device *pdev) | |||
316 | return ret; | 307 | return ret; |
317 | } | 308 | } |
318 | 309 | ||
310 | if (i2c->reg_io_width == 0) | ||
311 | i2c->reg_io_width = 1; /* Set to default value */ | ||
312 | |||
319 | ocores_init(i2c); | 313 | ocores_init(i2c); |
320 | 314 | ||
321 | init_waitqueue_head(&i2c->wait); | 315 | init_waitqueue_head(&i2c->wait); |
@@ -351,7 +345,7 @@ static int __devinit ocores_i2c_probe(struct platform_device *pdev) | |||
351 | return 0; | 345 | return 0; |
352 | } | 346 | } |
353 | 347 | ||
354 | static int __devexit ocores_i2c_remove(struct platform_device* pdev) | 348 | static int __devexit ocores_i2c_remove(struct platform_device *pdev) |
355 | { | 349 | { |
356 | struct ocores_i2c *i2c = platform_get_drvdata(pdev); | 350 | struct ocores_i2c *i2c = platform_get_drvdata(pdev); |
357 | 351 | ||
@@ -367,9 +361,9 @@ static int __devexit ocores_i2c_remove(struct platform_device* pdev) | |||
367 | } | 361 | } |
368 | 362 | ||
369 | #ifdef CONFIG_PM | 363 | #ifdef CONFIG_PM |
370 | static int ocores_i2c_suspend(struct platform_device *pdev, pm_message_t state) | 364 | static int ocores_i2c_suspend(struct device *dev) |
371 | { | 365 | { |
372 | struct ocores_i2c *i2c = platform_get_drvdata(pdev); | 366 | struct ocores_i2c *i2c = dev_get_drvdata(dev); |
373 | u8 ctrl = oc_getreg(i2c, OCI2C_CONTROL); | 367 | u8 ctrl = oc_getreg(i2c, OCI2C_CONTROL); |
374 | 368 | ||
375 | /* make sure the device is disabled */ | 369 | /* make sure the device is disabled */ |
@@ -378,17 +372,19 @@ static int ocores_i2c_suspend(struct platform_device *pdev, pm_message_t state) | |||
378 | return 0; | 372 | return 0; |
379 | } | 373 | } |
380 | 374 | ||
381 | static int ocores_i2c_resume(struct platform_device *pdev) | 375 | static int ocores_i2c_resume(struct device *dev) |
382 | { | 376 | { |
383 | struct ocores_i2c *i2c = platform_get_drvdata(pdev); | 377 | struct ocores_i2c *i2c = dev_get_drvdata(dev); |
384 | 378 | ||
385 | ocores_init(i2c); | 379 | ocores_init(i2c); |
386 | 380 | ||
387 | return 0; | 381 | return 0; |
388 | } | 382 | } |
383 | |||
384 | static SIMPLE_DEV_PM_OPS(ocores_i2c_pm, ocores_i2c_suspend, ocores_i2c_resume); | ||
385 | #define OCORES_I2C_PM (&ocores_i2c_pm) | ||
389 | #else | 386 | #else |
390 | #define ocores_i2c_suspend NULL | 387 | #define OCORES_I2C_PM NULL |
391 | #define ocores_i2c_resume NULL | ||
392 | #endif | 388 | #endif |
393 | 389 | ||
394 | static struct of_device_id ocores_i2c_match[] = { | 390 | static struct of_device_id ocores_i2c_match[] = { |
@@ -400,12 +396,11 @@ MODULE_DEVICE_TABLE(of, ocores_i2c_match); | |||
400 | static struct platform_driver ocores_i2c_driver = { | 396 | static struct platform_driver ocores_i2c_driver = { |
401 | .probe = ocores_i2c_probe, | 397 | .probe = ocores_i2c_probe, |
402 | .remove = __devexit_p(ocores_i2c_remove), | 398 | .remove = __devexit_p(ocores_i2c_remove), |
403 | .suspend = ocores_i2c_suspend, | ||
404 | .resume = ocores_i2c_resume, | ||
405 | .driver = { | 399 | .driver = { |
406 | .owner = THIS_MODULE, | 400 | .owner = THIS_MODULE, |
407 | .name = "ocores-i2c", | 401 | .name = "ocores-i2c", |
408 | .of_match_table = ocores_i2c_match, | 402 | .of_match_table = ocores_i2c_match, |
403 | .pm = OCORES_I2C_PM, | ||
409 | }, | 404 | }, |
410 | }; | 405 | }; |
411 | 406 | ||
diff --git a/drivers/i2c/busses/i2c-omap.c b/drivers/i2c/busses/i2c-omap.c index c2148332de0f..6849635b268a 100644 --- a/drivers/i2c/busses/i2c-omap.c +++ b/drivers/i2c/busses/i2c-omap.c | |||
@@ -49,8 +49,8 @@ | |||
49 | 49 | ||
50 | /* I2C controller revisions present on specific hardware */ | 50 | /* I2C controller revisions present on specific hardware */ |
51 | #define OMAP_I2C_REV_ON_2430 0x36 | 51 | #define OMAP_I2C_REV_ON_2430 0x36 |
52 | #define OMAP_I2C_REV_ON_3430 0x3C | 52 | #define OMAP_I2C_REV_ON_3430_3530 0x3C |
53 | #define OMAP_I2C_REV_ON_3530_4430 0x40 | 53 | #define OMAP_I2C_REV_ON_3630_4430 0x40 |
54 | 54 | ||
55 | /* timeout waiting for the controller to respond */ | 55 | /* timeout waiting for the controller to respond */ |
56 | #define OMAP_I2C_TIMEOUT (msecs_to_jiffies(1000)) | 56 | #define OMAP_I2C_TIMEOUT (msecs_to_jiffies(1000)) |
@@ -173,7 +173,7 @@ enum { | |||
173 | 173 | ||
174 | /* Errata definitions */ | 174 | /* Errata definitions */ |
175 | #define I2C_OMAP_ERRATA_I207 (1 << 0) | 175 | #define I2C_OMAP_ERRATA_I207 (1 << 0) |
176 | #define I2C_OMAP3_1P153 (1 << 1) | 176 | #define I2C_OMAP_ERRATA_I462 (1 << 1) |
177 | 177 | ||
178 | struct omap_i2c_dev { | 178 | struct omap_i2c_dev { |
179 | struct device *dev; | 179 | struct device *dev; |
@@ -269,47 +269,6 @@ static inline u16 omap_i2c_read_reg(struct omap_i2c_dev *i2c_dev, int reg) | |||
269 | (i2c_dev->regs[reg] << i2c_dev->reg_shift)); | 269 | (i2c_dev->regs[reg] << i2c_dev->reg_shift)); |
270 | } | 270 | } |
271 | 271 | ||
272 | static void omap_i2c_unidle(struct omap_i2c_dev *dev) | ||
273 | { | ||
274 | if (dev->flags & OMAP_I2C_FLAG_RESET_REGS_POSTIDLE) { | ||
275 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, 0); | ||
276 | omap_i2c_write_reg(dev, OMAP_I2C_PSC_REG, dev->pscstate); | ||
277 | omap_i2c_write_reg(dev, OMAP_I2C_SCLL_REG, dev->scllstate); | ||
278 | omap_i2c_write_reg(dev, OMAP_I2C_SCLH_REG, dev->sclhstate); | ||
279 | omap_i2c_write_reg(dev, OMAP_I2C_BUF_REG, dev->bufstate); | ||
280 | omap_i2c_write_reg(dev, OMAP_I2C_SYSC_REG, dev->syscstate); | ||
281 | omap_i2c_write_reg(dev, OMAP_I2C_WE_REG, dev->westate); | ||
282 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, OMAP_I2C_CON_EN); | ||
283 | } | ||
284 | |||
285 | /* | ||
286 | * Don't write to this register if the IE state is 0 as it can | ||
287 | * cause deadlock. | ||
288 | */ | ||
289 | if (dev->iestate) | ||
290 | omap_i2c_write_reg(dev, OMAP_I2C_IE_REG, dev->iestate); | ||
291 | } | ||
292 | |||
293 | static void omap_i2c_idle(struct omap_i2c_dev *dev) | ||
294 | { | ||
295 | u16 iv; | ||
296 | |||
297 | dev->iestate = omap_i2c_read_reg(dev, OMAP_I2C_IE_REG); | ||
298 | if (dev->dtrev == OMAP_I2C_IP_VERSION_2) | ||
299 | omap_i2c_write_reg(dev, OMAP_I2C_IP_V2_IRQENABLE_CLR, 1); | ||
300 | else | ||
301 | omap_i2c_write_reg(dev, OMAP_I2C_IE_REG, 0); | ||
302 | |||
303 | if (dev->rev < OMAP_I2C_OMAP1_REV_2) { | ||
304 | iv = omap_i2c_read_reg(dev, OMAP_I2C_IV_REG); /* Read clears */ | ||
305 | } else { | ||
306 | omap_i2c_write_reg(dev, OMAP_I2C_STAT_REG, dev->iestate); | ||
307 | |||
308 | /* Flush posted write */ | ||
309 | omap_i2c_read_reg(dev, OMAP_I2C_STAT_REG); | ||
310 | } | ||
311 | } | ||
312 | |||
313 | static int omap_i2c_init(struct omap_i2c_dev *dev) | 272 | static int omap_i2c_init(struct omap_i2c_dev *dev) |
314 | { | 273 | { |
315 | u16 psc = 0, scll = 0, sclh = 0, buf = 0; | 274 | u16 psc = 0, scll = 0, sclh = 0, buf = 0; |
@@ -346,7 +305,7 @@ static int omap_i2c_init(struct omap_i2c_dev *dev) | |||
346 | omap_i2c_write_reg(dev, OMAP_I2C_SYSC_REG, | 305 | omap_i2c_write_reg(dev, OMAP_I2C_SYSC_REG, |
347 | SYSC_AUTOIDLE_MASK); | 306 | SYSC_AUTOIDLE_MASK); |
348 | 307 | ||
349 | } else if (dev->rev >= OMAP_I2C_REV_ON_3430) { | 308 | } else if (dev->rev >= OMAP_I2C_REV_ON_3430_3530) { |
350 | dev->syscstate = SYSC_AUTOIDLE_MASK; | 309 | dev->syscstate = SYSC_AUTOIDLE_MASK; |
351 | dev->syscstate |= SYSC_ENAWAKEUP_MASK; | 310 | dev->syscstate |= SYSC_ENAWAKEUP_MASK; |
352 | dev->syscstate |= (SYSC_IDLEMODE_SMART << | 311 | dev->syscstate |= (SYSC_IDLEMODE_SMART << |
@@ -468,11 +427,6 @@ static int omap_i2c_init(struct omap_i2c_dev *dev) | |||
468 | /* Take the I2C module out of reset: */ | 427 | /* Take the I2C module out of reset: */ |
469 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, OMAP_I2C_CON_EN); | 428 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, OMAP_I2C_CON_EN); |
470 | 429 | ||
471 | dev->errata = 0; | ||
472 | |||
473 | if (dev->flags & OMAP_I2C_FLAG_APPLY_ERRATA_I207) | ||
474 | dev->errata |= I2C_OMAP_ERRATA_I207; | ||
475 | |||
476 | /* Enable interrupts */ | 430 | /* Enable interrupts */ |
477 | dev->iestate = (OMAP_I2C_IE_XRDY | OMAP_I2C_IE_RRDY | | 431 | dev->iestate = (OMAP_I2C_IE_XRDY | OMAP_I2C_IE_RRDY | |
478 | OMAP_I2C_IE_ARDY | OMAP_I2C_IE_NACK | | 432 | OMAP_I2C_IE_ARDY | OMAP_I2C_IE_NACK | |
@@ -514,7 +468,7 @@ static int omap_i2c_xfer_msg(struct i2c_adapter *adap, | |||
514 | struct i2c_msg *msg, int stop) | 468 | struct i2c_msg *msg, int stop) |
515 | { | 469 | { |
516 | struct omap_i2c_dev *dev = i2c_get_adapdata(adap); | 470 | struct omap_i2c_dev *dev = i2c_get_adapdata(adap); |
517 | int r; | 471 | unsigned long timeout; |
518 | u16 w; | 472 | u16 w; |
519 | 473 | ||
520 | dev_dbg(dev->dev, "addr: 0x%04x, len: %d, flags: 0x%x, stop: %d\n", | 474 | dev_dbg(dev->dev, "addr: 0x%04x, len: %d, flags: 0x%x, stop: %d\n", |
@@ -536,7 +490,7 @@ static int omap_i2c_xfer_msg(struct i2c_adapter *adap, | |||
536 | w |= OMAP_I2C_BUF_RXFIF_CLR | OMAP_I2C_BUF_TXFIF_CLR; | 490 | w |= OMAP_I2C_BUF_RXFIF_CLR | OMAP_I2C_BUF_TXFIF_CLR; |
537 | omap_i2c_write_reg(dev, OMAP_I2C_BUF_REG, w); | 491 | omap_i2c_write_reg(dev, OMAP_I2C_BUF_REG, w); |
538 | 492 | ||
539 | init_completion(&dev->cmd_complete); | 493 | INIT_COMPLETION(dev->cmd_complete); |
540 | dev->cmd_err = 0; | 494 | dev->cmd_err = 0; |
541 | 495 | ||
542 | w = OMAP_I2C_CON_EN | OMAP_I2C_CON_MST | OMAP_I2C_CON_STT; | 496 | w = OMAP_I2C_CON_EN | OMAP_I2C_CON_MST | OMAP_I2C_CON_STT; |
@@ -584,12 +538,10 @@ static int omap_i2c_xfer_msg(struct i2c_adapter *adap, | |||
584 | * REVISIT: We should abort the transfer on signals, but the bus goes | 538 | * REVISIT: We should abort the transfer on signals, but the bus goes |
585 | * into arbitration and we're currently unable to recover from it. | 539 | * into arbitration and we're currently unable to recover from it. |
586 | */ | 540 | */ |
587 | r = wait_for_completion_timeout(&dev->cmd_complete, | 541 | timeout = wait_for_completion_timeout(&dev->cmd_complete, |
588 | OMAP_I2C_TIMEOUT); | 542 | OMAP_I2C_TIMEOUT); |
589 | dev->buf_len = 0; | 543 | dev->buf_len = 0; |
590 | if (r < 0) | 544 | if (timeout == 0) { |
591 | return r; | ||
592 | if (r == 0) { | ||
593 | dev_err(dev->dev, "controller timed out\n"); | 545 | dev_err(dev->dev, "controller timed out\n"); |
594 | omap_i2c_init(dev); | 546 | omap_i2c_init(dev); |
595 | return -ETIMEDOUT; | 547 | return -ETIMEDOUT; |
@@ -630,7 +582,9 @@ omap_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msgs[], int num) | |||
630 | int i; | 582 | int i; |
631 | int r; | 583 | int r; |
632 | 584 | ||
633 | pm_runtime_get_sync(dev->dev); | 585 | r = pm_runtime_get_sync(dev->dev); |
586 | if (IS_ERR_VALUE(r)) | ||
587 | return r; | ||
634 | 588 | ||
635 | r = omap_i2c_wait_for_bb(dev); | 589 | r = omap_i2c_wait_for_bb(dev); |
636 | if (r < 0) | 590 | if (r < 0) |
@@ -767,11 +721,11 @@ omap_i2c_omap1_isr(int this_irq, void *dev_id) | |||
767 | #endif | 721 | #endif |
768 | 722 | ||
769 | /* | 723 | /* |
770 | * OMAP3430 Errata 1.153: When an XRDY/XDR is hit, wait for XUDF before writing | 724 | * OMAP3430 Errata i462: When an XRDY/XDR is hit, wait for XUDF before writing |
771 | * data to DATA_REG. Otherwise some data bytes can be lost while transferring | 725 | * data to DATA_REG. Otherwise some data bytes can be lost while transferring |
772 | * them from the memory to the I2C interface. | 726 | * them from the memory to the I2C interface. |
773 | */ | 727 | */ |
774 | static int errata_omap3_1p153(struct omap_i2c_dev *dev, u16 *stat, int *err) | 728 | static int errata_omap3_i462(struct omap_i2c_dev *dev, u16 *stat, int *err) |
775 | { | 729 | { |
776 | unsigned long timeout = 10000; | 730 | unsigned long timeout = 10000; |
777 | 731 | ||
@@ -779,7 +733,6 @@ static int errata_omap3_1p153(struct omap_i2c_dev *dev, u16 *stat, int *err) | |||
779 | if (*stat & (OMAP_I2C_STAT_NACK | OMAP_I2C_STAT_AL)) { | 733 | if (*stat & (OMAP_I2C_STAT_NACK | OMAP_I2C_STAT_AL)) { |
780 | omap_i2c_ack_stat(dev, *stat & (OMAP_I2C_STAT_XRDY | | 734 | omap_i2c_ack_stat(dev, *stat & (OMAP_I2C_STAT_XRDY | |
781 | OMAP_I2C_STAT_XDR)); | 735 | OMAP_I2C_STAT_XDR)); |
782 | *err |= OMAP_I2C_STAT_XUDF; | ||
783 | return -ETIMEDOUT; | 736 | return -ETIMEDOUT; |
784 | } | 737 | } |
785 | 738 | ||
@@ -792,6 +745,7 @@ static int errata_omap3_1p153(struct omap_i2c_dev *dev, u16 *stat, int *err) | |||
792 | return 0; | 745 | return 0; |
793 | } | 746 | } |
794 | 747 | ||
748 | *err |= OMAP_I2C_STAT_XUDF; | ||
795 | return 0; | 749 | return 0; |
796 | } | 750 | } |
797 | 751 | ||
@@ -930,8 +884,8 @@ complete: | |||
930 | break; | 884 | break; |
931 | } | 885 | } |
932 | 886 | ||
933 | if ((dev->errata & I2C_OMAP3_1P153) && | 887 | if ((dev->errata & I2C_OMAP_ERRATA_I462) && |
934 | errata_omap3_1p153(dev, &stat, &err)) | 888 | errata_omap3_i462(dev, &stat, &err)) |
935 | goto complete; | 889 | goto complete; |
936 | 890 | ||
937 | omap_i2c_write_reg(dev, OMAP_I2C_DATA_REG, w); | 891 | omap_i2c_write_reg(dev, OMAP_I2C_DATA_REG, w); |
@@ -1048,6 +1002,7 @@ omap_i2c_probe(struct platform_device *pdev) | |||
1048 | } | 1002 | } |
1049 | 1003 | ||
1050 | platform_set_drvdata(pdev, dev); | 1004 | platform_set_drvdata(pdev, dev); |
1005 | init_completion(&dev->cmd_complete); | ||
1051 | 1006 | ||
1052 | dev->reg_shift = (dev->flags >> OMAP_I2C_FLAG_BUS_SHIFT__SHIFT) & 3; | 1007 | dev->reg_shift = (dev->flags >> OMAP_I2C_FLAG_BUS_SHIFT__SHIFT) & 3; |
1053 | 1008 | ||
@@ -1057,12 +1012,19 @@ omap_i2c_probe(struct platform_device *pdev) | |||
1057 | dev->regs = (u8 *)reg_map_ip_v1; | 1012 | dev->regs = (u8 *)reg_map_ip_v1; |
1058 | 1013 | ||
1059 | pm_runtime_enable(dev->dev); | 1014 | pm_runtime_enable(dev->dev); |
1060 | pm_runtime_get_sync(dev->dev); | 1015 | r = pm_runtime_get_sync(dev->dev); |
1016 | if (IS_ERR_VALUE(r)) | ||
1017 | goto err_free_mem; | ||
1061 | 1018 | ||
1062 | dev->rev = omap_i2c_read_reg(dev, OMAP_I2C_REV_REG) & 0xff; | 1019 | dev->rev = omap_i2c_read_reg(dev, OMAP_I2C_REV_REG) & 0xff; |
1063 | 1020 | ||
1064 | if (dev->rev <= OMAP_I2C_REV_ON_3430) | 1021 | dev->errata = 0; |
1065 | dev->errata |= I2C_OMAP3_1P153; | 1022 | |
1023 | if (dev->flags & OMAP_I2C_FLAG_APPLY_ERRATA_I207) | ||
1024 | dev->errata |= I2C_OMAP_ERRATA_I207; | ||
1025 | |||
1026 | if (dev->rev <= OMAP_I2C_REV_ON_3430_3530) | ||
1027 | dev->errata |= I2C_OMAP_ERRATA_I462; | ||
1066 | 1028 | ||
1067 | if (!(dev->flags & OMAP_I2C_FLAG_NO_FIFO)) { | 1029 | if (!(dev->flags & OMAP_I2C_FLAG_NO_FIFO)) { |
1068 | u16 s; | 1030 | u16 s; |
@@ -1079,7 +1041,7 @@ omap_i2c_probe(struct platform_device *pdev) | |||
1079 | 1041 | ||
1080 | dev->fifo_size = (dev->fifo_size / 2); | 1042 | dev->fifo_size = (dev->fifo_size / 2); |
1081 | 1043 | ||
1082 | if (dev->rev >= OMAP_I2C_REV_ON_3530_4430) | 1044 | if (dev->rev >= OMAP_I2C_REV_ON_3630_4430) |
1083 | dev->b_hw = 0; /* Disable hardware fixes */ | 1045 | dev->b_hw = 0; /* Disable hardware fixes */ |
1084 | else | 1046 | else |
1085 | dev->b_hw = 1; /* Enable hardware fixes */ | 1047 | dev->b_hw = 1; /* Enable hardware fixes */ |
@@ -1095,7 +1057,7 @@ omap_i2c_probe(struct platform_device *pdev) | |||
1095 | 1057 | ||
1096 | isr = (dev->rev < OMAP_I2C_OMAP1_REV_2) ? omap_i2c_omap1_isr : | 1058 | isr = (dev->rev < OMAP_I2C_OMAP1_REV_2) ? omap_i2c_omap1_isr : |
1097 | omap_i2c_isr; | 1059 | omap_i2c_isr; |
1098 | r = request_irq(dev->irq, isr, 0, pdev->name, dev); | 1060 | r = request_irq(dev->irq, isr, IRQF_NO_SUSPEND, pdev->name, dev); |
1099 | 1061 | ||
1100 | if (r) { | 1062 | if (r) { |
1101 | dev_err(dev->dev, "failure requesting irq %i\n", dev->irq); | 1063 | dev_err(dev->dev, "failure requesting irq %i\n", dev->irq); |
@@ -1105,8 +1067,6 @@ omap_i2c_probe(struct platform_device *pdev) | |||
1105 | dev_info(dev->dev, "bus %d rev%d.%d.%d at %d kHz\n", pdev->id, | 1067 | dev_info(dev->dev, "bus %d rev%d.%d.%d at %d kHz\n", pdev->id, |
1106 | dev->dtrev, dev->rev >> 4, dev->rev & 0xf, dev->speed); | 1068 | dev->dtrev, dev->rev >> 4, dev->rev & 0xf, dev->speed); |
1107 | 1069 | ||
1108 | pm_runtime_put(dev->dev); | ||
1109 | |||
1110 | adap = &dev->adapter; | 1070 | adap = &dev->adapter; |
1111 | i2c_set_adapdata(adap, dev); | 1071 | i2c_set_adapdata(adap, dev); |
1112 | adap->owner = THIS_MODULE; | 1072 | adap->owner = THIS_MODULE; |
@@ -1126,6 +1086,8 @@ omap_i2c_probe(struct platform_device *pdev) | |||
1126 | 1086 | ||
1127 | of_i2c_register_devices(adap); | 1087 | of_i2c_register_devices(adap); |
1128 | 1088 | ||
1089 | pm_runtime_put(dev->dev); | ||
1090 | |||
1129 | return 0; | 1091 | return 0; |
1130 | 1092 | ||
1131 | err_free_irq: | 1093 | err_free_irq: |
@@ -1134,6 +1096,7 @@ err_unuse_clocks: | |||
1134 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, 0); | 1096 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, 0); |
1135 | pm_runtime_put(dev->dev); | 1097 | pm_runtime_put(dev->dev); |
1136 | iounmap(dev->base); | 1098 | iounmap(dev->base); |
1099 | pm_runtime_disable(&pdev->dev); | ||
1137 | err_free_mem: | 1100 | err_free_mem: |
1138 | platform_set_drvdata(pdev, NULL); | 1101 | platform_set_drvdata(pdev, NULL); |
1139 | kfree(dev); | 1102 | kfree(dev); |
@@ -1143,17 +1106,23 @@ err_release_region: | |||
1143 | return r; | 1106 | return r; |
1144 | } | 1107 | } |
1145 | 1108 | ||
1146 | static int | 1109 | static int __devexit omap_i2c_remove(struct platform_device *pdev) |
1147 | omap_i2c_remove(struct platform_device *pdev) | ||
1148 | { | 1110 | { |
1149 | struct omap_i2c_dev *dev = platform_get_drvdata(pdev); | 1111 | struct omap_i2c_dev *dev = platform_get_drvdata(pdev); |
1150 | struct resource *mem; | 1112 | struct resource *mem; |
1113 | int ret; | ||
1151 | 1114 | ||
1152 | platform_set_drvdata(pdev, NULL); | 1115 | platform_set_drvdata(pdev, NULL); |
1153 | 1116 | ||
1154 | free_irq(dev->irq, dev); | 1117 | free_irq(dev->irq, dev); |
1155 | i2c_del_adapter(&dev->adapter); | 1118 | i2c_del_adapter(&dev->adapter); |
1119 | ret = pm_runtime_get_sync(&pdev->dev); | ||
1120 | if (IS_ERR_VALUE(ret)) | ||
1121 | return ret; | ||
1122 | |||
1156 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, 0); | 1123 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, 0); |
1124 | pm_runtime_put(&pdev->dev); | ||
1125 | pm_runtime_disable(&pdev->dev); | ||
1157 | iounmap(dev->base); | 1126 | iounmap(dev->base); |
1158 | kfree(dev); | 1127 | kfree(dev); |
1159 | mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 1128 | mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
@@ -1161,13 +1130,26 @@ omap_i2c_remove(struct platform_device *pdev) | |||
1161 | return 0; | 1130 | return 0; |
1162 | } | 1131 | } |
1163 | 1132 | ||
1133 | #ifdef CONFIG_PM | ||
1164 | #ifdef CONFIG_PM_RUNTIME | 1134 | #ifdef CONFIG_PM_RUNTIME |
1165 | static int omap_i2c_runtime_suspend(struct device *dev) | 1135 | static int omap_i2c_runtime_suspend(struct device *dev) |
1166 | { | 1136 | { |
1167 | struct platform_device *pdev = to_platform_device(dev); | 1137 | struct platform_device *pdev = to_platform_device(dev); |
1168 | struct omap_i2c_dev *_dev = platform_get_drvdata(pdev); | 1138 | struct omap_i2c_dev *_dev = platform_get_drvdata(pdev); |
1139 | u16 iv; | ||
1140 | |||
1141 | _dev->iestate = omap_i2c_read_reg(_dev, OMAP_I2C_IE_REG); | ||
1142 | |||
1143 | omap_i2c_write_reg(_dev, OMAP_I2C_IE_REG, 0); | ||
1169 | 1144 | ||
1170 | omap_i2c_idle(_dev); | 1145 | if (_dev->rev < OMAP_I2C_OMAP1_REV_2) { |
1146 | iv = omap_i2c_read_reg(_dev, OMAP_I2C_IV_REG); /* Read clears */ | ||
1147 | } else { | ||
1148 | omap_i2c_write_reg(_dev, OMAP_I2C_STAT_REG, _dev->iestate); | ||
1149 | |||
1150 | /* Flush posted write */ | ||
1151 | omap_i2c_read_reg(_dev, OMAP_I2C_STAT_REG); | ||
1152 | } | ||
1171 | 1153 | ||
1172 | return 0; | 1154 | return 0; |
1173 | } | 1155 | } |
@@ -1177,23 +1159,40 @@ static int omap_i2c_runtime_resume(struct device *dev) | |||
1177 | struct platform_device *pdev = to_platform_device(dev); | 1159 | struct platform_device *pdev = to_platform_device(dev); |
1178 | struct omap_i2c_dev *_dev = platform_get_drvdata(pdev); | 1160 | struct omap_i2c_dev *_dev = platform_get_drvdata(pdev); |
1179 | 1161 | ||
1180 | omap_i2c_unidle(_dev); | 1162 | if (_dev->flags & OMAP_I2C_FLAG_RESET_REGS_POSTIDLE) { |
1163 | omap_i2c_write_reg(_dev, OMAP_I2C_CON_REG, 0); | ||
1164 | omap_i2c_write_reg(_dev, OMAP_I2C_PSC_REG, _dev->pscstate); | ||
1165 | omap_i2c_write_reg(_dev, OMAP_I2C_SCLL_REG, _dev->scllstate); | ||
1166 | omap_i2c_write_reg(_dev, OMAP_I2C_SCLH_REG, _dev->sclhstate); | ||
1167 | omap_i2c_write_reg(_dev, OMAP_I2C_BUF_REG, _dev->bufstate); | ||
1168 | omap_i2c_write_reg(_dev, OMAP_I2C_SYSC_REG, _dev->syscstate); | ||
1169 | omap_i2c_write_reg(_dev, OMAP_I2C_WE_REG, _dev->westate); | ||
1170 | omap_i2c_write_reg(_dev, OMAP_I2C_CON_REG, OMAP_I2C_CON_EN); | ||
1171 | } | ||
1172 | |||
1173 | /* | ||
1174 | * Don't write to this register if the IE state is 0 as it can | ||
1175 | * cause deadlock. | ||
1176 | */ | ||
1177 | if (_dev->iestate) | ||
1178 | omap_i2c_write_reg(_dev, OMAP_I2C_IE_REG, _dev->iestate); | ||
1181 | 1179 | ||
1182 | return 0; | 1180 | return 0; |
1183 | } | 1181 | } |
1182 | #endif /* CONFIG_PM_RUNTIME */ | ||
1184 | 1183 | ||
1185 | static struct dev_pm_ops omap_i2c_pm_ops = { | 1184 | static struct dev_pm_ops omap_i2c_pm_ops = { |
1186 | .runtime_suspend = omap_i2c_runtime_suspend, | 1185 | SET_RUNTIME_PM_OPS(omap_i2c_runtime_suspend, |
1187 | .runtime_resume = omap_i2c_runtime_resume, | 1186 | omap_i2c_runtime_resume, NULL) |
1188 | }; | 1187 | }; |
1189 | #define OMAP_I2C_PM_OPS (&omap_i2c_pm_ops) | 1188 | #define OMAP_I2C_PM_OPS (&omap_i2c_pm_ops) |
1190 | #else | 1189 | #else |
1191 | #define OMAP_I2C_PM_OPS NULL | 1190 | #define OMAP_I2C_PM_OPS NULL |
1192 | #endif | 1191 | #endif /* CONFIG_PM */ |
1193 | 1192 | ||
1194 | static struct platform_driver omap_i2c_driver = { | 1193 | static struct platform_driver omap_i2c_driver = { |
1195 | .probe = omap_i2c_probe, | 1194 | .probe = omap_i2c_probe, |
1196 | .remove = omap_i2c_remove, | 1195 | .remove = __devexit_p(omap_i2c_remove), |
1197 | .driver = { | 1196 | .driver = { |
1198 | .name = "omap_i2c", | 1197 | .name = "omap_i2c", |
1199 | .owner = THIS_MODULE, | 1198 | .owner = THIS_MODULE, |
diff --git a/drivers/i2c/busses/i2c-pnx.c b/drivers/i2c/busses/i2c-pnx.c index 99389d2eae51..5d54416770b0 100644 --- a/drivers/i2c/busses/i2c-pnx.c +++ b/drivers/i2c/busses/i2c-pnx.c | |||
@@ -587,25 +587,27 @@ static struct i2c_algorithm pnx_algorithm = { | |||
587 | }; | 587 | }; |
588 | 588 | ||
589 | #ifdef CONFIG_PM | 589 | #ifdef CONFIG_PM |
590 | static int i2c_pnx_controller_suspend(struct platform_device *pdev, | 590 | static int i2c_pnx_controller_suspend(struct device *dev) |
591 | pm_message_t state) | ||
592 | { | 591 | { |
593 | struct i2c_pnx_algo_data *alg_data = platform_get_drvdata(pdev); | 592 | struct i2c_pnx_algo_data *alg_data = dev_get_drvdata(dev); |
594 | 593 | ||
595 | clk_disable(alg_data->clk); | 594 | clk_disable(alg_data->clk); |
596 | 595 | ||
597 | return 0; | 596 | return 0; |
598 | } | 597 | } |
599 | 598 | ||
600 | static int i2c_pnx_controller_resume(struct platform_device *pdev) | 599 | static int i2c_pnx_controller_resume(struct device *dev) |
601 | { | 600 | { |
602 | struct i2c_pnx_algo_data *alg_data = platform_get_drvdata(pdev); | 601 | struct i2c_pnx_algo_data *alg_data = dev_get_drvdata(dev); |
603 | 602 | ||
604 | return clk_enable(alg_data->clk); | 603 | return clk_enable(alg_data->clk); |
605 | } | 604 | } |
605 | |||
606 | static SIMPLE_DEV_PM_OPS(i2c_pnx_pm, | ||
607 | i2c_pnx_controller_suspend, i2c_pnx_controller_resume); | ||
608 | #define PNX_I2C_PM (&i2c_pnx_pm) | ||
606 | #else | 609 | #else |
607 | #define i2c_pnx_controller_suspend NULL | 610 | #define PNX_I2C_PM NULL |
608 | #define i2c_pnx_controller_resume NULL | ||
609 | #endif | 611 | #endif |
610 | 612 | ||
611 | static int __devinit i2c_pnx_probe(struct platform_device *pdev) | 613 | static int __devinit i2c_pnx_probe(struct platform_device *pdev) |
@@ -783,11 +785,10 @@ static struct platform_driver i2c_pnx_driver = { | |||
783 | .name = "pnx-i2c", | 785 | .name = "pnx-i2c", |
784 | .owner = THIS_MODULE, | 786 | .owner = THIS_MODULE, |
785 | .of_match_table = of_match_ptr(i2c_pnx_of_match), | 787 | .of_match_table = of_match_ptr(i2c_pnx_of_match), |
788 | .pm = PNX_I2C_PM, | ||
786 | }, | 789 | }, |
787 | .probe = i2c_pnx_probe, | 790 | .probe = i2c_pnx_probe, |
788 | .remove = __devexit_p(i2c_pnx_remove), | 791 | .remove = __devexit_p(i2c_pnx_remove), |
789 | .suspend = i2c_pnx_controller_suspend, | ||
790 | .resume = i2c_pnx_controller_resume, | ||
791 | }; | 792 | }; |
792 | 793 | ||
793 | static int __init i2c_adap_pnx_init(void) | 794 | static int __init i2c_adap_pnx_init(void) |
diff --git a/drivers/i2c/busses/i2c-puv3.c b/drivers/i2c/busses/i2c-puv3.c index 93709fbe30eb..d8515be00b98 100644 --- a/drivers/i2c/busses/i2c-puv3.c +++ b/drivers/i2c/busses/i2c-puv3.c | |||
@@ -254,7 +254,7 @@ static int __devexit puv3_i2c_remove(struct platform_device *pdev) | |||
254 | } | 254 | } |
255 | 255 | ||
256 | #ifdef CONFIG_PM | 256 | #ifdef CONFIG_PM |
257 | static int puv3_i2c_suspend(struct platform_device *dev, pm_message_t state) | 257 | static int puv3_i2c_suspend(struct device *dev) |
258 | { | 258 | { |
259 | int poll_count; | 259 | int poll_count; |
260 | /* Disable the IIC */ | 260 | /* Disable the IIC */ |
@@ -267,23 +267,20 @@ static int puv3_i2c_suspend(struct platform_device *dev, pm_message_t state) | |||
267 | return 0; | 267 | return 0; |
268 | } | 268 | } |
269 | 269 | ||
270 | static int puv3_i2c_resume(struct platform_device *dev) | 270 | static SIMPLE_DEV_PM_OPS(puv3_i2c_pm, puv3_i2c_suspend, NULL); |
271 | { | 271 | #define PUV3_I2C_PM (&puv3_i2c_pm) |
272 | return 0 ; | 272 | |
273 | } | ||
274 | #else | 273 | #else |
275 | #define puv3_i2c_suspend NULL | 274 | #define PUV3_I2C_PM NULL |
276 | #define puv3_i2c_resume NULL | ||
277 | #endif | 275 | #endif |
278 | 276 | ||
279 | static struct platform_driver puv3_i2c_driver = { | 277 | static struct platform_driver puv3_i2c_driver = { |
280 | .probe = puv3_i2c_probe, | 278 | .probe = puv3_i2c_probe, |
281 | .remove = __devexit_p(puv3_i2c_remove), | 279 | .remove = __devexit_p(puv3_i2c_remove), |
282 | .suspend = puv3_i2c_suspend, | ||
283 | .resume = puv3_i2c_resume, | ||
284 | .driver = { | 280 | .driver = { |
285 | .name = "PKUnity-v3-I2C", | 281 | .name = "PKUnity-v3-I2C", |
286 | .owner = THIS_MODULE, | 282 | .owner = THIS_MODULE, |
283 | .pm = PUV3_I2C_PM, | ||
287 | } | 284 | } |
288 | }; | 285 | }; |
289 | 286 | ||
diff --git a/drivers/i2c/busses/i2c-s3c2410.c b/drivers/i2c/busses/i2c-s3c2410.c index 01959154572d..5ae3b0236bd3 100644 --- a/drivers/i2c/busses/i2c-s3c2410.c +++ b/drivers/i2c/busses/i2c-s3c2410.c | |||
@@ -122,7 +122,7 @@ static inline unsigned int s3c24xx_get_device_quirks(struct platform_device *pde | |||
122 | { | 122 | { |
123 | if (pdev->dev.of_node) { | 123 | if (pdev->dev.of_node) { |
124 | const struct of_device_id *match; | 124 | const struct of_device_id *match; |
125 | match = of_match_node(&s3c24xx_i2c_match, pdev->dev.of_node); | 125 | match = of_match_node(s3c24xx_i2c_match, pdev->dev.of_node); |
126 | return (unsigned int)match->data; | 126 | return (unsigned int)match->data; |
127 | } | 127 | } |
128 | 128 | ||
@@ -609,7 +609,7 @@ static int s3c24xx_i2c_xfer(struct i2c_adapter *adap, | |||
609 | 609 | ||
610 | if (ret != -EAGAIN) { | 610 | if (ret != -EAGAIN) { |
611 | clk_disable(i2c->clk); | 611 | clk_disable(i2c->clk); |
612 | pm_runtime_put_sync(&adap->dev); | 612 | pm_runtime_put(&adap->dev); |
613 | return ret; | 613 | return ret; |
614 | } | 614 | } |
615 | 615 | ||
@@ -619,7 +619,7 @@ static int s3c24xx_i2c_xfer(struct i2c_adapter *adap, | |||
619 | } | 619 | } |
620 | 620 | ||
621 | clk_disable(i2c->clk); | 621 | clk_disable(i2c->clk); |
622 | pm_runtime_put_sync(&adap->dev); | 622 | pm_runtime_put(&adap->dev); |
623 | return -EREMOTEIO; | 623 | return -EREMOTEIO; |
624 | } | 624 | } |
625 | 625 | ||
diff --git a/drivers/i2c/busses/i2c-stu300.c b/drivers/i2c/busses/i2c-stu300.c index 4d44af181f37..580a0c04cb42 100644 --- a/drivers/i2c/busses/i2c-stu300.c +++ b/drivers/i2c/busses/i2c-stu300.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (C) 2007-2009 ST-Ericsson AB | 2 | * Copyright (C) 2007-2012 ST-Ericsson AB |
3 | * License terms: GNU General Public License (GPL) version 2 | 3 | * License terms: GNU General Public License (GPL) version 2 |
4 | * ST DDC I2C master mode driver, used in e.g. U300 series platforms. | 4 | * ST DDC I2C master mode driver, used in e.g. U300 series platforms. |
5 | * Author: Linus Walleij <linus.walleij@stericsson.com> | 5 | * Author: Linus Walleij <linus.walleij@stericsson.com> |
@@ -139,8 +139,6 @@ module_param(scl_frequency, uint, 0644); | |||
139 | * struct stu300_dev - the stu300 driver state holder | 139 | * struct stu300_dev - the stu300 driver state holder |
140 | * @pdev: parent platform device | 140 | * @pdev: parent platform device |
141 | * @adapter: corresponding I2C adapter | 141 | * @adapter: corresponding I2C adapter |
142 | * @phybase: location of I/O area in memory | ||
143 | * @physize: size of I/O area in memory | ||
144 | * @clk: hardware block clock | 142 | * @clk: hardware block clock |
145 | * @irq: assigned interrupt line | 143 | * @irq: assigned interrupt line |
146 | * @cmd_issue_lock: this locks the following cmd_ variables | 144 | * @cmd_issue_lock: this locks the following cmd_ variables |
@@ -155,8 +153,6 @@ module_param(scl_frequency, uint, 0644); | |||
155 | struct stu300_dev { | 153 | struct stu300_dev { |
156 | struct platform_device *pdev; | 154 | struct platform_device *pdev; |
157 | struct i2c_adapter adapter; | 155 | struct i2c_adapter adapter; |
158 | resource_size_t phybase; | ||
159 | resource_size_t physize; | ||
160 | void __iomem *virtbase; | 156 | void __iomem *virtbase; |
161 | struct clk *clk; | 157 | struct clk *clk; |
162 | int irq; | 158 | int irq; |
@@ -873,64 +869,44 @@ stu300_probe(struct platform_device *pdev) | |||
873 | int ret = 0; | 869 | int ret = 0; |
874 | char clk_name[] = "I2C0"; | 870 | char clk_name[] = "I2C0"; |
875 | 871 | ||
876 | dev = kzalloc(sizeof(struct stu300_dev), GFP_KERNEL); | 872 | dev = devm_kzalloc(&pdev->dev, sizeof(struct stu300_dev), GFP_KERNEL); |
877 | if (!dev) { | 873 | if (!dev) { |
878 | dev_err(&pdev->dev, "could not allocate device struct\n"); | 874 | dev_err(&pdev->dev, "could not allocate device struct\n"); |
879 | ret = -ENOMEM; | 875 | return -ENOMEM; |
880 | goto err_no_devmem; | ||
881 | } | 876 | } |
882 | 877 | ||
883 | bus_nr = pdev->id; | 878 | bus_nr = pdev->id; |
884 | clk_name[3] += (char)bus_nr; | 879 | clk_name[3] += (char)bus_nr; |
885 | dev->clk = clk_get(&pdev->dev, clk_name); | 880 | dev->clk = devm_clk_get(&pdev->dev, clk_name); |
886 | if (IS_ERR(dev->clk)) { | 881 | if (IS_ERR(dev->clk)) { |
887 | ret = PTR_ERR(dev->clk); | ||
888 | dev_err(&pdev->dev, "could not retrieve i2c bus clock\n"); | 882 | dev_err(&pdev->dev, "could not retrieve i2c bus clock\n"); |
889 | goto err_no_clk; | 883 | return PTR_ERR(dev->clk); |
890 | } | 884 | } |
891 | 885 | ||
892 | dev->pdev = pdev; | 886 | dev->pdev = pdev; |
893 | platform_set_drvdata(pdev, dev); | ||
894 | |||
895 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 887 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
896 | if (!res) { | 888 | if (!res) |
897 | ret = -ENOENT; | 889 | return -ENOENT; |
898 | goto err_no_resource; | ||
899 | } | ||
900 | |||
901 | dev->phybase = res->start; | ||
902 | dev->physize = resource_size(res); | ||
903 | |||
904 | if (request_mem_region(dev->phybase, dev->physize, | ||
905 | NAME " I/O Area") == NULL) { | ||
906 | ret = -EBUSY; | ||
907 | goto err_no_ioregion; | ||
908 | } | ||
909 | 890 | ||
910 | dev->virtbase = ioremap(dev->phybase, dev->physize); | 891 | dev->virtbase = devm_request_and_ioremap(&pdev->dev, res); |
911 | dev_dbg(&pdev->dev, "initialize bus device I2C%d on virtual " | 892 | dev_dbg(&pdev->dev, "initialize bus device I2C%d on virtual " |
912 | "base %p\n", bus_nr, dev->virtbase); | 893 | "base %p\n", bus_nr, dev->virtbase); |
913 | if (!dev->virtbase) { | 894 | if (!dev->virtbase) |
914 | ret = -ENOMEM; | 895 | return -ENOMEM; |
915 | goto err_no_ioremap; | ||
916 | } | ||
917 | 896 | ||
918 | dev->irq = platform_get_irq(pdev, 0); | 897 | dev->irq = platform_get_irq(pdev, 0); |
919 | if (request_irq(dev->irq, stu300_irh, 0, | 898 | ret = devm_request_irq(&pdev->dev, dev->irq, stu300_irh, 0, NAME, dev); |
920 | NAME, dev)) { | 899 | if (ret < 0) |
921 | ret = -EIO; | 900 | return ret; |
922 | goto err_no_irq; | ||
923 | } | ||
924 | 901 | ||
925 | dev->speed = scl_frequency; | 902 | dev->speed = scl_frequency; |
926 | 903 | ||
927 | clk_enable(dev->clk); | 904 | clk_prepare_enable(dev->clk); |
928 | ret = stu300_init_hw(dev); | 905 | ret = stu300_init_hw(dev); |
929 | clk_disable(dev->clk); | 906 | clk_disable(dev->clk); |
930 | |||
931 | if (ret != 0) { | 907 | if (ret != 0) { |
932 | dev_err(&dev->pdev->dev, "error initializing hardware.\n"); | 908 | dev_err(&dev->pdev->dev, "error initializing hardware.\n"); |
933 | goto err_init_hw; | 909 | return -EIO; |
934 | } | 910 | } |
935 | 911 | ||
936 | /* IRQ event handling initialization */ | 912 | /* IRQ event handling initialization */ |
@@ -952,57 +928,43 @@ stu300_probe(struct platform_device *pdev) | |||
952 | /* i2c device drivers may be active on return from add_adapter() */ | 928 | /* i2c device drivers may be active on return from add_adapter() */ |
953 | ret = i2c_add_numbered_adapter(adap); | 929 | ret = i2c_add_numbered_adapter(adap); |
954 | if (ret) { | 930 | if (ret) { |
955 | dev_err(&dev->pdev->dev, "failure adding ST Micro DDC " | 931 | dev_err(&pdev->dev, "failure adding ST Micro DDC " |
956 | "I2C adapter\n"); | 932 | "I2C adapter\n"); |
957 | goto err_add_adapter; | 933 | return ret; |
958 | } | 934 | } |
959 | return 0; | ||
960 | 935 | ||
961 | err_add_adapter: | 936 | platform_set_drvdata(pdev, dev); |
962 | err_init_hw: | 937 | return 0; |
963 | free_irq(dev->irq, dev); | ||
964 | err_no_irq: | ||
965 | iounmap(dev->virtbase); | ||
966 | err_no_ioremap: | ||
967 | release_mem_region(dev->phybase, dev->physize); | ||
968 | err_no_ioregion: | ||
969 | platform_set_drvdata(pdev, NULL); | ||
970 | err_no_resource: | ||
971 | clk_put(dev->clk); | ||
972 | err_no_clk: | ||
973 | kfree(dev); | ||
974 | err_no_devmem: | ||
975 | dev_err(&pdev->dev, "failed to add " NAME " adapter: %d\n", | ||
976 | pdev->id); | ||
977 | return ret; | ||
978 | } | 938 | } |
979 | 939 | ||
980 | #ifdef CONFIG_PM | 940 | #ifdef CONFIG_PM |
981 | static int stu300_suspend(struct platform_device *pdev, pm_message_t state) | 941 | static int stu300_suspend(struct device *device) |
982 | { | 942 | { |
983 | struct stu300_dev *dev = platform_get_drvdata(pdev); | 943 | struct stu300_dev *dev = dev_get_drvdata(device); |
984 | 944 | ||
985 | /* Turn off everything */ | 945 | /* Turn off everything */ |
986 | stu300_wr8(0x00, dev->virtbase + I2C_CR); | 946 | stu300_wr8(0x00, dev->virtbase + I2C_CR); |
987 | return 0; | 947 | return 0; |
988 | } | 948 | } |
989 | 949 | ||
990 | static int stu300_resume(struct platform_device *pdev) | 950 | static int stu300_resume(struct device *device) |
991 | { | 951 | { |
992 | int ret = 0; | 952 | int ret = 0; |
993 | struct stu300_dev *dev = platform_get_drvdata(pdev); | 953 | struct stu300_dev *dev = dev_get_drvdata(device); |
994 | 954 | ||
995 | clk_enable(dev->clk); | 955 | clk_enable(dev->clk); |
996 | ret = stu300_init_hw(dev); | 956 | ret = stu300_init_hw(dev); |
997 | clk_disable(dev->clk); | 957 | clk_disable(dev->clk); |
998 | 958 | ||
999 | if (ret != 0) | 959 | if (ret != 0) |
1000 | dev_err(&pdev->dev, "error re-initializing hardware.\n"); | 960 | dev_err(device, "error re-initializing hardware.\n"); |
1001 | return ret; | 961 | return ret; |
1002 | } | 962 | } |
963 | |||
964 | static SIMPLE_DEV_PM_OPS(stu300_pm, stu300_suspend, stu300_resume); | ||
965 | #define STU300_I2C_PM (&stu300_pm) | ||
1003 | #else | 966 | #else |
1004 | #define stu300_suspend NULL | 967 | #define STU300_I2C_PM NULL |
1005 | #define stu300_resume NULL | ||
1006 | #endif | 968 | #endif |
1007 | 969 | ||
1008 | static int __exit | 970 | static int __exit |
@@ -1013,12 +975,7 @@ stu300_remove(struct platform_device *pdev) | |||
1013 | i2c_del_adapter(&dev->adapter); | 975 | i2c_del_adapter(&dev->adapter); |
1014 | /* Turn off everything */ | 976 | /* Turn off everything */ |
1015 | stu300_wr8(0x00, dev->virtbase + I2C_CR); | 977 | stu300_wr8(0x00, dev->virtbase + I2C_CR); |
1016 | free_irq(dev->irq, dev); | ||
1017 | iounmap(dev->virtbase); | ||
1018 | release_mem_region(dev->phybase, dev->physize); | ||
1019 | clk_put(dev->clk); | ||
1020 | platform_set_drvdata(pdev, NULL); | 978 | platform_set_drvdata(pdev, NULL); |
1021 | kfree(dev); | ||
1022 | return 0; | 979 | return 0; |
1023 | } | 980 | } |
1024 | 981 | ||
@@ -1026,10 +983,9 @@ static struct platform_driver stu300_i2c_driver = { | |||
1026 | .driver = { | 983 | .driver = { |
1027 | .name = NAME, | 984 | .name = NAME, |
1028 | .owner = THIS_MODULE, | 985 | .owner = THIS_MODULE, |
986 | .pm = STU300_I2C_PM, | ||
1029 | }, | 987 | }, |
1030 | .remove = __exit_p(stu300_remove), | 988 | .remove = __exit_p(stu300_remove), |
1031 | .suspend = stu300_suspend, | ||
1032 | .resume = stu300_resume, | ||
1033 | 989 | ||
1034 | }; | 990 | }; |
1035 | 991 | ||
diff --git a/drivers/i2c/busses/i2c-tegra.c b/drivers/i2c/busses/i2c-tegra.c index 3da7ee3eb505..66eb53fac202 100644 --- a/drivers/i2c/busses/i2c-tegra.c +++ b/drivers/i2c/busses/i2c-tegra.c | |||
@@ -97,8 +97,21 @@ | |||
97 | #define I2C_HEADER_10BIT_ADDR (1<<18) | 97 | #define I2C_HEADER_10BIT_ADDR (1<<18) |
98 | #define I2C_HEADER_IE_ENABLE (1<<17) | 98 | #define I2C_HEADER_IE_ENABLE (1<<17) |
99 | #define I2C_HEADER_REPEAT_START (1<<16) | 99 | #define I2C_HEADER_REPEAT_START (1<<16) |
100 | #define I2C_HEADER_CONTINUE_XFER (1<<15) | ||
100 | #define I2C_HEADER_MASTER_ADDR_SHIFT 12 | 101 | #define I2C_HEADER_MASTER_ADDR_SHIFT 12 |
101 | #define I2C_HEADER_SLAVE_ADDR_SHIFT 1 | 102 | #define I2C_HEADER_SLAVE_ADDR_SHIFT 1 |
103 | /* | ||
104 | * msg_end_type: The bus control which need to be send at end of transfer. | ||
105 | * @MSG_END_STOP: Send stop pulse at end of transfer. | ||
106 | * @MSG_END_REPEAT_START: Send repeat start at end of transfer. | ||
107 | * @MSG_END_CONTINUE: The following on message is coming and so do not send | ||
108 | * stop or repeat start. | ||
109 | */ | ||
110 | enum msg_end_type { | ||
111 | MSG_END_STOP, | ||
112 | MSG_END_REPEAT_START, | ||
113 | MSG_END_CONTINUE, | ||
114 | }; | ||
102 | 115 | ||
103 | /** | 116 | /** |
104 | * struct tegra_i2c_dev - per device i2c context | 117 | * struct tegra_i2c_dev - per device i2c context |
@@ -106,7 +119,6 @@ | |||
106 | * @adapter: core i2c layer adapter information | 119 | * @adapter: core i2c layer adapter information |
107 | * @clk: clock reference for i2c controller | 120 | * @clk: clock reference for i2c controller |
108 | * @i2c_clk: clock reference for i2c bus | 121 | * @i2c_clk: clock reference for i2c bus |
109 | * @iomem: memory resource for registers | ||
110 | * @base: ioremapped registers cookie | 122 | * @base: ioremapped registers cookie |
111 | * @cont_id: i2c controller id, used for for packet header | 123 | * @cont_id: i2c controller id, used for for packet header |
112 | * @irq: irq number of transfer complete interrupt | 124 | * @irq: irq number of transfer complete interrupt |
@@ -124,7 +136,6 @@ struct tegra_i2c_dev { | |||
124 | struct i2c_adapter adapter; | 136 | struct i2c_adapter adapter; |
125 | struct clk *clk; | 137 | struct clk *clk; |
126 | struct clk *i2c_clk; | 138 | struct clk *i2c_clk; |
127 | struct resource *iomem; | ||
128 | void __iomem *base; | 139 | void __iomem *base; |
129 | int cont_id; | 140 | int cont_id; |
130 | int irq; | 141 | int irq; |
@@ -165,6 +176,10 @@ static void i2c_writel(struct tegra_i2c_dev *i2c_dev, u32 val, | |||
165 | unsigned long reg) | 176 | unsigned long reg) |
166 | { | 177 | { |
167 | writel(val, i2c_dev->base + tegra_i2c_reg_addr(i2c_dev, reg)); | 178 | writel(val, i2c_dev->base + tegra_i2c_reg_addr(i2c_dev, reg)); |
179 | |||
180 | /* Read back register to make sure that register writes completed */ | ||
181 | if (reg != I2C_TX_FIFO) | ||
182 | readl(i2c_dev->base + tegra_i2c_reg_addr(i2c_dev, reg)); | ||
168 | } | 183 | } |
169 | 184 | ||
170 | static u32 i2c_readl(struct tegra_i2c_dev *i2c_dev, unsigned long reg) | 185 | static u32 i2c_readl(struct tegra_i2c_dev *i2c_dev, unsigned long reg) |
@@ -449,7 +464,7 @@ err: | |||
449 | } | 464 | } |
450 | 465 | ||
451 | static int tegra_i2c_xfer_msg(struct tegra_i2c_dev *i2c_dev, | 466 | static int tegra_i2c_xfer_msg(struct tegra_i2c_dev *i2c_dev, |
452 | struct i2c_msg *msg, int stop) | 467 | struct i2c_msg *msg, enum msg_end_type end_state) |
453 | { | 468 | { |
454 | u32 packet_header; | 469 | u32 packet_header; |
455 | u32 int_mask; | 470 | u32 int_mask; |
@@ -476,7 +491,9 @@ static int tegra_i2c_xfer_msg(struct tegra_i2c_dev *i2c_dev, | |||
476 | i2c_writel(i2c_dev, packet_header, I2C_TX_FIFO); | 491 | i2c_writel(i2c_dev, packet_header, I2C_TX_FIFO); |
477 | 492 | ||
478 | packet_header = I2C_HEADER_IE_ENABLE; | 493 | packet_header = I2C_HEADER_IE_ENABLE; |
479 | if (!stop) | 494 | if (end_state == MSG_END_CONTINUE) |
495 | packet_header |= I2C_HEADER_CONTINUE_XFER; | ||
496 | else if (end_state == MSG_END_REPEAT_START) | ||
480 | packet_header |= I2C_HEADER_REPEAT_START; | 497 | packet_header |= I2C_HEADER_REPEAT_START; |
481 | if (msg->flags & I2C_M_TEN) { | 498 | if (msg->flags & I2C_M_TEN) { |
482 | packet_header |= msg->addr; | 499 | packet_header |= msg->addr; |
@@ -548,8 +565,14 @@ static int tegra_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msgs[], | |||
548 | 565 | ||
549 | clk_prepare_enable(i2c_dev->clk); | 566 | clk_prepare_enable(i2c_dev->clk); |
550 | for (i = 0; i < num; i++) { | 567 | for (i = 0; i < num; i++) { |
551 | int stop = (i == (num - 1)) ? 1 : 0; | 568 | enum msg_end_type end_type = MSG_END_STOP; |
552 | ret = tegra_i2c_xfer_msg(i2c_dev, &msgs[i], stop); | 569 | if (i < (num - 1)) { |
570 | if (msgs[i + 1].flags & I2C_M_NOSTART) | ||
571 | end_type = MSG_END_CONTINUE; | ||
572 | else | ||
573 | end_type = MSG_END_REPEAT_START; | ||
574 | } | ||
575 | ret = tegra_i2c_xfer_msg(i2c_dev, &msgs[i], end_type); | ||
553 | if (ret) | 576 | if (ret) |
554 | break; | 577 | break; |
555 | } | 578 | } |
@@ -559,7 +582,8 @@ static int tegra_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msgs[], | |||
559 | 582 | ||
560 | static u32 tegra_i2c_func(struct i2c_adapter *adap) | 583 | static u32 tegra_i2c_func(struct i2c_adapter *adap) |
561 | { | 584 | { |
562 | return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL | I2C_FUNC_10BIT_ADDR; | 585 | return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL | I2C_FUNC_10BIT_ADDR | |
586 | I2C_FUNC_PROTOCOL_MANGLING | I2C_FUNC_NOSTART; | ||
563 | } | 587 | } |
564 | 588 | ||
565 | static const struct i2c_algorithm tegra_i2c_algo = { | 589 | static const struct i2c_algorithm tegra_i2c_algo = { |
@@ -572,7 +596,6 @@ static int __devinit tegra_i2c_probe(struct platform_device *pdev) | |||
572 | struct tegra_i2c_dev *i2c_dev; | 596 | struct tegra_i2c_dev *i2c_dev; |
573 | struct tegra_i2c_platform_data *pdata = pdev->dev.platform_data; | 597 | struct tegra_i2c_platform_data *pdata = pdev->dev.platform_data; |
574 | struct resource *res; | 598 | struct resource *res; |
575 | struct resource *iomem; | ||
576 | struct clk *clk; | 599 | struct clk *clk; |
577 | struct clk *i2c_clk; | 600 | struct clk *i2c_clk; |
578 | const unsigned int *prop; | 601 | const unsigned int *prop; |
@@ -585,50 +608,41 @@ static int __devinit tegra_i2c_probe(struct platform_device *pdev) | |||
585 | dev_err(&pdev->dev, "no mem resource\n"); | 608 | dev_err(&pdev->dev, "no mem resource\n"); |
586 | return -EINVAL; | 609 | return -EINVAL; |
587 | } | 610 | } |
588 | iomem = request_mem_region(res->start, resource_size(res), pdev->name); | ||
589 | if (!iomem) { | ||
590 | dev_err(&pdev->dev, "I2C region already claimed\n"); | ||
591 | return -EBUSY; | ||
592 | } | ||
593 | 611 | ||
594 | base = ioremap(iomem->start, resource_size(iomem)); | 612 | base = devm_request_and_ioremap(&pdev->dev, res); |
595 | if (!base) { | 613 | if (!base) { |
596 | dev_err(&pdev->dev, "Cannot ioremap I2C region\n"); | 614 | dev_err(&pdev->dev, "Cannot request/ioremap I2C registers\n"); |
597 | return -ENOMEM; | 615 | return -EADDRNOTAVAIL; |
598 | } | 616 | } |
599 | 617 | ||
600 | res = platform_get_resource(pdev, IORESOURCE_IRQ, 0); | 618 | res = platform_get_resource(pdev, IORESOURCE_IRQ, 0); |
601 | if (!res) { | 619 | if (!res) { |
602 | dev_err(&pdev->dev, "no irq resource\n"); | 620 | dev_err(&pdev->dev, "no irq resource\n"); |
603 | ret = -EINVAL; | 621 | return -EINVAL; |
604 | goto err_iounmap; | ||
605 | } | 622 | } |
606 | irq = res->start; | 623 | irq = res->start; |
607 | 624 | ||
608 | clk = clk_get(&pdev->dev, NULL); | 625 | clk = devm_clk_get(&pdev->dev, NULL); |
609 | if (IS_ERR(clk)) { | 626 | if (IS_ERR(clk)) { |
610 | dev_err(&pdev->dev, "missing controller clock"); | 627 | dev_err(&pdev->dev, "missing controller clock"); |
611 | ret = PTR_ERR(clk); | 628 | return PTR_ERR(clk); |
612 | goto err_release_region; | ||
613 | } | 629 | } |
614 | 630 | ||
615 | i2c_clk = clk_get(&pdev->dev, "i2c"); | 631 | i2c_clk = devm_clk_get(&pdev->dev, "i2c"); |
616 | if (IS_ERR(i2c_clk)) { | 632 | if (IS_ERR(i2c_clk)) { |
617 | dev_err(&pdev->dev, "missing bus clock"); | 633 | dev_err(&pdev->dev, "missing bus clock"); |
618 | ret = PTR_ERR(i2c_clk); | 634 | return PTR_ERR(i2c_clk); |
619 | goto err_clk_put; | ||
620 | } | 635 | } |
621 | 636 | ||
622 | i2c_dev = kzalloc(sizeof(struct tegra_i2c_dev), GFP_KERNEL); | 637 | i2c_dev = devm_kzalloc(&pdev->dev, sizeof(*i2c_dev), GFP_KERNEL); |
623 | if (!i2c_dev) { | 638 | if (!i2c_dev) { |
624 | ret = -ENOMEM; | 639 | dev_err(&pdev->dev, "Could not allocate struct tegra_i2c_dev"); |
625 | goto err_i2c_clk_put; | 640 | return -ENOMEM; |
626 | } | 641 | } |
627 | 642 | ||
628 | i2c_dev->base = base; | 643 | i2c_dev->base = base; |
629 | i2c_dev->clk = clk; | 644 | i2c_dev->clk = clk; |
630 | i2c_dev->i2c_clk = i2c_clk; | 645 | i2c_dev->i2c_clk = i2c_clk; |
631 | i2c_dev->iomem = iomem; | ||
632 | i2c_dev->adapter.algo = &tegra_i2c_algo; | 646 | i2c_dev->adapter.algo = &tegra_i2c_algo; |
633 | i2c_dev->irq = irq; | 647 | i2c_dev->irq = irq; |
634 | i2c_dev->cont_id = pdev->id; | 648 | i2c_dev->cont_id = pdev->id; |
@@ -657,13 +671,14 @@ static int __devinit tegra_i2c_probe(struct platform_device *pdev) | |||
657 | ret = tegra_i2c_init(i2c_dev); | 671 | ret = tegra_i2c_init(i2c_dev); |
658 | if (ret) { | 672 | if (ret) { |
659 | dev_err(&pdev->dev, "Failed to initialize i2c controller"); | 673 | dev_err(&pdev->dev, "Failed to initialize i2c controller"); |
660 | goto err_free; | 674 | return ret; |
661 | } | 675 | } |
662 | 676 | ||
663 | ret = request_irq(i2c_dev->irq, tegra_i2c_isr, 0, pdev->name, i2c_dev); | 677 | ret = devm_request_irq(&pdev->dev, i2c_dev->irq, |
678 | tegra_i2c_isr, 0, pdev->name, i2c_dev); | ||
664 | if (ret) { | 679 | if (ret) { |
665 | dev_err(&pdev->dev, "Failed to request irq %i\n", i2c_dev->irq); | 680 | dev_err(&pdev->dev, "Failed to request irq %i\n", i2c_dev->irq); |
666 | goto err_free; | 681 | return ret; |
667 | } | 682 | } |
668 | 683 | ||
669 | clk_prepare_enable(i2c_dev->i2c_clk); | 684 | clk_prepare_enable(i2c_dev->i2c_clk); |
@@ -681,45 +696,26 @@ static int __devinit tegra_i2c_probe(struct platform_device *pdev) | |||
681 | ret = i2c_add_numbered_adapter(&i2c_dev->adapter); | 696 | ret = i2c_add_numbered_adapter(&i2c_dev->adapter); |
682 | if (ret) { | 697 | if (ret) { |
683 | dev_err(&pdev->dev, "Failed to add I2C adapter\n"); | 698 | dev_err(&pdev->dev, "Failed to add I2C adapter\n"); |
684 | goto err_free_irq; | 699 | clk_disable_unprepare(i2c_dev->i2c_clk); |
700 | return ret; | ||
685 | } | 701 | } |
686 | 702 | ||
687 | of_i2c_register_devices(&i2c_dev->adapter); | 703 | of_i2c_register_devices(&i2c_dev->adapter); |
688 | 704 | ||
689 | return 0; | 705 | return 0; |
690 | err_free_irq: | ||
691 | free_irq(i2c_dev->irq, i2c_dev); | ||
692 | err_free: | ||
693 | kfree(i2c_dev); | ||
694 | err_i2c_clk_put: | ||
695 | clk_put(i2c_clk); | ||
696 | err_clk_put: | ||
697 | clk_put(clk); | ||
698 | err_release_region: | ||
699 | release_mem_region(iomem->start, resource_size(iomem)); | ||
700 | err_iounmap: | ||
701 | iounmap(base); | ||
702 | return ret; | ||
703 | } | 706 | } |
704 | 707 | ||
705 | static int __devexit tegra_i2c_remove(struct platform_device *pdev) | 708 | static int __devexit tegra_i2c_remove(struct platform_device *pdev) |
706 | { | 709 | { |
707 | struct tegra_i2c_dev *i2c_dev = platform_get_drvdata(pdev); | 710 | struct tegra_i2c_dev *i2c_dev = platform_get_drvdata(pdev); |
708 | i2c_del_adapter(&i2c_dev->adapter); | 711 | i2c_del_adapter(&i2c_dev->adapter); |
709 | free_irq(i2c_dev->irq, i2c_dev); | ||
710 | clk_put(i2c_dev->i2c_clk); | ||
711 | clk_put(i2c_dev->clk); | ||
712 | release_mem_region(i2c_dev->iomem->start, | ||
713 | resource_size(i2c_dev->iomem)); | ||
714 | iounmap(i2c_dev->base); | ||
715 | kfree(i2c_dev); | ||
716 | return 0; | 712 | return 0; |
717 | } | 713 | } |
718 | 714 | ||
719 | #ifdef CONFIG_PM | 715 | #ifdef CONFIG_PM |
720 | static int tegra_i2c_suspend(struct platform_device *pdev, pm_message_t state) | 716 | static int tegra_i2c_suspend(struct device *dev) |
721 | { | 717 | { |
722 | struct tegra_i2c_dev *i2c_dev = platform_get_drvdata(pdev); | 718 | struct tegra_i2c_dev *i2c_dev = dev_get_drvdata(dev); |
723 | 719 | ||
724 | i2c_lock_adapter(&i2c_dev->adapter); | 720 | i2c_lock_adapter(&i2c_dev->adapter); |
725 | i2c_dev->is_suspended = true; | 721 | i2c_dev->is_suspended = true; |
@@ -728,9 +724,9 @@ static int tegra_i2c_suspend(struct platform_device *pdev, pm_message_t state) | |||
728 | return 0; | 724 | return 0; |
729 | } | 725 | } |
730 | 726 | ||
731 | static int tegra_i2c_resume(struct platform_device *pdev) | 727 | static int tegra_i2c_resume(struct device *dev) |
732 | { | 728 | { |
733 | struct tegra_i2c_dev *i2c_dev = platform_get_drvdata(pdev); | 729 | struct tegra_i2c_dev *i2c_dev = dev_get_drvdata(dev); |
734 | int ret; | 730 | int ret; |
735 | 731 | ||
736 | i2c_lock_adapter(&i2c_dev->adapter); | 732 | i2c_lock_adapter(&i2c_dev->adapter); |
@@ -748,6 +744,11 @@ static int tegra_i2c_resume(struct platform_device *pdev) | |||
748 | 744 | ||
749 | return 0; | 745 | return 0; |
750 | } | 746 | } |
747 | |||
748 | static SIMPLE_DEV_PM_OPS(tegra_i2c_pm, tegra_i2c_suspend, tegra_i2c_resume); | ||
749 | #define TEGRA_I2C_PM (&tegra_i2c_pm) | ||
750 | #else | ||
751 | #define TEGRA_I2C_PM NULL | ||
751 | #endif | 752 | #endif |
752 | 753 | ||
753 | #if defined(CONFIG_OF) | 754 | #if defined(CONFIG_OF) |
@@ -758,21 +759,16 @@ static const struct of_device_id tegra_i2c_of_match[] __devinitconst = { | |||
758 | {}, | 759 | {}, |
759 | }; | 760 | }; |
760 | MODULE_DEVICE_TABLE(of, tegra_i2c_of_match); | 761 | MODULE_DEVICE_TABLE(of, tegra_i2c_of_match); |
761 | #else | ||
762 | #define tegra_i2c_of_match NULL | ||
763 | #endif | 762 | #endif |
764 | 763 | ||
765 | static struct platform_driver tegra_i2c_driver = { | 764 | static struct platform_driver tegra_i2c_driver = { |
766 | .probe = tegra_i2c_probe, | 765 | .probe = tegra_i2c_probe, |
767 | .remove = __devexit_p(tegra_i2c_remove), | 766 | .remove = __devexit_p(tegra_i2c_remove), |
768 | #ifdef CONFIG_PM | ||
769 | .suspend = tegra_i2c_suspend, | ||
770 | .resume = tegra_i2c_resume, | ||
771 | #endif | ||
772 | .driver = { | 767 | .driver = { |
773 | .name = "tegra-i2c", | 768 | .name = "tegra-i2c", |
774 | .owner = THIS_MODULE, | 769 | .owner = THIS_MODULE, |
775 | .of_match_table = tegra_i2c_of_match, | 770 | .of_match_table = of_match_ptr(tegra_i2c_of_match), |
771 | .pm = TEGRA_I2C_PM, | ||
776 | }, | 772 | }, |
777 | }; | 773 | }; |
778 | 774 | ||