diff options
Diffstat (limited to 'drivers/media/usb/dvb-usb/cxusb.c')
| -rw-r--r-- | drivers/media/usb/dvb-usb/cxusb.c | 27 | 
1 files changed, 14 insertions, 13 deletions
| diff --git a/drivers/media/usb/dvb-usb/cxusb.c b/drivers/media/usb/dvb-usb/cxusb.c index 907ac01ae297..243403081fa5 100644 --- a/drivers/media/usb/dvb-usb/cxusb.c +++ b/drivers/media/usb/dvb-usb/cxusb.c @@ -45,9 +45,6 @@  #include "si2168.h"  #include "si2157.h" -/* Max transfer size done by I2C transfer functions */ -#define MAX_XFER_SIZE  80 -  /* debug */  static int dvb_usb_cxusb_debug;  module_param_named(debug, dvb_usb_cxusb_debug, int, 0644); @@ -61,23 +58,27 @@ DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);  static int cxusb_ctrl_msg(struct dvb_usb_device *d,  			  u8 cmd, u8 *wbuf, int wlen, u8 *rbuf, int rlen)  { -	int wo = (rbuf == NULL || rlen == 0); /* write-only */ -	u8 sndbuf[MAX_XFER_SIZE]; +	struct cxusb_state *st = d->priv; +	int ret, wo; -	if (1 + wlen > sizeof(sndbuf)) { -		warn("i2c wr: len=%d is too big!\n", -		     wlen); +	if (1 + wlen > MAX_XFER_SIZE) { +		warn("i2c wr: len=%d is too big!\n", wlen);  		return -EOPNOTSUPP;  	} -	memset(sndbuf, 0, 1+wlen); +	wo = (rbuf == NULL || rlen == 0); /* write-only */ -	sndbuf[0] = cmd; -	memcpy(&sndbuf[1], wbuf, wlen); +	mutex_lock(&d->data_mutex); +	st->data[0] = cmd; +	memcpy(&st->data[1], wbuf, wlen);  	if (wo) -		return dvb_usb_generic_write(d, sndbuf, 1+wlen); +		ret = dvb_usb_generic_write(d, st->data, 1 + wlen);  	else -		return dvb_usb_generic_rw(d, sndbuf, 1+wlen, rbuf, rlen, 0); +		ret = dvb_usb_generic_rw(d, st->data, 1 + wlen, +					 rbuf, rlen, 0); + +	mutex_unlock(&d->data_mutex); +	return ret;  }  /* GPIO */ |