diff options
author | Sean Young <sean@mess.org> | 2012-08-13 07:59:40 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2012-08-13 15:05:57 -0400 |
commit | 0797b4802b57ce88e9361c8d64b0980508370649 (patch) | |
tree | 095b41fa36a42b7b330139e9ab46b3fe663bcdc8 | |
parent | e99a7cfe93fd9b853d80e7dda8b86ecca71c22bb (diff) |
[media] iguanair: ignore unsupported firmware versions
Firmware versions lower than 0x0205 use a different interface which is not
supported. Also report the firmware version in the standard format.
Signed-off-by: Sean Young <sean@mess.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r-- | drivers/media/rc/Kconfig | 8 | ||||
-rw-r--r-- | drivers/media/rc/iguanair.c | 21 |
2 files changed, 17 insertions, 12 deletions
diff --git a/drivers/media/rc/Kconfig b/drivers/media/rc/Kconfig index 5180390be7a..2e91e664d02 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 bdd526df0b7..58854004db8 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 | ||