aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/em28xx
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/video/em28xx')
-rw-r--r--drivers/media/video/em28xx/em28xx-cards.c29
-rw-r--r--drivers/media/video/em28xx/em28xx-input.c30
-rw-r--r--drivers/media/video/em28xx/em28xx.h2
3 files changed, 55 insertions, 6 deletions
diff --git a/drivers/media/video/em28xx/em28xx-cards.c b/drivers/media/video/em28xx/em28xx-cards.c
index 25100001ffff..b1c5d9516e22 100644
--- a/drivers/media/video/em28xx/em28xx-cards.c
+++ b/drivers/media/video/em28xx/em28xx-cards.c
@@ -461,21 +461,30 @@ struct em28xx_board em28xx_boards[] = {
461 .name = "Leadtek Winfast USB II Deluxe", 461 .name = "Leadtek Winfast USB II Deluxe",
462 .valid = EM28XX_BOARD_NOT_VALIDATED, 462 .valid = EM28XX_BOARD_NOT_VALIDATED,
463 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3, 463 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
464 .tda9887_conf = TDA9887_PRESENT, 464 .has_ir_i2c = 1,
465 .tvaudio_addr = 0x58,
466 .tda9887_conf = TDA9887_PRESENT |
467 TDA9887_PORT2_ACTIVE |
468 TDA9887_QSS,
465 .decoder = EM28XX_SAA711X, 469 .decoder = EM28XX_SAA711X,
470 .adecoder = EM28XX_TVAUDIO,
466 .input = { { 471 .input = { {
467 .type = EM28XX_VMUX_TELEVISION, 472 .type = EM28XX_VMUX_TELEVISION,
468 .vmux = SAA7115_COMPOSITE2, 473 .vmux = SAA7115_COMPOSITE4,
469 .amux = EM28XX_AMUX_VIDEO, 474 .amux = EM28XX_AMUX_AUX,
470 }, { 475 }, {
471 .type = EM28XX_VMUX_COMPOSITE1, 476 .type = EM28XX_VMUX_COMPOSITE1,
472 .vmux = SAA7115_COMPOSITE0, 477 .vmux = SAA7115_COMPOSITE5,
473 .amux = EM28XX_AMUX_LINE_IN, 478 .amux = EM28XX_AMUX_LINE_IN,
474 }, { 479 }, {
475 .type = EM28XX_VMUX_SVIDEO, 480 .type = EM28XX_VMUX_SVIDEO,
476 .vmux = SAA7115_COMPOSITE0, 481 .vmux = SAA7115_SVIDEO3,
477 .amux = EM28XX_AMUX_LINE_IN, 482 .amux = EM28XX_AMUX_LINE_IN,
478 } }, 483 } },
484 .radio = {
485 .type = EM28XX_RADIO,
486 .amux = EM28XX_AMUX_AUX,
487 }
479 }, 488 },
480 [EM2820_BOARD_VIDEOLOGY_20K14XUSB] = { 489 [EM2820_BOARD_VIDEOLOGY_20K14XUSB] = {
481 .name = "Videology 20K14XUSB USB2.0", 490 .name = "Videology 20K14XUSB USB2.0",
@@ -2259,9 +2268,12 @@ static int em28xx_hint_board(struct em28xx *dev)
2259/* ----------------------------------------------------------------------- */ 2268/* ----------------------------------------------------------------------- */
2260void em28xx_register_i2c_ir(struct em28xx *dev) 2269void em28xx_register_i2c_ir(struct em28xx *dev)
2261{ 2270{
2271 /* Leadtek winfast tv USBII deluxe can find a non working IR-device */
2272 /* at address 0x18, so if that address is needed for another board in */
2273 /* the future, please put it after 0x1f. */
2262 struct i2c_board_info info; 2274 struct i2c_board_info info;
2263 const unsigned short addr_list[] = { 2275 const unsigned short addr_list[] = {
2264 0x30, 0x47, I2C_CLIENT_END 2276 0x1f, 0x30, 0x47, I2C_CLIENT_END
2265 }; 2277 };
2266 2278
2267 if (disable_ir) 2279 if (disable_ir)
@@ -2344,6 +2356,11 @@ void em28xx_card_setup(struct em28xx *dev)
2344 dev->board.has_msp34xx = 1; 2356 dev->board.has_msp34xx = 1;
2345 } 2357 }
2346 break; 2358 break;
2359 case EM2820_BOARD_LEADTEK_WINFAST_USBII_DELUXE:
2360 dev->init_data.ir_codes = &ir_codes_winfast_usbii_deluxe_table;;
2361 dev->init_data.get_key = em28xx_get_key_winfast_usbii_deluxe;
2362 dev->init_data.name = "i2c IR (EM2820 Winfast TV USBII Deluxe)";
2363 break;
2347 } 2364 }
2348 case EM2882_BOARD_KWORLD_ATSC_315U: 2365 case EM2882_BOARD_KWORLD_ATSC_315U:
2349 em28xx_write_reg(dev, 0x0d, 0x42); 2366 em28xx_write_reg(dev, 0x0d, 0x42);
diff --git a/drivers/media/video/em28xx/em28xx-input.c b/drivers/media/video/em28xx/em28xx-input.c
index 69dcf0cc1f1e..1fb754e20875 100644
--- a/drivers/media/video/em28xx/em28xx-input.c
+++ b/drivers/media/video/em28xx/em28xx-input.c
@@ -184,6 +184,36 @@ int em28xx_get_key_pinnacle_usb_grey(struct IR_i2c *ir, u32 *ir_key,
184 return 1; 184 return 1;
185} 185}
186 186
187int em28xx_get_key_winfast_usbii_deluxe(struct IR_i2c *ir, u32 *ir_key, u32 *ir_raw)
188{
189 unsigned char subaddr, keydetect, key;
190
191 struct i2c_msg msg[] = { { .addr = ir->c->addr, .flags = 0, .buf = &subaddr, .len = 1},
192
193 { .addr = ir->c->addr, .flags = I2C_M_RD, .buf = &keydetect, .len = 1} };
194
195 subaddr = 0x10;
196 if (2 != i2c_transfer(ir->c->adapter, msg, 2)) {
197 i2cdprintk("read error\n");
198 return -EIO;
199 }
200 if (keydetect == 0x00)
201 return 0;
202
203 subaddr = 0x00;
204 msg[1].buf = &key;
205 if (2 != i2c_transfer(ir->c->adapter, msg, 2)) {
206 i2cdprintk("read error\n");
207 return -EIO;
208 }
209 if (key == 0x00)
210 return 0;
211
212 *ir_key = key;
213 *ir_raw = key;
214 return 1;
215}
216
187/********************************************************** 217/**********************************************************
188 Poll based get keycode functions 218 Poll based get keycode functions
189 **********************************************************/ 219 **********************************************************/
diff --git a/drivers/media/video/em28xx/em28xx.h b/drivers/media/video/em28xx/em28xx.h
index 71e90dc66582..0cb8d151cd0b 100644
--- a/drivers/media/video/em28xx/em28xx.h
+++ b/drivers/media/video/em28xx/em28xx.h
@@ -694,6 +694,8 @@ int em28xx_get_key_terratec(struct IR_i2c *ir, u32 *ir_key, u32 *ir_raw);
694int em28xx_get_key_em_haup(struct IR_i2c *ir, u32 *ir_key, u32 *ir_raw); 694int em28xx_get_key_em_haup(struct IR_i2c *ir, u32 *ir_key, u32 *ir_raw);
695int em28xx_get_key_pinnacle_usb_grey(struct IR_i2c *ir, u32 *ir_key, 695int em28xx_get_key_pinnacle_usb_grey(struct IR_i2c *ir, u32 *ir_key,
696 u32 *ir_raw); 696 u32 *ir_raw);
697int em28xx_get_key_winfast_usbii_deluxe(struct IR_i2c *ir, u32 *ir_key,
698 u32 *ir_raw);
697void em28xx_register_snapshot_button(struct em28xx *dev); 699void em28xx_register_snapshot_button(struct em28xx *dev);
698void em28xx_deregister_snapshot_button(struct em28xx *dev); 700void em28xx_deregister_snapshot_button(struct em28xx *dev);
699 701