aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/media/rc/Kconfig8
-rw-r--r--drivers/media/rc/iguanair.c21
2 files changed, 17 insertions, 12 deletions
diff --git a/drivers/media/rc/Kconfig b/drivers/media/rc/Kconfig
index 5180390be7ab..2e91e664d024 100644
--- a/drivers/media/rc/Kconfig
+++ b/drivers/media/rc/Kconfig
@@ -264,8 +264,12 @@ config IR_IGUANA
264 depends on RC_CORE 264 depends on RC_CORE
265 select USB 265 select USB
266 ---help--- 266 ---help---
267 Say Y here if you want to use the IgaunaWorks USB IR Transceiver. 267 Say Y here if you want to use the IguanaWorks USB IR Transceiver.
268 Both infrared receive and send are supported. 268 Both infrared receive and send are supported. If you want to
269 change the ID or the pin config, use the user space driver from
270 IguanaWorks.
271
272 Only firmware 0x0205 and later is supported.
269 273
270 To compile this driver as a module, choose M here: the module will 274 To compile this driver as a module, choose M here: the module will
271 be called iguanair. 275 be called iguanair.
diff --git a/drivers/media/rc/iguanair.c b/drivers/media/rc/iguanair.c
index bdd526df0b74..58854004db88 100644
--- a/drivers/media/rc/iguanair.c
+++ b/drivers/media/rc/iguanair.c
@@ -36,8 +36,8 @@ struct iguanair {
36 struct usb_device *udev; 36 struct usb_device *udev;
37 37
38 int pipe_out; 38 int pipe_out;
39 uint16_t version;
39 uint8_t bufsize; 40 uint8_t bufsize;
40 uint8_t version[2];
41 41
42 struct mutex lock; 42 struct mutex lock;
43 43
@@ -97,8 +97,8 @@ static void process_ir_data(struct iguanair *ir, unsigned len)
97 switch (ir->buf_in[3]) { 97 switch (ir->buf_in[3]) {
98 case CMD_GET_VERSION: 98 case CMD_GET_VERSION:
99 if (len == 6) { 99 if (len == 6) {
100 ir->version[0] = ir->buf_in[4]; 100 ir->version = (ir->buf_in[5] << 8) |
101 ir->version[1] = ir->buf_in[5]; 101 ir->buf_in[4];
102 complete(&ir->completion); 102 complete(&ir->completion);
103 } 103 }
104 break; 104 break;
@@ -110,8 +110,7 @@ static void process_ir_data(struct iguanair *ir, unsigned len)
110 break; 110 break;
111 case CMD_GET_FEATURES: 111 case CMD_GET_FEATURES:
112 if (len > 5) { 112 if (len > 5) {
113 if (ir->version[0] >= 4) 113 ir->cycle_overhead = ir->buf_in[5];
114 ir->cycle_overhead = ir->buf_in[5];
115 complete(&ir->completion); 114 complete(&ir->completion);
116 } 115 }
117 break; 116 break;
@@ -219,6 +218,12 @@ static int iguanair_get_features(struct iguanair *ir)
219 goto out; 218 goto out;
220 } 219 }
221 220
221 if (ir->version < 0x205) {
222 dev_err(ir->dev, "firmware 0x%04x is too old\n", ir->version);
223 rc = -ENODEV;
224 goto out;
225 }
226
222 ir->bufsize = 150; 227 ir->bufsize = 150;
223 ir->cycle_overhead = 65; 228 ir->cycle_overhead = 65;
224 229
@@ -230,9 +235,6 @@ static int iguanair_get_features(struct iguanair *ir)
230 goto out; 235 goto out;
231 } 236 }
232 237
233 if (ir->version[0] == 0 || ir->version[1] == 0)
234 goto out;
235
236 packet.cmd = CMD_GET_FEATURES; 238 packet.cmd = CMD_GET_FEATURES;
237 239
238 rc = iguanair_send(ir, &packet, sizeof(packet)); 240 rc = iguanair_send(ir, &packet, sizeof(packet));
@@ -485,8 +487,7 @@ static int __devinit iguanair_probe(struct usb_interface *intf,
485 goto out2; 487 goto out2;
486 488
487 snprintf(ir->name, sizeof(ir->name), 489 snprintf(ir->name, sizeof(ir->name),
488 "IguanaWorks USB IR Transceiver version %d.%d", 490 "IguanaWorks USB IR Transceiver version 0x%04x", ir->version);
489 ir->version[0], ir->version[1]);
490 491
491 usb_make_path(ir->udev, ir->phys, sizeof(ir->phys)); 492 usb_make_path(ir->udev, ir->phys, sizeof(ir->phys));
492 493