summaryrefslogtreecommitdiff
path: root/linux/drivers
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@redhat.com>2007-11-24 17:34:42 +1000
committerMauro Carvalho Chehab <mchehab@redhat.com>2007-11-24 17:34:42 +1000
commita6f7c54705eda8223fdf1c7b2a519a3183188120 (patch)
tree54d118891bccecea54e2393d7153af1b5a6fbcf5 /linux/drivers
parent8f4e70f7624babdb4b36e9377307647177c04008 (diff)
downloadmediapointer-dvb-s2-a6f7c54705eda8223fdf1c7b2a519a3183188120.tar.gz
mediapointer-dvb-s2-a6f7c54705eda8223fdf1c7b2a519a3183188120.tar.bz2
tm6000: update USB request names and clean up i2c routine
From: Chris Pascoe <c.pascoe@itee.uq.edu.au> Update the descriptions of the USB request types so that they match what we now know they do. Rework the i2c_xfer function so that it is more explicit what sort of I2C transfers it is that the tm6000 can't perform. Signed-off-by: Chris Pascoe <c.pascoe@itee.uq.edu.au> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'linux/drivers')
-rw-r--r--linux/drivers/staging/tm6000/tm6000-i2c.c100
-rw-r--r--linux/drivers/staging/tm6000/tm6000-regs.h4
2 files changed, 39 insertions, 65 deletions
diff --git a/linux/drivers/staging/tm6000/tm6000-i2c.c b/linux/drivers/staging/tm6000/tm6000-i2c.c
index d1ae9ffa0..ccf22ab45 100644
--- a/linux/drivers/staging/tm6000/tm6000-i2c.c
+++ b/linux/drivers/staging/tm6000/tm6000-i2c.c
@@ -74,7 +74,7 @@ static int tm6000_i2c_scan(struct i2c_adapter *i2c_adap, int addr)
/* This sends addr + 1 byte with 0 */
rc = tm6000_read_write_usb (dev,
USB_DIR_IN | USB_TYPE_VENDOR,
- REQ_16_SET_GET_I2CSEQ,
+ REQ_16_SET_GET_I2C_WR1_RDN,
addr, 0,
buf, 0);
msleep(10);
@@ -95,86 +95,61 @@ static int tm6000_i2c_xfer(struct i2c_adapter *i2c_adap,
{
struct tm6000_core *dev = i2c_adap->algo_data;
int addr, rc, i, byte;
- int prev_reg = -1;
if (num <= 0)
return 0;
for (i = 0; i < num; i++) {
- addr = (msgs[i].addr << 1) &0xff;
+ addr = (msgs[i].addr << 1) & 0xff;
i2c_dprintk(2,"%s %s addr=0x%x len=%d:",
(msgs[i].flags & I2C_M_RD) ? "read" : "write",
i == num - 1 ? "stop" : "nonstop", addr, msgs[i].len);
if (!msgs[i].len) {
/* Do I2C scan */
- rc=tm6000_i2c_scan(i2c_adap, addr);
+ rc = tm6000_i2c_scan(i2c_adap, addr);
} else if (msgs[i].flags & I2C_M_RD) {
- /* Read bytes */
- /* I2C is assumed to have always a subaddr at the first byte of the
- message bus. Also, the first i2c value of the answer is returned
- out of message data.
- */
- /* SMBus Read Byte command */
- if (prev_reg < 0)
- printk("XXX read from unknown prev_reg\n");
- rc = tm6000_read_write_usb (dev,
- USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
- REQ_16_SET_GET_I2CSEQ,
- addr | (prev_reg << 8), 0,
- msgs[i].buf, msgs[i].len);
- if (prev_reg >= 0)
- prev_reg += msgs[i].len;
-#if 0
- if (rc>=0)
- *msgs[i].buf=rc;
-#endif
- if (i2c_debug>=2) {
- for (byte = 0; byte < msgs[i].len; byte++) {
+ /* read request without preceding register selection */
+ /*
+ * The TM6000 only supports a read transaction
+ * immediately after a 1 or 2 byte write to select
+ * a register. We cannot fulfil this request.
+ */
+ i2c_dprintk(2, " read without preceding write not"
+ " supported");
+ rc = -EOPNOTSUPP;
+ goto err;
+ } else if (i + 1 < num && msgs[i].len <= 2 &&
+ (msgs[i + 1].flags & I2C_M_RD) &&
+ msgs[i].addr == msgs[i + 1].addr) {
+ /* 1 or 2 byte write followed by a read */
+ if (i2c_debug >= 2)
+ for (byte = 0; byte < msgs[i].len; byte++)
printk(" %02x", msgs[i].buf[byte]);
- }
- }
- } else if (i+1 < num && msgs[i].len == 2 &&
- (msgs[i+1].flags & I2C_M_RD) &&
- msgs[i].addr == msgs[i+1].addr) {
- i2c_dprintk(2, "msg %d: write 2, read %d", i,
- msgs[i+1].len);
- /* Write 2 Read N command */
+ i2c_dprintk(2, "; joined to read %s len=%d:",
+ i == num - 2 ? "stop" : "nonstop",
+ msgs[i + 1].len);
rc = tm6000_read_write_usb (dev,
USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
- REQ_14_SET_GET_EEPROM_PAGE, /* XXX wrong name */
- addr | msgs[i].buf[0] << 8, msgs[i].buf[1],
- msgs[i+1].buf, msgs[i+1].len);
+ msgs[i].len == 1 ? REQ_16_SET_GET_I2C_WR1_RDN
+ : REQ_14_SET_GET_I2C_WR2_RDN,
+ addr | msgs[i].buf[0] << 8,
+ msgs[i].len == 1 ? 0 : msgs[i].buf[1],
+ msgs[i + 1].buf, msgs[i + 1].len);
i++;
- if (i2c_debug>=2) {
- for (byte = 0; byte < msgs[i].len; byte++) {
+ if (i2c_debug >= 2)
+ for (byte = 0; byte < msgs[i].len; byte++)
printk(" %02x", msgs[i].buf[byte]);
- }
- }
- prev_reg = -1;
} else {
/* write bytes */
- if (i2c_debug>=2) {
+ if (i2c_debug >= 2)
for (byte = 0; byte < msgs[i].len; byte++)
printk(" %02x", msgs[i].buf[byte]);
- }
-
- /* SMBus Write Byte command followed by a read command */
- if(msgs[i].len == 1 && i+1 < num && msgs[i+1].flags & I2C_M_RD
- && msgs[i+1].addr == msgs[i].addr) {
- prev_reg = msgs[i].buf[0];
- if (i2c_debug >= 2)
- printk("\n");
- continue;
- }
-
- rc = tm6000_read_write_usb (dev,
+ rc = tm6000_read_write_usb(dev,
USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
- REQ_16_SET_GET_I2CSEQ,
- addr|(*msgs[i].buf)<<8, 0,
- msgs[i].buf+1, msgs[i].len-1);
-
- prev_reg = -1;
+ REQ_16_SET_GET_I2C_WR1_RDN,
+ addr | msgs[i].buf[0] << 8, 0,
+ msgs[i].buf + 1, msgs[i].len - 1);
}
- if (i2c_debug>=2)
+ if (i2c_debug >= 2)
printk("\n");
if (rc < 0)
goto err;
@@ -186,7 +161,6 @@ err:
return rc;
}
-
static int tm6000_i2c_eeprom(struct tm6000_core *dev,
unsigned char *eedata, int len)
{
@@ -204,7 +178,7 @@ static int tm6000_i2c_eeprom(struct tm6000_core *dev,
*p = i;
rc = tm6000_read_write_usb (dev,
USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
- REQ_16_SET_GET_I2CSEQ, 0xa0 | i<<8, 0, p, 1);
+ REQ_16_SET_GET_I2C_WR1_RDN, 0xa0 | i<<8, 0, p, 1);
#endif
if (rc < 1) {
if (p == eedata)
@@ -282,7 +256,7 @@ static void dec_use(struct i2c_adapter *adap)
#define mass_write(addr, reg, data...) \
{ const static u8 _val[] = data; \
rc=tm6000_read_write_usb(dev,USB_DIR_OUT | USB_TYPE_VENDOR, \
- REQ_16_SET_GET_I2CSEQ,(reg<<8)+addr, 0x00, (u8 *) _val, \
+ REQ_16_SET_GET_I2C_WR1_RDN,(reg<<8)+addr, 0x00, (u8 *) _val, \
ARRAY_SIZE(_val)); \
if (rc<0) { \
printk(KERN_ERR "Error on line %d: %d\n",__LINE__,rc); \
diff --git a/linux/drivers/staging/tm6000/tm6000-regs.h b/linux/drivers/staging/tm6000/tm6000-regs.h
index 414852e69..9b6456e18 100644
--- a/linux/drivers/staging/tm6000/tm6000-regs.h
+++ b/linux/drivers/staging/tm6000/tm6000-regs.h
@@ -38,11 +38,11 @@
#define REQ_11_SET_EEPROM_ADDR 11
#define REQ_12_SET_GET_EEPROMBYTE 12
#define REQ_13_GET_EEPROM_SEQREAD 13
-#define REQ_14_SET_GET_EEPROM_PAGE 14
+#define REQ_14_SET_GET_I2C_WR2_RDN 14
#define REQ_15_SET_GET_I2CBYTE 15
/* Write: Subaddr, Slave Addr, value, 0 */
/* Read : Subaddr, Slave Addr, value, 1 */
-#define REQ_16_SET_GET_I2CSEQ 16
+#define REQ_16_SET_GET_I2C_WR1_RDN 16
/* Subaddr, Slave Addr, 0, length */
#define REQ_17_SET_GET_I2CFP 17
/* Write: Slave Addr, register, value */