linux-i2c.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] i2c-dev: relax ban on I2C_M_RECV_LEN
@ 2012-02-04 21:42 Douglas Gilbert
       [not found] ` <4F2DA645.3080604-qazKcTl6WRFWk0Htik3J/w@public.gmane.org>
  0 siblings, 1 reply; 5+ messages in thread
From: Douglas Gilbert @ 2012-02-04 21:42 UTC (permalink / raw)
  To: linux-i2c-u79uwXL29TY76Z2rM5mHXA

[-- Attachment #1: Type: text/plain, Size: 531 bytes --]

The I2C_M_RECV_LEN flag indicates that the length of
an I2C response is in the first byte read. So the maximum
size of the read buffer using this option is 256 bytes.

Currently the i2c-dev driver returns EINVAL when an
attempt is made to use ioctl(I2C_RDWR) with the
I2C_M_RECV_LEN flag set. That is overly paranoid:

ChangeLog:
   - allow I2C_M_RECV_LEN flag in the i2c-dev driver as
     long as the associated buffer length can cope with
     the worst case size (which is 256 bytes).

Doug Gilbert
[Please cc responses to me]

[-- Attachment #2: i2c-dev_mrecv_len1.patch --]
[-- Type: text/x-patch, Size: 634 bytes --]

diff --git a/drivers/i2c/i2c-dev.c b/drivers/i2c/i2c-dev.c
index 57a45ce8..b8f226a0 100644
--- a/drivers/i2c/i2c-dev.c
+++ b/drivers/i2c/i2c-dev.c
@@ -270,9 +270,10 @@ static noinline int i2cdev_ioctl_rdrw(struct i2c_client *client,
 	res = 0;
 	for (i = 0; i < rdwr_arg.nmsgs; i++) {
 		/* Limit the size of the message to a sane amount;
-		 * and don't let length change either. */
+		 * with I2C_M_RECV_LEN require worst case len. */
 		if ((rdwr_pa[i].len > 8192) ||
-		    (rdwr_pa[i].flags & I2C_M_RECV_LEN)) {
+		    ((rdwr_pa[i].flags & I2C_M_RECV_LEN) &&
+		     (rdwr_pa[i].len < 256))) {
 			res = -EINVAL;
 			break;
 		}

^ permalink raw reply related	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2012-02-21  8:19 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-02-04 21:42 [PATCH] i2c-dev: relax ban on I2C_M_RECV_LEN Douglas Gilbert
     [not found] ` <4F2DA645.3080604-qazKcTl6WRFWk0Htik3J/w@public.gmane.org>
2012-02-20 15:29   ` Jean Delvare
     [not found]     ` <20120220162939.5ce96d52-R0o5gVi9kd7kN2dkZ6Wm7A@public.gmane.org>
2012-02-21  3:45       ` Douglas Gilbert
     [not found]         ` <4F43133F.5040906-qazKcTl6WRFWk0Htik3J/w@public.gmane.org>
2012-02-21  7:31           ` Jean Delvare
     [not found]             ` <20120221083126.3bda01f3-R0o5gVi9kd7kN2dkZ6Wm7A@public.gmane.org>
2012-02-21  8:19               ` Jean Delvare

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).