Updated from Linux LTS 3.10.21 to 3.10.22
This commit is contained in:
@@ -397,12 +397,13 @@ error:
|
||||
return ret;
|
||||
}
|
||||
|
||||
#define AF9015_EEPROM_SIZE 256
|
||||
|
||||
/* hash (and dump) eeprom */
|
||||
static int af9015_eeprom_hash(struct dvb_usb_device *d)
|
||||
{
|
||||
struct af9015_state *state = d_to_priv(d);
|
||||
int ret, i;
|
||||
static const unsigned int AF9015_EEPROM_SIZE = 256;
|
||||
u8 buf[AF9015_EEPROM_SIZE];
|
||||
struct req_t req = {READ_I2C, AF9015_I2C_EEPROM, 0, 0, 1, 1, NULL};
|
||||
|
||||
|
||||
@@ -21,6 +21,9 @@
|
||||
|
||||
#include "af9035.h"
|
||||
|
||||
/* Max transfer size done by I2C transfer functions */
|
||||
#define MAX_XFER_SIZE 64
|
||||
|
||||
DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
|
||||
|
||||
static u16 af9035_checksum(const u8 *buf, size_t len)
|
||||
@@ -125,10 +128,16 @@ exit:
|
||||
/* write multiple registers */
|
||||
static int af9035_wr_regs(struct dvb_usb_device *d, u32 reg, u8 *val, int len)
|
||||
{
|
||||
u8 wbuf[6 + len];
|
||||
u8 wbuf[MAX_XFER_SIZE];
|
||||
u8 mbox = (reg >> 16) & 0xff;
|
||||
struct usb_req req = { CMD_MEM_WR, mbox, sizeof(wbuf), wbuf, 0, NULL };
|
||||
|
||||
if (6 + len > sizeof(wbuf)) {
|
||||
dev_warn(&d->udev->dev, "%s: i2c wr: len=%d is too big!\n",
|
||||
KBUILD_MODNAME, len);
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
|
||||
wbuf[0] = len;
|
||||
wbuf[1] = 2;
|
||||
wbuf[2] = 0;
|
||||
@@ -227,9 +236,16 @@ static int af9035_i2c_master_xfer(struct i2c_adapter *adap,
|
||||
msg[1].len);
|
||||
} else {
|
||||
/* I2C */
|
||||
u8 buf[5 + msg[0].len];
|
||||
u8 buf[MAX_XFER_SIZE];
|
||||
struct usb_req req = { CMD_I2C_RD, 0, sizeof(buf),
|
||||
buf, msg[1].len, msg[1].buf };
|
||||
|
||||
if (5 + msg[0].len > sizeof(buf)) {
|
||||
dev_warn(&d->udev->dev,
|
||||
"%s: i2c xfer: len=%d is too big!\n",
|
||||
KBUILD_MODNAME, msg[0].len);
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
req.mbox |= ((msg[0].addr & 0x80) >> 3);
|
||||
buf[0] = msg[1].len;
|
||||
buf[1] = msg[0].addr << 1;
|
||||
@@ -256,9 +272,16 @@ static int af9035_i2c_master_xfer(struct i2c_adapter *adap,
|
||||
msg[0].len - 3);
|
||||
} else {
|
||||
/* I2C */
|
||||
u8 buf[5 + msg[0].len];
|
||||
u8 buf[MAX_XFER_SIZE];
|
||||
struct usb_req req = { CMD_I2C_WR, 0, sizeof(buf), buf,
|
||||
0, NULL };
|
||||
|
||||
if (5 + msg[0].len > sizeof(buf)) {
|
||||
dev_warn(&d->udev->dev,
|
||||
"%s: i2c xfer: len=%d is too big!\n",
|
||||
KBUILD_MODNAME, msg[0].len);
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
req.mbox |= ((msg[0].addr & 0x80) >> 3);
|
||||
buf[0] = msg[0].len;
|
||||
buf[1] = msg[0].addr << 1;
|
||||
|
||||
@@ -23,6 +23,9 @@
|
||||
#include "lgdt3305.h"
|
||||
#include "lg2160.h"
|
||||
|
||||
/* Max transfer size done by I2C transfer functions */
|
||||
#define MAX_XFER_SIZE 64
|
||||
|
||||
int dvb_usb_mxl111sf_debug;
|
||||
module_param_named(debug, dvb_usb_mxl111sf_debug, int, 0644);
|
||||
MODULE_PARM_DESC(debug, "set debugging level "
|
||||
@@ -63,7 +66,12 @@ int mxl111sf_ctrl_msg(struct dvb_usb_device *d,
|
||||
{
|
||||
int wo = (rbuf == NULL || rlen == 0); /* write-only */
|
||||
int ret;
|
||||
u8 sndbuf[1+wlen];
|
||||
u8 sndbuf[MAX_XFER_SIZE];
|
||||
|
||||
if (1 + wlen > sizeof(sndbuf)) {
|
||||
pr_warn("%s: len=%d is too big!\n", __func__, wlen);
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
|
||||
deb_adv("%s(wlen = %d, rlen = %d)\n", __func__, wlen, rlen);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user