diff options
author | Wolfram Sang <wsa@the-dreams.de> | 2015-01-07 06:24:10 -0500 |
---|---|---|
committer | Wolfram Sang <wsa@the-dreams.de> | 2015-03-13 10:10:54 -0400 |
commit | b94c820f37804a461376205b4919eef300ff3abe (patch) | |
tree | 68d29fbf9cae1ef102f02b1ad73dbf2f12dfe05f | |
parent | 994647db6bb2284de7dfee10a51b4d9fec760ed3 (diff) |
i2c: cpm: make use of the new infrastructure for quirks
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
-rw-r--r-- | drivers/i2c/busses/i2c-cpm.c | 20 |
1 files changed, 9 insertions, 11 deletions
diff --git a/drivers/i2c/busses/i2c-cpm.c b/drivers/i2c/busses/i2c-cpm.c index 2d466538b2e2..714bdc837769 100644 --- a/drivers/i2c/busses/i2c-cpm.c +++ b/drivers/i2c/busses/i2c-cpm.c | |||
@@ -308,22 +308,12 @@ static int cpm_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg *msgs, int num) | |||
308 | struct i2c_reg __iomem *i2c_reg = cpm->i2c_reg; | 308 | struct i2c_reg __iomem *i2c_reg = cpm->i2c_reg; |
309 | struct i2c_ram __iomem *i2c_ram = cpm->i2c_ram; | 309 | struct i2c_ram __iomem *i2c_ram = cpm->i2c_ram; |
310 | struct i2c_msg *pmsg; | 310 | struct i2c_msg *pmsg; |
311 | int ret, i; | 311 | int ret; |
312 | int tptr; | 312 | int tptr; |
313 | int rptr; | 313 | int rptr; |
314 | cbd_t __iomem *tbdf; | 314 | cbd_t __iomem *tbdf; |
315 | cbd_t __iomem *rbdf; | 315 | cbd_t __iomem *rbdf; |
316 | 316 | ||
317 | if (num > CPM_MAXBD) | ||
318 | return -EINVAL; | ||
319 | |||
320 | /* Check if we have any oversized READ requests */ | ||
321 | for (i = 0; i < num; i++) { | ||
322 | pmsg = &msgs[i]; | ||
323 | if (pmsg->len >= CPM_MAX_READ) | ||
324 | return -EINVAL; | ||
325 | } | ||
326 | |||
327 | /* Reset to use first buffer */ | 317 | /* Reset to use first buffer */ |
328 | out_be16(&i2c_ram->rbptr, in_be16(&i2c_ram->rbase)); | 318 | out_be16(&i2c_ram->rbptr, in_be16(&i2c_ram->rbase)); |
329 | out_be16(&i2c_ram->tbptr, in_be16(&i2c_ram->tbase)); | 319 | out_be16(&i2c_ram->tbptr, in_be16(&i2c_ram->tbase)); |
@@ -424,10 +414,18 @@ static const struct i2c_algorithm cpm_i2c_algo = { | |||
424 | .functionality = cpm_i2c_func, | 414 | .functionality = cpm_i2c_func, |
425 | }; | 415 | }; |
426 | 416 | ||
417 | /* CPM_MAX_READ is also limiting writes according to the code! */ | ||
418 | static struct i2c_adapter_quirks cpm_i2c_quirks = { | ||
419 | .max_num_msgs = CPM_MAXBD, | ||
420 | .max_read_len = CPM_MAX_READ, | ||
421 | .max_write_len = CPM_MAX_READ, | ||
422 | }; | ||
423 | |||
427 | static const struct i2c_adapter cpm_ops = { | 424 | static const struct i2c_adapter cpm_ops = { |
428 | .owner = THIS_MODULE, | 425 | .owner = THIS_MODULE, |
429 | .name = "i2c-cpm", | 426 | .name = "i2c-cpm", |
430 | .algo = &cpm_i2c_algo, | 427 | .algo = &cpm_i2c_algo, |
428 | .quirks = &cpm_i2c_quirks, | ||
431 | }; | 429 | }; |
432 | 430 | ||
433 | static int cpm_i2c_setup(struct cpm_i2c *cpm) | 431 | static int cpm_i2c_setup(struct cpm_i2c *cpm) |