diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/media/video/em28xx/em28xx-cards.c | 30 | ||||
-rw-r--r-- | drivers/media/video/em28xx/em28xx-i2c.c | 19 | ||||
-rw-r--r-- | drivers/media/video/em28xx/em28xx-video.c | 1 | ||||
-rw-r--r-- | drivers/media/video/em28xx/em28xx.h | 2 |
4 files changed, 46 insertions, 6 deletions
diff --git a/drivers/media/video/em28xx/em28xx-cards.c b/drivers/media/video/em28xx/em28xx-cards.c index ae6634156e76..fd7a8a5fba66 100644 --- a/drivers/media/video/em28xx/em28xx-cards.c +++ b/drivers/media/video/em28xx/em28xx-cards.c | |||
@@ -402,6 +402,11 @@ static struct em28xx_hash_table em28xx_hash [] = { | |||
402 | { 0x6ce05a8f, EM2820_BOARD_PROLINK_PLAYTV_USB2, TUNER_YMEC_TVF_5533MF }, | 402 | { 0x6ce05a8f, EM2820_BOARD_PROLINK_PLAYTV_USB2, TUNER_YMEC_TVF_5533MF }, |
403 | }; | 403 | }; |
404 | 404 | ||
405 | static struct em28xx_hash_table em28xx_i2c_hash[] = { | ||
406 | { 0xb06a32c3, EM2800_BOARD_TERRATEC_CINERGY_200, TUNER_LG_PAL_NEW_TAPC }, | ||
407 | { 0xf51200e3, EM2800_BOARD_VGEAR_POCKETTV, TUNER_LG_PAL_NEW_TAPC }, | ||
408 | }; | ||
409 | |||
405 | /* Since em28xx_pre_card_setup() requires a proper dev->model, | 410 | /* Since em28xx_pre_card_setup() requires a proper dev->model, |
406 | * this won't work for boards with generic PCI IDs | 411 | * this won't work for boards with generic PCI IDs |
407 | */ | 412 | */ |
@@ -498,6 +503,30 @@ static int em28xx_hint_board(struct em28xx *dev) | |||
498 | return 0; | 503 | return 0; |
499 | } | 504 | } |
500 | } | 505 | } |
506 | |||
507 | /* user did not request i2c scanning => do it now */ | ||
508 | if (!dev->i2c_hash) | ||
509 | em28xx_do_i2c_scan(dev); | ||
510 | |||
511 | for (i = 0; i < ARRAY_SIZE(em28xx_i2c_hash); i++) { | ||
512 | if (dev->i2c_hash == em28xx_i2c_hash[i].hash) { | ||
513 | dev->model = em28xx_i2c_hash[i].model; | ||
514 | dev->tuner_type = em28xx_i2c_hash[i].tuner; | ||
515 | em28xx_errdev("Your board has no unique USB ID.\n"); | ||
516 | em28xx_errdev("A hint were successfully done, " | ||
517 | "based on i2c devicelist hash.\n"); | ||
518 | em28xx_errdev("This method is not 100%% failproof.\n"); | ||
519 | em28xx_errdev("If the board were missdetected, " | ||
520 | "please email this log to:\n"); | ||
521 | em28xx_errdev("\tV4L Mailing List " | ||
522 | " <video4linux-list@redhat.com>\n"); | ||
523 | em28xx_errdev("Board detected as %s\n", | ||
524 | em28xx_boards[dev->model].name); | ||
525 | |||
526 | return 0; | ||
527 | } | ||
528 | } | ||
529 | |||
501 | em28xx_errdev("Your board has no unique USB ID and thus need a " | 530 | em28xx_errdev("Your board has no unique USB ID and thus need a " |
502 | "hint to be detected.\n"); | 531 | "hint to be detected.\n"); |
503 | em28xx_errdev("You may try to use card=<n> insmod option to " | 532 | em28xx_errdev("You may try to use card=<n> insmod option to " |
@@ -505,6 +534,7 @@ static int em28xx_hint_board(struct em28xx *dev) | |||
505 | em28xx_errdev("Please send an email with this log to:\n"); | 534 | em28xx_errdev("Please send an email with this log to:\n"); |
506 | em28xx_errdev("\tV4L Mailing List <video4linux-list@redhat.com>\n"); | 535 | em28xx_errdev("\tV4L Mailing List <video4linux-list@redhat.com>\n"); |
507 | em28xx_errdev("Board eeprom hash is 0x%08lx\n", dev->hash); | 536 | em28xx_errdev("Board eeprom hash is 0x%08lx\n", dev->hash); |
537 | em28xx_errdev("Board i2c devicelist hash is 0x%08lx\n", dev->i2c_hash); | ||
508 | 538 | ||
509 | em28xx_errdev("Here is a list of valid choices for the card=<n>" | 539 | em28xx_errdev("Here is a list of valid choices for the card=<n>" |
510 | " insmod option:\n"); | 540 | " insmod option:\n"); |
diff --git a/drivers/media/video/em28xx/em28xx-i2c.c b/drivers/media/video/em28xx/em28xx-i2c.c index e2003455f2b2..acd853d217ea 100644 --- a/drivers/media/video/em28xx/em28xx-i2c.c +++ b/drivers/media/video/em28xx/em28xx-i2c.c | |||
@@ -533,19 +533,26 @@ static char *i2c_devs[128] = { | |||
533 | * do_i2c_scan() | 533 | * do_i2c_scan() |
534 | * check i2c address range for devices | 534 | * check i2c address range for devices |
535 | */ | 535 | */ |
536 | static void do_i2c_scan(char *name, struct i2c_client *c) | 536 | void em28xx_do_i2c_scan(struct em28xx *dev) |
537 | { | 537 | { |
538 | u8 i2c_devicelist[128]; | ||
538 | unsigned char buf; | 539 | unsigned char buf; |
539 | int i, rc; | 540 | int i, rc; |
540 | 541 | ||
542 | memset(i2c_devicelist, 0, ARRAY_SIZE(i2c_devicelist)); | ||
543 | |||
541 | for (i = 0; i < ARRAY_SIZE(i2c_devs); i++) { | 544 | for (i = 0; i < ARRAY_SIZE(i2c_devs); i++) { |
542 | c->addr = i; | 545 | dev->i2c_client.addr = i; |
543 | rc = i2c_master_recv(c, &buf, 0); | 546 | rc = i2c_master_recv(&dev->i2c_client, &buf, 0); |
544 | if (rc < 0) | 547 | if (rc < 0) |
545 | continue; | 548 | continue; |
546 | printk(KERN_INFO "%s: found i2c device @ 0x%x [%s]\n", name, | 549 | i2c_devicelist[i] = i; |
547 | i << 1, i2c_devs[i] ? i2c_devs[i] : "???"); | 550 | printk(KERN_INFO "%s: found i2c device @ 0x%x [%s]\n", |
551 | dev->name, i << 1, i2c_devs[i] ? i2c_devs[i] : "???"); | ||
548 | } | 552 | } |
553 | |||
554 | dev->i2c_hash = em28xx_hash_mem(i2c_devicelist, | ||
555 | ARRAY_SIZE(i2c_devicelist), 32); | ||
549 | } | 556 | } |
550 | 557 | ||
551 | /* | 558 | /* |
@@ -578,7 +585,7 @@ int em28xx_i2c_register(struct em28xx *dev) | |||
578 | em28xx_i2c_eeprom(dev, dev->eedata, sizeof(dev->eedata)); | 585 | em28xx_i2c_eeprom(dev, dev->eedata, sizeof(dev->eedata)); |
579 | 586 | ||
580 | if (i2c_scan) | 587 | if (i2c_scan) |
581 | do_i2c_scan(dev->name, &dev->i2c_client); | 588 | em28xx_do_i2c_scan(dev); |
582 | return 0; | 589 | return 0; |
583 | } | 590 | } |
584 | 591 | ||
diff --git a/drivers/media/video/em28xx/em28xx-video.c b/drivers/media/video/em28xx/em28xx-video.c index bc495a11dc2d..b43edc3fa23e 100644 --- a/drivers/media/video/em28xx/em28xx-video.c +++ b/drivers/media/video/em28xx/em28xx-video.c | |||
@@ -1510,6 +1510,7 @@ static int em28xx_init_dev(struct em28xx **devhandle, struct usb_device *udev, | |||
1510 | dev->em28xx_read_reg_req_len = em28xx_read_reg_req_len; | 1510 | dev->em28xx_read_reg_req_len = em28xx_read_reg_req_len; |
1511 | dev->em28xx_write_regs_req = em28xx_write_regs_req; | 1511 | dev->em28xx_write_regs_req = em28xx_write_regs_req; |
1512 | dev->em28xx_read_reg_req = em28xx_read_reg_req; | 1512 | dev->em28xx_read_reg_req = em28xx_read_reg_req; |
1513 | dev->is_em2800 = em28xx_boards[dev->model].is_em2800; | ||
1513 | 1514 | ||
1514 | /* setup video picture settings for saa7113h */ | 1515 | /* setup video picture settings for saa7113h */ |
1515 | memset(&dev->vpic, 0, sizeof(dev->vpic)); | 1516 | memset(&dev->vpic, 0, sizeof(dev->vpic)); |
diff --git a/drivers/media/video/em28xx/em28xx.h b/drivers/media/video/em28xx/em28xx.h index 70fddd45d1f7..c2531da2e618 100644 --- a/drivers/media/video/em28xx/em28xx.h +++ b/drivers/media/video/em28xx/em28xx.h | |||
@@ -260,6 +260,7 @@ struct em28xx { | |||
260 | int type; | 260 | int type; |
261 | 261 | ||
262 | unsigned long hash; /* eeprom hash - for boards with generic ID */ | 262 | unsigned long hash; /* eeprom hash - for boards with generic ID */ |
263 | unsigned long i2c_hash; /* i2c devicelist hash - for boards with generic ID */ | ||
263 | 264 | ||
264 | /* states */ | 265 | /* states */ |
265 | enum em28xx_dev_state state; | 266 | enum em28xx_dev_state state; |
@@ -296,6 +297,7 @@ struct em28xx { | |||
296 | /* Provided by em28xx-i2c.c */ | 297 | /* Provided by em28xx-i2c.c */ |
297 | 298 | ||
298 | void em28xx_i2c_call_clients(struct em28xx *dev, unsigned int cmd, void *arg); | 299 | void em28xx_i2c_call_clients(struct em28xx *dev, unsigned int cmd, void *arg); |
300 | void em28xx_do_i2c_scan(struct em28xx *dev); | ||
299 | int em28xx_i2c_register(struct em28xx *dev); | 301 | int em28xx_i2c_register(struct em28xx *dev); |
300 | int em28xx_i2c_unregister(struct em28xx *dev); | 302 | int em28xx_i2c_unregister(struct em28xx *dev); |
301 | 303 | ||