Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0797b480 authored by Sean Young's avatar Sean Young Committed by Mauro Carvalho Chehab
Browse files

[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: default avatarSean Young <sean@mess.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent e99a7cfe
Loading
Loading
Loading
Loading
+6 −2
Original line number Diff line number Diff line
@@ -264,8 +264,12 @@ config IR_IGUANA
	depends on RC_CORE
	select USB
	---help---
	   Say Y here if you want to use the IgaunaWorks USB IR Transceiver.
	   Both infrared receive and send are supported.
	   Say Y here if you want to use the IguanaWorks USB IR Transceiver.
	   Both infrared receive and send are supported. If you want to
	   change the ID or the pin config, use the user space driver from
	   IguanaWorks.

	   Only firmware 0x0205 and later is supported.

	   To compile this driver as a module, choose M here: the module will
	   be called iguanair.
+11 −10
Original line number Diff line number Diff line
@@ -36,8 +36,8 @@ struct iguanair {
	struct usb_device *udev;

	int pipe_out;
	uint16_t version;
	uint8_t bufsize;
	uint8_t version[2];

	struct mutex lock;

@@ -97,8 +97,8 @@ static void process_ir_data(struct iguanair *ir, unsigned len)
		switch (ir->buf_in[3]) {
		case CMD_GET_VERSION:
			if (len == 6) {
				ir->version[0] = ir->buf_in[4];
				ir->version[1] = ir->buf_in[5];
				ir->version = (ir->buf_in[5] << 8) |
							ir->buf_in[4];
				complete(&ir->completion);
			}
			break;
@@ -110,7 +110,6 @@ static void process_ir_data(struct iguanair *ir, unsigned len)
			break;
		case CMD_GET_FEATURES:
			if (len > 5) {
				if (ir->version[0] >= 4)
				ir->cycle_overhead = ir->buf_in[5];
				complete(&ir->completion);
			}
@@ -219,6 +218,12 @@ static int iguanair_get_features(struct iguanair *ir)
		goto out;
	}

	if (ir->version < 0x205) {
		dev_err(ir->dev, "firmware 0x%04x is too old\n", ir->version);
		rc = -ENODEV;
		goto out;
	}

	ir->bufsize = 150;
	ir->cycle_overhead = 65;

@@ -230,9 +235,6 @@ static int iguanair_get_features(struct iguanair *ir)
		goto out;
	}

	if (ir->version[0] == 0 || ir->version[1] == 0)
		goto out;

	packet.cmd = CMD_GET_FEATURES;

	rc = iguanair_send(ir, &packet, sizeof(packet));
@@ -485,8 +487,7 @@ static int __devinit iguanair_probe(struct usb_interface *intf,
		goto out2;

	snprintf(ir->name, sizeof(ir->name),
		"IguanaWorks USB IR Transceiver version %d.%d",
		ir->version[0], ir->version[1]);
		"IguanaWorks USB IR Transceiver version 0x%04x", ir->version);

	usb_make_path(ir->udev, ir->phys, sizeof(ir->phys));