Commit 30093e8b authored by Jean Delvare's avatar Jean Delvare Committed by Mauro Carvalho Chehab

V4L/DVB (13235): saa7134: Complete the IR address list

Google is pretty clear that the HVR 1110 IR chip is always at address
0x71 and the BeholdTV IR chip is always at address 0x2d. This
completes the list of IR device addresses for the SAA7134-based
adapters, and we no longer need to probe any of them.
Signed-off-by: default avatarJean Delvare <khali@linux-fr.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent aef02aa1
...@@ -696,10 +696,6 @@ void saa7134_input_fini(struct saa7134_dev *dev) ...@@ -696,10 +696,6 @@ void saa7134_input_fini(struct saa7134_dev *dev)
void saa7134_probe_i2c_ir(struct saa7134_dev *dev) void saa7134_probe_i2c_ir(struct saa7134_dev *dev)
{ {
struct i2c_board_info info; struct i2c_board_info info;
const unsigned short addr_list[] = {
0x47, 0x71, 0x2d,
I2C_CLIENT_END
};
struct i2c_msg msg_msi = { struct i2c_msg msg_msi = {
.addr = 0x50, .addr = 0x50,
...@@ -757,6 +753,7 @@ void saa7134_probe_i2c_ir(struct saa7134_dev *dev) ...@@ -757,6 +753,7 @@ void saa7134_probe_i2c_ir(struct saa7134_dev *dev)
dev->init_data.name = "HVR 1110"; dev->init_data.name = "HVR 1110";
dev->init_data.get_key = get_key_hvr1110; dev->init_data.get_key = get_key_hvr1110;
dev->init_data.ir_codes = &ir_codes_hauppauge_new_table; dev->init_data.ir_codes = &ir_codes_hauppauge_new_table;
info.addr = 0x71;
break; break;
case SAA7134_BOARD_BEHOLD_607FM_MK3: case SAA7134_BOARD_BEHOLD_607FM_MK3:
case SAA7134_BOARD_BEHOLD_607FM_MK5: case SAA7134_BOARD_BEHOLD_607FM_MK5:
...@@ -774,23 +771,20 @@ void saa7134_probe_i2c_ir(struct saa7134_dev *dev) ...@@ -774,23 +771,20 @@ void saa7134_probe_i2c_ir(struct saa7134_dev *dev)
dev->init_data.name = "BeholdTV"; dev->init_data.name = "BeholdTV";
dev->init_data.get_key = get_key_beholdm6xx; dev->init_data.get_key = get_key_beholdm6xx;
dev->init_data.ir_codes = &ir_codes_behold_table; dev->init_data.ir_codes = &ir_codes_behold_table;
info.addr = 0x2d;
break; break;
case SAA7134_BOARD_AVERMEDIA_CARDBUS_501: case SAA7134_BOARD_AVERMEDIA_CARDBUS_501:
case SAA7134_BOARD_AVERMEDIA_CARDBUS_506: case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
info.addr = 0x40; info.addr = 0x40;
break; break;
default:
dprintk("No I2C IR support for board %x\n", dev->board);
return;
} }
if (dev->init_data.name) if (dev->init_data.name)
info.platform_data = &dev->init_data; info.platform_data = &dev->init_data;
/* No need to probe if address is known */
if (info.addr) {
i2c_new_device(&dev->i2c_adap, &info); i2c_new_device(&dev->i2c_adap, &info);
return;
}
/* Address not known, fallback to probing */
i2c_new_probed_device(&dev->i2c_adap, &info, addr_list);
} }
static int saa7134_rc5_irq(struct saa7134_dev *dev) static int saa7134_rc5_irq(struct saa7134_dev *dev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment