diff options
Diffstat (limited to 'drivers/i2c/algos/i2c-algo-bit.c')
-rw-r--r-- | drivers/i2c/algos/i2c-algo-bit.c | 286 |
1 files changed, 168 insertions, 118 deletions
diff --git a/drivers/i2c/algos/i2c-algo-bit.c b/drivers/i2c/algos/i2c-algo-bit.c index 95aa5395a5be..8a5f5825bb72 100644 --- a/drivers/i2c/algos/i2c-algo-bit.c +++ b/drivers/i2c/algos/i2c-algo-bit.c | |||
@@ -33,19 +33,30 @@ | |||
33 | 33 | ||
34 | 34 | ||
35 | /* ----- global defines ----------------------------------------------- */ | 35 | /* ----- global defines ----------------------------------------------- */ |
36 | #define DEB(x) if (i2c_debug>=1) x; | ||
37 | #define DEB2(x) if (i2c_debug>=2) x; | ||
38 | #define DEBSTAT(x) if (i2c_debug>=3) x; /* print several statistical values*/ | ||
39 | #define DEBPROTO(x) if (i2c_debug>=9) { x; } | ||
40 | /* debug the protocol by showing transferred bits */ | ||
41 | 36 | ||
37 | #ifdef DEBUG | ||
38 | #define bit_dbg(level, dev, format, args...) \ | ||
39 | do { \ | ||
40 | if (i2c_debug >= level) \ | ||
41 | dev_dbg(dev, format, ##args); \ | ||
42 | } while (0) | ||
43 | #else | ||
44 | #define bit_dbg(level, dev, format, args...) \ | ||
45 | do {} while (0) | ||
46 | #endif /* DEBUG */ | ||
42 | 47 | ||
43 | /* ----- global variables --------------------------------------------- */ | 48 | /* ----- global variables --------------------------------------------- */ |
44 | 49 | ||
45 | /* module parameters: | ||
46 | */ | ||
47 | static int i2c_debug; | ||
48 | static int bit_test; /* see if the line-setting functions work */ | 50 | static int bit_test; /* see if the line-setting functions work */ |
51 | module_param(bit_test, bool, 0); | ||
52 | MODULE_PARM_DESC(bit_test, "Test the lines of the bus to see if it is stuck"); | ||
53 | |||
54 | #ifdef DEBUG | ||
55 | static int i2c_debug = 1; | ||
56 | module_param(i2c_debug, int, S_IRUGO | S_IWUSR); | ||
57 | MODULE_PARM_DESC(i2c_debug, | ||
58 | "debug level - 0 off; 1 normal; 2 verbose; 3 very verbose"); | ||
59 | #endif | ||
49 | 60 | ||
50 | /* --- setting states on the bus with the right timing: --------------- */ | 61 | /* --- setting states on the bus with the right timing: --------------- */ |
51 | 62 | ||
@@ -57,19 +68,19 @@ static int bit_test; /* see if the line-setting functions work */ | |||
57 | static inline void sdalo(struct i2c_algo_bit_data *adap) | 68 | static inline void sdalo(struct i2c_algo_bit_data *adap) |
58 | { | 69 | { |
59 | setsda(adap,0); | 70 | setsda(adap,0); |
60 | udelay(adap->udelay); | 71 | udelay((adap->udelay + 1) / 2); |
61 | } | 72 | } |
62 | 73 | ||
63 | static inline void sdahi(struct i2c_algo_bit_data *adap) | 74 | static inline void sdahi(struct i2c_algo_bit_data *adap) |
64 | { | 75 | { |
65 | setsda(adap,1); | 76 | setsda(adap,1); |
66 | udelay(adap->udelay); | 77 | udelay((adap->udelay + 1) / 2); |
67 | } | 78 | } |
68 | 79 | ||
69 | static inline void scllo(struct i2c_algo_bit_data *adap) | 80 | static inline void scllo(struct i2c_algo_bit_data *adap) |
70 | { | 81 | { |
71 | setscl(adap,0); | 82 | setscl(adap,0); |
72 | udelay(adap->udelay); | 83 | udelay(adap->udelay / 2); |
73 | } | 84 | } |
74 | 85 | ||
75 | /* | 86 | /* |
@@ -98,7 +109,11 @@ static int sclhi(struct i2c_algo_bit_data *adap) | |||
98 | } | 109 | } |
99 | cond_resched(); | 110 | cond_resched(); |
100 | } | 111 | } |
101 | DEBSTAT(printk(KERN_DEBUG "needed %ld jiffies\n", jiffies-start)); | 112 | #ifdef DEBUG |
113 | if (jiffies != start && i2c_debug >= 3) | ||
114 | pr_debug("i2c-algo-bit: needed %ld jiffies for SCL to go " | ||
115 | "high\n", jiffies - start); | ||
116 | #endif | ||
102 | 117 | ||
103 | done: | 118 | done: |
104 | udelay(adap->udelay); | 119 | udelay(adap->udelay); |
@@ -110,30 +125,29 @@ done: | |||
110 | static void i2c_start(struct i2c_algo_bit_data *adap) | 125 | static void i2c_start(struct i2c_algo_bit_data *adap) |
111 | { | 126 | { |
112 | /* assert: scl, sda are high */ | 127 | /* assert: scl, sda are high */ |
113 | DEBPROTO(printk("S ")); | 128 | setsda(adap, 0); |
114 | sdalo(adap); | 129 | udelay(adap->udelay); |
115 | scllo(adap); | 130 | scllo(adap); |
116 | } | 131 | } |
117 | 132 | ||
118 | static void i2c_repstart(struct i2c_algo_bit_data *adap) | 133 | static void i2c_repstart(struct i2c_algo_bit_data *adap) |
119 | { | 134 | { |
120 | /* scl, sda may not be high */ | 135 | /* assert: scl is low */ |
121 | DEBPROTO(printk(" Sr ")); | 136 | sdahi(adap); |
122 | setsda(adap,1); | ||
123 | sclhi(adap); | 137 | sclhi(adap); |
124 | 138 | setsda(adap, 0); | |
125 | sdalo(adap); | 139 | udelay(adap->udelay); |
126 | scllo(adap); | 140 | scllo(adap); |
127 | } | 141 | } |
128 | 142 | ||
129 | 143 | ||
130 | static void i2c_stop(struct i2c_algo_bit_data *adap) | 144 | static void i2c_stop(struct i2c_algo_bit_data *adap) |
131 | { | 145 | { |
132 | DEBPROTO(printk("P\n")); | ||
133 | /* assert: scl is low */ | 146 | /* assert: scl is low */ |
134 | sdalo(adap); | 147 | sdalo(adap); |
135 | sclhi(adap); | 148 | sclhi(adap); |
136 | sdahi(adap); | 149 | setsda(adap, 1); |
150 | udelay(adap->udelay); | ||
137 | } | 151 | } |
138 | 152 | ||
139 | 153 | ||
@@ -145,7 +159,7 @@ static void i2c_stop(struct i2c_algo_bit_data *adap) | |||
145 | * 0 if the device did not ack | 159 | * 0 if the device did not ack |
146 | * -ETIMEDOUT if an error occurred (while raising the scl line) | 160 | * -ETIMEDOUT if an error occurred (while raising the scl line) |
147 | */ | 161 | */ |
148 | static int i2c_outb(struct i2c_adapter *i2c_adap, char c) | 162 | static int i2c_outb(struct i2c_adapter *i2c_adap, unsigned char c) |
149 | { | 163 | { |
150 | int i; | 164 | int i; |
151 | int sb; | 165 | int sb; |
@@ -154,34 +168,32 @@ static int i2c_outb(struct i2c_adapter *i2c_adap, char c) | |||
154 | 168 | ||
155 | /* assert: scl is low */ | 169 | /* assert: scl is low */ |
156 | for ( i=7 ; i>=0 ; i-- ) { | 170 | for ( i=7 ; i>=0 ; i-- ) { |
157 | sb = c & ( 1 << i ); | 171 | sb = (c >> i) & 1; |
158 | setsda(adap,sb); | 172 | setsda(adap,sb); |
159 | udelay(adap->udelay); | 173 | udelay((adap->udelay + 1) / 2); |
160 | DEBPROTO(printk(KERN_DEBUG "%d",sb!=0)); | ||
161 | if (sclhi(adap)<0) { /* timed out */ | 174 | if (sclhi(adap)<0) { /* timed out */ |
162 | sdahi(adap); /* we don't want to block the net */ | 175 | bit_dbg(1, &i2c_adap->dev, "i2c_outb: 0x%02x, " |
163 | DEB2(printk(KERN_DEBUG " i2c_outb: 0x%02x, timeout at bit #%d\n", c&0xff, i)); | 176 | "timeout at bit #%d\n", (int)c, i); |
164 | return -ETIMEDOUT; | 177 | return -ETIMEDOUT; |
165 | }; | 178 | }; |
166 | /* do arbitration here: | 179 | /* do arbitration here: |
167 | * if ( sb && ! getsda(adap) ) -> ouch! Get out of here. | 180 | * if ( sb && ! getsda(adap) ) -> ouch! Get out of here. |
168 | */ | 181 | */ |
169 | setscl(adap, 0 ); | 182 | scllo(adap); |
170 | udelay(adap->udelay); | ||
171 | } | 183 | } |
172 | sdahi(adap); | 184 | sdahi(adap); |
173 | if (sclhi(adap)<0){ /* timeout */ | 185 | if (sclhi(adap)<0){ /* timeout */ |
174 | DEB2(printk(KERN_DEBUG " i2c_outb: 0x%02x, timeout at ack\n", c&0xff)); | 186 | bit_dbg(1, &i2c_adap->dev, "i2c_outb: 0x%02x, " |
175 | return -ETIMEDOUT; | 187 | "timeout at ack\n", (int)c); |
188 | return -ETIMEDOUT; | ||
176 | }; | 189 | }; |
177 | /* read ack: SDA should be pulled down by slave */ | 190 | /* read ack: SDA should be pulled down by slave */ |
178 | ack=getsda(adap); /* ack: sda is pulled low ->success. */ | 191 | ack = !getsda(adap); /* ack: sda is pulled low -> success */ |
179 | DEB2(printk(KERN_DEBUG " i2c_outb: 0x%02x , getsda() = %d\n", c & 0xff, ack)); | 192 | bit_dbg(2, &i2c_adap->dev, "i2c_outb: 0x%02x %s\n", (int)c, |
193 | ack ? "A" : "NA"); | ||
180 | 194 | ||
181 | DEBPROTO( printk(KERN_DEBUG "[%2.2x]",c&0xff) ); | ||
182 | DEBPROTO(if (0==ack){ printk(KERN_DEBUG " A ");} else printk(KERN_DEBUG " NA ") ); | ||
183 | scllo(adap); | 195 | scllo(adap); |
184 | return 0==ack; /* return 1 if device acked */ | 196 | return ack; |
185 | /* assert: scl is low (sda undef) */ | 197 | /* assert: scl is low (sda undef) */ |
186 | } | 198 | } |
187 | 199 | ||
@@ -198,19 +210,18 @@ static int i2c_inb(struct i2c_adapter *i2c_adap) | |||
198 | sdahi(adap); | 210 | sdahi(adap); |
199 | for (i=0;i<8;i++) { | 211 | for (i=0;i<8;i++) { |
200 | if (sclhi(adap)<0) { /* timeout */ | 212 | if (sclhi(adap)<0) { /* timeout */ |
201 | DEB2(printk(KERN_DEBUG " i2c_inb: timeout at bit #%d\n", 7-i)); | 213 | bit_dbg(1, &i2c_adap->dev, "i2c_inb: timeout at bit " |
214 | "#%d\n", 7 - i); | ||
202 | return -ETIMEDOUT; | 215 | return -ETIMEDOUT; |
203 | }; | 216 | }; |
204 | indata *= 2; | 217 | indata *= 2; |
205 | if ( getsda(adap) ) | 218 | if ( getsda(adap) ) |
206 | indata |= 0x01; | 219 | indata |= 0x01; |
207 | scllo(adap); | 220 | setscl(adap, 0); |
221 | udelay(i == 7 ? adap->udelay / 2 : adap->udelay); | ||
208 | } | 222 | } |
209 | /* assert: scl is low */ | 223 | /* assert: scl is low */ |
210 | DEB2(printk(KERN_DEBUG "i2c_inb: 0x%02x\n", indata & 0xff)); | 224 | return indata; |
211 | |||
212 | DEBPROTO(printk(KERN_DEBUG " 0x%02x", indata & 0xff)); | ||
213 | return (int) (indata & 0xff); | ||
214 | } | 225 | } |
215 | 226 | ||
216 | /* | 227 | /* |
@@ -221,73 +232,67 @@ static int test_bus(struct i2c_algo_bit_data *adap, char* name) { | |||
221 | int scl,sda; | 232 | int scl,sda; |
222 | 233 | ||
223 | if (adap->getscl==NULL) | 234 | if (adap->getscl==NULL) |
224 | printk(KERN_INFO "i2c-algo-bit.o: Testing SDA only, " | 235 | pr_info("%s: Testing SDA only, SCL is not readable\n", name); |
225 | "SCL is not readable.\n"); | ||
226 | 236 | ||
227 | sda=getsda(adap); | 237 | sda=getsda(adap); |
228 | scl=(adap->getscl==NULL?1:getscl(adap)); | 238 | scl=(adap->getscl==NULL?1:getscl(adap)); |
229 | printk(KERN_DEBUG "i2c-algo-bit.o: (0) scl=%d, sda=%d\n",scl,sda); | ||
230 | if (!scl || !sda ) { | 239 | if (!scl || !sda ) { |
231 | printk(KERN_WARNING "i2c-algo-bit.o: %s seems to be busy.\n", name); | 240 | printk(KERN_WARNING "%s: bus seems to be busy\n", name); |
232 | goto bailout; | 241 | goto bailout; |
233 | } | 242 | } |
234 | 243 | ||
235 | sdalo(adap); | 244 | sdalo(adap); |
236 | sda=getsda(adap); | 245 | sda=getsda(adap); |
237 | scl=(adap->getscl==NULL?1:getscl(adap)); | 246 | scl=(adap->getscl==NULL?1:getscl(adap)); |
238 | printk(KERN_DEBUG "i2c-algo-bit.o: (1) scl=%d, sda=%d\n",scl,sda); | ||
239 | if ( 0 != sda ) { | 247 | if ( 0 != sda ) { |
240 | printk(KERN_WARNING "i2c-algo-bit.o: SDA stuck high!\n"); | 248 | printk(KERN_WARNING "%s: SDA stuck high!\n", name); |
241 | goto bailout; | 249 | goto bailout; |
242 | } | 250 | } |
243 | if ( 0 == scl ) { | 251 | if ( 0 == scl ) { |
244 | printk(KERN_WARNING "i2c-algo-bit.o: SCL unexpected low " | 252 | printk(KERN_WARNING "%s: SCL unexpected low " |
245 | "while pulling SDA low!\n"); | 253 | "while pulling SDA low!\n", name); |
246 | goto bailout; | 254 | goto bailout; |
247 | } | 255 | } |
248 | 256 | ||
249 | sdahi(adap); | 257 | sdahi(adap); |
250 | sda=getsda(adap); | 258 | sda=getsda(adap); |
251 | scl=(adap->getscl==NULL?1:getscl(adap)); | 259 | scl=(adap->getscl==NULL?1:getscl(adap)); |
252 | printk(KERN_DEBUG "i2c-algo-bit.o: (2) scl=%d, sda=%d\n",scl,sda); | ||
253 | if ( 0 == sda ) { | 260 | if ( 0 == sda ) { |
254 | printk(KERN_WARNING "i2c-algo-bit.o: SDA stuck low!\n"); | 261 | printk(KERN_WARNING "%s: SDA stuck low!\n", name); |
255 | goto bailout; | 262 | goto bailout; |
256 | } | 263 | } |
257 | if ( 0 == scl ) { | 264 | if ( 0 == scl ) { |
258 | printk(KERN_WARNING "i2c-algo-bit.o: SCL unexpected low " | 265 | printk(KERN_WARNING "%s: SCL unexpected low " |
259 | "while pulling SDA high!\n"); | 266 | "while pulling SDA high!\n", name); |
260 | goto bailout; | 267 | goto bailout; |
261 | } | 268 | } |
262 | 269 | ||
263 | scllo(adap); | 270 | scllo(adap); |
264 | sda=getsda(adap); | 271 | sda=getsda(adap); |
265 | scl=(adap->getscl==NULL?0:getscl(adap)); | 272 | scl=(adap->getscl==NULL?0:getscl(adap)); |
266 | printk(KERN_DEBUG "i2c-algo-bit.o: (3) scl=%d, sda=%d\n",scl,sda); | ||
267 | if ( 0 != scl ) { | 273 | if ( 0 != scl ) { |
268 | printk(KERN_WARNING "i2c-algo-bit.o: SCL stuck high!\n"); | 274 | printk(KERN_WARNING "%s: SCL stuck high!\n", name); |
269 | goto bailout; | 275 | goto bailout; |
270 | } | 276 | } |
271 | if ( 0 == sda ) { | 277 | if ( 0 == sda ) { |
272 | printk(KERN_WARNING "i2c-algo-bit.o: SDA unexpected low " | 278 | printk(KERN_WARNING "%s: SDA unexpected low " |
273 | "while pulling SCL low!\n"); | 279 | "while pulling SCL low!\n", name); |
274 | goto bailout; | 280 | goto bailout; |
275 | } | 281 | } |
276 | 282 | ||
277 | sclhi(adap); | 283 | sclhi(adap); |
278 | sda=getsda(adap); | 284 | sda=getsda(adap); |
279 | scl=(adap->getscl==NULL?1:getscl(adap)); | 285 | scl=(adap->getscl==NULL?1:getscl(adap)); |
280 | printk(KERN_DEBUG "i2c-algo-bit.o: (4) scl=%d, sda=%d\n",scl,sda); | ||
281 | if ( 0 == scl ) { | 286 | if ( 0 == scl ) { |
282 | printk(KERN_WARNING "i2c-algo-bit.o: SCL stuck low!\n"); | 287 | printk(KERN_WARNING "%s: SCL stuck low!\n", name); |
283 | goto bailout; | 288 | goto bailout; |
284 | } | 289 | } |
285 | if ( 0 == sda ) { | 290 | if ( 0 == sda ) { |
286 | printk(KERN_WARNING "i2c-algo-bit.o: SDA unexpected low " | 291 | printk(KERN_WARNING "%s: SDA unexpected low " |
287 | "while pulling SCL high!\n"); | 292 | "while pulling SCL high!\n", name); |
288 | goto bailout; | 293 | goto bailout; |
289 | } | 294 | } |
290 | printk(KERN_INFO "i2c-algo-bit.o: %s passed test.\n",name); | 295 | pr_info("%s: Test OK\n", name); |
291 | return 0; | 296 | return 0; |
292 | bailout: | 297 | bailout: |
293 | sdahi(adap); | 298 | sdahi(adap); |
@@ -312,44 +317,39 @@ static int try_address(struct i2c_adapter *i2c_adap, | |||
312 | int i,ret = -1; | 317 | int i,ret = -1; |
313 | for (i=0;i<=retries;i++) { | 318 | for (i=0;i<=retries;i++) { |
314 | ret = i2c_outb(i2c_adap,addr); | 319 | ret = i2c_outb(i2c_adap,addr); |
315 | if (ret==1) | 320 | if (ret == 1 || i == retries) |
316 | break; /* success! */ | ||
317 | i2c_stop(adap); | ||
318 | udelay(5/*adap->udelay*/); | ||
319 | if (i==retries) /* no success */ | ||
320 | break; | 321 | break; |
321 | i2c_start(adap); | 322 | bit_dbg(3, &i2c_adap->dev, "emitting stop condition\n"); |
323 | i2c_stop(adap); | ||
322 | udelay(adap->udelay); | 324 | udelay(adap->udelay); |
325 | yield(); | ||
326 | bit_dbg(3, &i2c_adap->dev, "emitting start condition\n"); | ||
327 | i2c_start(adap); | ||
323 | } | 328 | } |
324 | DEB2(if (i) | 329 | if (i && ret) |
325 | printk(KERN_DEBUG "i2c-algo-bit.o: Used %d tries to %s client at 0x%02x : %s\n", | 330 | bit_dbg(1, &i2c_adap->dev, "Used %d tries to %s client at " |
326 | i+1, addr & 1 ? "read" : "write", addr>>1, | 331 | "0x%02x: %s\n", i + 1, |
327 | ret==1 ? "success" : ret==0 ? "no ack" : "failed, timeout?" ) | 332 | addr & 1 ? "read from" : "write to", addr >> 1, |
328 | ); | 333 | ret == 1 ? "success" : "failed, timeout?"); |
329 | return ret; | 334 | return ret; |
330 | } | 335 | } |
331 | 336 | ||
332 | static int sendbytes(struct i2c_adapter *i2c_adap, struct i2c_msg *msg) | 337 | static int sendbytes(struct i2c_adapter *i2c_adap, struct i2c_msg *msg) |
333 | { | 338 | { |
334 | struct i2c_algo_bit_data *adap = i2c_adap->algo_data; | 339 | const unsigned char *temp = msg->buf; |
335 | char c; | ||
336 | const char *temp = msg->buf; | ||
337 | int count = msg->len; | 340 | int count = msg->len; |
338 | unsigned short nak_ok = msg->flags & I2C_M_IGNORE_NAK; | 341 | unsigned short nak_ok = msg->flags & I2C_M_IGNORE_NAK; |
339 | int retval; | 342 | int retval; |
340 | int wrcount=0; | 343 | int wrcount=0; |
341 | 344 | ||
342 | while (count > 0) { | 345 | while (count > 0) { |
343 | c = *temp; | 346 | retval = i2c_outb(i2c_adap, *temp); |
344 | DEB2(dev_dbg(&i2c_adap->dev, "sendbytes: writing %2.2X\n", c&0xff)); | ||
345 | retval = i2c_outb(i2c_adap,c); | ||
346 | if ((retval>0) || (nak_ok && (retval==0))) { /* ok or ignored NAK */ | 347 | if ((retval>0) || (nak_ok && (retval==0))) { /* ok or ignored NAK */ |
347 | count--; | 348 | count--; |
348 | temp++; | 349 | temp++; |
349 | wrcount++; | 350 | wrcount++; |
350 | } else { /* arbitration or no acknowledge */ | 351 | } else { /* arbitration or no acknowledge */ |
351 | dev_err(&i2c_adap->dev, "sendbytes: error - bailout.\n"); | 352 | dev_err(&i2c_adap->dev, "sendbytes: error - bailout.\n"); |
352 | i2c_stop(adap); | ||
353 | return (retval<0)? retval : -EFAULT; | 353 | return (retval<0)? retval : -EFAULT; |
354 | /* got a better one ?? */ | 354 | /* got a better one ?? */ |
355 | } | 355 | } |
@@ -362,7 +362,7 @@ static int readbytes(struct i2c_adapter *i2c_adap, struct i2c_msg *msg) | |||
362 | int inval; | 362 | int inval; |
363 | int rdcount=0; /* counts bytes read */ | 363 | int rdcount=0; /* counts bytes read */ |
364 | struct i2c_algo_bit_data *adap = i2c_adap->algo_data; | 364 | struct i2c_algo_bit_data *adap = i2c_adap->algo_data; |
365 | char *temp = msg->buf; | 365 | unsigned char *temp = msg->buf; |
366 | int count = msg->len; | 366 | int count = msg->len; |
367 | 367 | ||
368 | while (count > 0) { | 368 | while (count > 0) { |
@@ -371,30 +371,44 @@ static int readbytes(struct i2c_adapter *i2c_adap, struct i2c_msg *msg) | |||
371 | *temp = inval; | 371 | *temp = inval; |
372 | rdcount++; | 372 | rdcount++; |
373 | } else { /* read timed out */ | 373 | } else { /* read timed out */ |
374 | printk(KERN_ERR "i2c-algo-bit.o: readbytes: i2c_inb timed out.\n"); | ||
375 | break; | 374 | break; |
376 | } | 375 | } |
377 | 376 | ||
378 | temp++; | 377 | temp++; |
379 | count--; | 378 | count--; |
380 | 379 | ||
381 | if (msg->flags & I2C_M_NO_RD_ACK) | 380 | if (msg->flags & I2C_M_NO_RD_ACK) { |
381 | bit_dbg(2, &i2c_adap->dev, "i2c_inb: 0x%02x\n", | ||
382 | inval); | ||
382 | continue; | 383 | continue; |
383 | |||
384 | if ( count > 0 ) { /* send ack */ | ||
385 | sdalo(adap); | ||
386 | DEBPROTO(printk(" Am ")); | ||
387 | } else { | ||
388 | sdahi(adap); /* neg. ack on last byte */ | ||
389 | DEBPROTO(printk(" NAm ")); | ||
390 | } | 384 | } |
385 | |||
386 | /* assert: sda is high */ | ||
387 | if (count) /* send ack */ | ||
388 | setsda(adap, 0); | ||
389 | udelay((adap->udelay + 1) / 2); | ||
390 | bit_dbg(2, &i2c_adap->dev, "i2c_inb: 0x%02x %s\n", inval, | ||
391 | count ? "A" : "NA"); | ||
391 | if (sclhi(adap)<0) { /* timeout */ | 392 | if (sclhi(adap)<0) { /* timeout */ |
392 | sdahi(adap); | 393 | dev_err(&i2c_adap->dev, "readbytes: timeout at ack\n"); |
393 | printk(KERN_ERR "i2c-algo-bit.o: readbytes: Timeout at ack\n"); | ||
394 | return -ETIMEDOUT; | 394 | return -ETIMEDOUT; |
395 | }; | 395 | }; |
396 | scllo(adap); | 396 | scllo(adap); |
397 | sdahi(adap); | 397 | |
398 | /* Some SMBus transactions require that we receive the | ||
399 | transaction length as the first read byte. */ | ||
400 | if (rdcount == 1 && (msg->flags & I2C_M_RECV_LEN)) { | ||
401 | if (inval <= 0 || inval > I2C_SMBUS_BLOCK_MAX) { | ||
402 | dev_err(&i2c_adap->dev, "readbytes: invalid " | ||
403 | "block length (%d)\n", inval); | ||
404 | return -EREMOTEIO; | ||
405 | } | ||
406 | /* The original count value accounts for the extra | ||
407 | bytes, that is, either 1 for a regular transaction, | ||
408 | or 2 for a PEC transaction. */ | ||
409 | count += inval; | ||
410 | msg->len += inval; | ||
411 | } | ||
398 | } | 412 | } |
399 | return rdcount; | 413 | return rdcount; |
400 | } | 414 | } |
@@ -421,27 +435,31 @@ static int bit_doAddress(struct i2c_adapter *i2c_adap, struct i2c_msg *msg) | |||
421 | if ( (flags & I2C_M_TEN) ) { | 435 | if ( (flags & I2C_M_TEN) ) { |
422 | /* a ten bit address */ | 436 | /* a ten bit address */ |
423 | addr = 0xf0 | (( msg->addr >> 7) & 0x03); | 437 | addr = 0xf0 | (( msg->addr >> 7) & 0x03); |
424 | DEB2(printk(KERN_DEBUG "addr0: %d\n",addr)); | 438 | bit_dbg(2, &i2c_adap->dev, "addr0: %d\n", addr); |
425 | /* try extended address code...*/ | 439 | /* try extended address code...*/ |
426 | ret = try_address(i2c_adap, addr, retries); | 440 | ret = try_address(i2c_adap, addr, retries); |
427 | if ((ret != 1) && !nak_ok) { | 441 | if ((ret != 1) && !nak_ok) { |
428 | printk(KERN_ERR "died at extended address code.\n"); | 442 | dev_err(&i2c_adap->dev, |
443 | "died at extended address code\n"); | ||
429 | return -EREMOTEIO; | 444 | return -EREMOTEIO; |
430 | } | 445 | } |
431 | /* the remaining 8 bit address */ | 446 | /* the remaining 8 bit address */ |
432 | ret = i2c_outb(i2c_adap,msg->addr & 0x7f); | 447 | ret = i2c_outb(i2c_adap,msg->addr & 0x7f); |
433 | if ((ret != 1) && !nak_ok) { | 448 | if ((ret != 1) && !nak_ok) { |
434 | /* the chip did not ack / xmission error occurred */ | 449 | /* the chip did not ack / xmission error occurred */ |
435 | printk(KERN_ERR "died at 2nd address code.\n"); | 450 | dev_err(&i2c_adap->dev, "died at 2nd address code\n"); |
436 | return -EREMOTEIO; | 451 | return -EREMOTEIO; |
437 | } | 452 | } |
438 | if ( flags & I2C_M_RD ) { | 453 | if ( flags & I2C_M_RD ) { |
454 | bit_dbg(3, &i2c_adap->dev, "emitting repeated " | ||
455 | "start condition\n"); | ||
439 | i2c_repstart(adap); | 456 | i2c_repstart(adap); |
440 | /* okay, now switch into reading mode */ | 457 | /* okay, now switch into reading mode */ |
441 | addr |= 0x01; | 458 | addr |= 0x01; |
442 | ret = try_address(i2c_adap, addr, retries); | 459 | ret = try_address(i2c_adap, addr, retries); |
443 | if ((ret!=1) && !nak_ok) { | 460 | if ((ret!=1) && !nak_ok) { |
444 | printk(KERN_ERR "died at extended address code.\n"); | 461 | dev_err(&i2c_adap->dev, |
462 | "died at repeated address code\n"); | ||
445 | return -EREMOTEIO; | 463 | return -EREMOTEIO; |
446 | } | 464 | } |
447 | } | 465 | } |
@@ -468,44 +486,62 @@ static int bit_xfer(struct i2c_adapter *i2c_adap, | |||
468 | int i,ret; | 486 | int i,ret; |
469 | unsigned short nak_ok; | 487 | unsigned short nak_ok; |
470 | 488 | ||
489 | bit_dbg(3, &i2c_adap->dev, "emitting start condition\n"); | ||
471 | i2c_start(adap); | 490 | i2c_start(adap); |
472 | for (i=0;i<num;i++) { | 491 | for (i=0;i<num;i++) { |
473 | pmsg = &msgs[i]; | 492 | pmsg = &msgs[i]; |
474 | nak_ok = pmsg->flags & I2C_M_IGNORE_NAK; | 493 | nak_ok = pmsg->flags & I2C_M_IGNORE_NAK; |
475 | if (!(pmsg->flags & I2C_M_NOSTART)) { | 494 | if (!(pmsg->flags & I2C_M_NOSTART)) { |
476 | if (i) { | 495 | if (i) { |
496 | bit_dbg(3, &i2c_adap->dev, "emitting " | ||
497 | "repeated start condition\n"); | ||
477 | i2c_repstart(adap); | 498 | i2c_repstart(adap); |
478 | } | 499 | } |
479 | ret = bit_doAddress(i2c_adap, pmsg); | 500 | ret = bit_doAddress(i2c_adap, pmsg); |
480 | if ((ret != 0) && !nak_ok) { | 501 | if ((ret != 0) && !nak_ok) { |
481 | DEB2(printk(KERN_DEBUG "i2c-algo-bit.o: NAK from device addr %2.2x msg #%d\n" | 502 | bit_dbg(1, &i2c_adap->dev, "NAK from " |
482 | ,msgs[i].addr,i)); | 503 | "device addr 0x%02x msg #%d\n", |
483 | return (ret<0) ? ret : -EREMOTEIO; | 504 | msgs[i].addr, i); |
505 | goto bailout; | ||
484 | } | 506 | } |
485 | } | 507 | } |
486 | if (pmsg->flags & I2C_M_RD ) { | 508 | if (pmsg->flags & I2C_M_RD ) { |
487 | /* read bytes into buffer*/ | 509 | /* read bytes into buffer*/ |
488 | ret = readbytes(i2c_adap, pmsg); | 510 | ret = readbytes(i2c_adap, pmsg); |
489 | DEB2(printk(KERN_DEBUG "i2c-algo-bit.o: read %d bytes.\n",ret)); | 511 | if (ret >= 1) |
490 | if (ret < pmsg->len ) { | 512 | bit_dbg(2, &i2c_adap->dev, "read %d byte%s\n", |
491 | return (ret<0)? ret : -EREMOTEIO; | 513 | ret, ret == 1 ? "" : "s"); |
514 | if (ret < pmsg->len) { | ||
515 | if (ret >= 0) | ||
516 | ret = -EREMOTEIO; | ||
517 | goto bailout; | ||
492 | } | 518 | } |
493 | } else { | 519 | } else { |
494 | /* write bytes from buffer */ | 520 | /* write bytes from buffer */ |
495 | ret = sendbytes(i2c_adap, pmsg); | 521 | ret = sendbytes(i2c_adap, pmsg); |
496 | DEB2(printk(KERN_DEBUG "i2c-algo-bit.o: wrote %d bytes.\n",ret)); | 522 | if (ret >= 1) |
497 | if (ret < pmsg->len ) { | 523 | bit_dbg(2, &i2c_adap->dev, "wrote %d byte%s\n", |
498 | return (ret<0) ? ret : -EREMOTEIO; | 524 | ret, ret == 1 ? "" : "s"); |
525 | if (ret < pmsg->len) { | ||
526 | if (ret >= 0) | ||
527 | ret = -EREMOTEIO; | ||
528 | goto bailout; | ||
499 | } | 529 | } |
500 | } | 530 | } |
501 | } | 531 | } |
532 | ret = i; | ||
533 | |||
534 | bailout: | ||
535 | bit_dbg(3, &i2c_adap->dev, "emitting stop condition\n"); | ||
502 | i2c_stop(adap); | 536 | i2c_stop(adap); |
503 | return num; | 537 | return ret; |
504 | } | 538 | } |
505 | 539 | ||
506 | static u32 bit_func(struct i2c_adapter *adap) | 540 | static u32 bit_func(struct i2c_adapter *adap) |
507 | { | 541 | { |
508 | return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL | | 542 | return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL | |
543 | I2C_FUNC_SMBUS_READ_BLOCK_DATA | | ||
544 | I2C_FUNC_SMBUS_BLOCK_PROC_CALL | | ||
509 | I2C_FUNC_10BIT_ADDR | I2C_FUNC_PROTOCOL_MANGLING; | 545 | I2C_FUNC_10BIT_ADDR | I2C_FUNC_PROTOCOL_MANGLING; |
510 | } | 546 | } |
511 | 547 | ||
@@ -520,7 +556,7 @@ static const struct i2c_algorithm i2c_bit_algo = { | |||
520 | /* | 556 | /* |
521 | * registering functions to load algorithms at runtime | 557 | * registering functions to load algorithms at runtime |
522 | */ | 558 | */ |
523 | int i2c_bit_add_bus(struct i2c_adapter *adap) | 559 | static int i2c_bit_prepare_bus(struct i2c_adapter *adap) |
524 | { | 560 | { |
525 | struct i2c_algo_bit_data *bit_adap = adap->algo_data; | 561 | struct i2c_algo_bit_data *bit_adap = adap->algo_data; |
526 | 562 | ||
@@ -530,25 +566,39 @@ int i2c_bit_add_bus(struct i2c_adapter *adap) | |||
530 | return -ENODEV; | 566 | return -ENODEV; |
531 | } | 567 | } |
532 | 568 | ||
533 | DEB2(dev_dbg(&adap->dev, "hw routines registered.\n")); | ||
534 | |||
535 | /* register new adapter to i2c module... */ | 569 | /* register new adapter to i2c module... */ |
536 | adap->algo = &i2c_bit_algo; | 570 | adap->algo = &i2c_bit_algo; |
537 | 571 | ||
538 | adap->timeout = 100; /* default values, should */ | 572 | adap->timeout = 100; /* default values, should */ |
539 | adap->retries = 3; /* be replaced by defines */ | 573 | adap->retries = 3; /* be replaced by defines */ |
540 | 574 | ||
575 | return 0; | ||
576 | } | ||
577 | |||
578 | int i2c_bit_add_bus(struct i2c_adapter *adap) | ||
579 | { | ||
580 | int err; | ||
581 | |||
582 | err = i2c_bit_prepare_bus(adap); | ||
583 | if (err) | ||
584 | return err; | ||
585 | |||
541 | return i2c_add_adapter(adap); | 586 | return i2c_add_adapter(adap); |
542 | } | 587 | } |
543 | EXPORT_SYMBOL(i2c_bit_add_bus); | 588 | EXPORT_SYMBOL(i2c_bit_add_bus); |
544 | 589 | ||
590 | int i2c_bit_add_numbered_bus(struct i2c_adapter *adap) | ||
591 | { | ||
592 | int err; | ||
593 | |||
594 | err = i2c_bit_prepare_bus(adap); | ||
595 | if (err) | ||
596 | return err; | ||
597 | |||
598 | return i2c_add_numbered_adapter(adap); | ||
599 | } | ||
600 | EXPORT_SYMBOL(i2c_bit_add_numbered_bus); | ||
601 | |||
545 | MODULE_AUTHOR("Simon G. Vogl <simon@tk.uni-linz.ac.at>"); | 602 | MODULE_AUTHOR("Simon G. Vogl <simon@tk.uni-linz.ac.at>"); |
546 | MODULE_DESCRIPTION("I2C-Bus bit-banging algorithm"); | 603 | MODULE_DESCRIPTION("I2C-Bus bit-banging algorithm"); |
547 | MODULE_LICENSE("GPL"); | 604 | MODULE_LICENSE("GPL"); |
548 | |||
549 | module_param(bit_test, bool, 0); | ||
550 | module_param(i2c_debug, int, S_IRUGO | S_IWUSR); | ||
551 | |||
552 | MODULE_PARM_DESC(bit_test, "Test the lines of the bus to see if it is stuck"); | ||
553 | MODULE_PARM_DESC(i2c_debug, | ||
554 | "debug level - 0 off; 1 normal; 2,3 more verbose; 9 bit-protocol"); | ||