aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/video/vino.c207
1 files changed, 67 insertions, 140 deletions
diff --git a/drivers/media/video/vino.c b/drivers/media/video/vino.c
index 308fa419ae04..96ce68a3dd95 100644
--- a/drivers/media/video/vino.c
+++ b/drivers/media/video/vino.c
@@ -287,20 +287,17 @@ struct vino_channel_settings {
287 struct video_device *vdev; 287 struct video_device *vdev;
288}; 288};
289 289
290struct vino_client {
291 /* the channel which owns this client:
292 * VINO_NO_CHANNEL, VINO_CHANNEL_A or VINO_CHANNEL_B */
293 unsigned int owner;
294 struct i2c_client *driver;
295};
296
297struct vino_settings { 290struct vino_settings {
298 struct v4l2_device v4l2_dev; 291 struct v4l2_device v4l2_dev;
299 struct vino_channel_settings a; 292 struct vino_channel_settings a;
300 struct vino_channel_settings b; 293 struct vino_channel_settings b;
301 294
302 struct vino_client decoder; 295 /* the channel which owns this client:
303 struct vino_client camera; 296 * VINO_NO_CHANNEL, VINO_CHANNEL_A or VINO_CHANNEL_B */
297 unsigned int decoder_owner;
298 struct v4l2_subdev *decoder;
299 unsigned int camera_owner;
300 struct v4l2_subdev *camera;
304 301
305 /* a lock for vino register access */ 302 /* a lock for vino register access */
306 spinlock_t vino_lock; 303 spinlock_t vino_lock;
@@ -340,6 +337,11 @@ static struct sgi_vino *vino;
340 337
341static struct vino_settings *vino_drvdata; 338static struct vino_settings *vino_drvdata;
342 339
340#define camera_call(o, f, args...) \
341 v4l2_subdev_call(vino_drvdata->camera, o, f, ##args)
342#define decoder_call(o, f, args...) \
343 v4l2_subdev_call(vino_drvdata->decoder, o, f, ##args)
344
343static const char *vino_driver_name = "vino"; 345static const char *vino_driver_name = "vino";
344static const char *vino_driver_description = "SGI VINO"; 346static const char *vino_driver_description = "SGI VINO";
345static const char *vino_bus_name = "GIO64 bus"; 347static const char *vino_bus_name = "GIO64 bus";
@@ -670,66 +672,12 @@ static struct i2c_algo_sgi_data i2c_sgi_vino_data =
670 .ack_timeout = 1000, 672 .ack_timeout = 1000,
671}; 673};
672 674
673/*
674 * There are two possible clients on VINO I2C bus, so we limit usage only
675 * to them.
676 */
677static int i2c_vino_client_reg(struct i2c_client *client)
678{
679 unsigned long flags;
680 int ret = 0;
681
682 spin_lock_irqsave(&vino_drvdata->input_lock, flags);
683 switch (client->driver->id) {
684 case I2C_DRIVERID_SAA7191:
685 if (vino_drvdata->decoder.driver)
686 ret = -EBUSY;
687 else
688 vino_drvdata->decoder.driver = client;
689 break;
690 case I2C_DRIVERID_INDYCAM:
691 if (vino_drvdata->camera.driver)
692 ret = -EBUSY;
693 else
694 vino_drvdata->camera.driver = client;
695 break;
696 default:
697 ret = -ENODEV;
698 }
699 spin_unlock_irqrestore(&vino_drvdata->input_lock, flags);
700
701 return ret;
702}
703
704static int i2c_vino_client_unreg(struct i2c_client *client)
705{
706 unsigned long flags;
707 int ret = 0;
708
709 spin_lock_irqsave(&vino_drvdata->input_lock, flags);
710 if (client == vino_drvdata->decoder.driver) {
711 if (vino_drvdata->decoder.owner != VINO_NO_CHANNEL)
712 ret = -EBUSY;
713 else
714 vino_drvdata->decoder.driver = NULL;
715 } else if (client == vino_drvdata->camera.driver) {
716 if (vino_drvdata->camera.owner != VINO_NO_CHANNEL)
717 ret = -EBUSY;
718 else
719 vino_drvdata->camera.driver = NULL;
720 }
721 spin_unlock_irqrestore(&vino_drvdata->input_lock, flags);
722
723 return ret;
724}
725
726static struct i2c_adapter vino_i2c_adapter = 675static struct i2c_adapter vino_i2c_adapter =
727{ 676{
728 .name = "VINO I2C bus", 677 .name = "VINO I2C bus",
729 .id = I2C_HW_SGI_VINO, 678 .id = I2C_HW_SGI_VINO,
730 .algo_data = &i2c_sgi_vino_data, 679 .algo_data = &i2c_sgi_vino_data,
731 .client_register = &i2c_vino_client_reg, 680 .owner = THIS_MODULE,
732 .client_unregister = &i2c_vino_client_unreg,
733}; 681};
734 682
735static int vino_i2c_add_bus(void) 683static int vino_i2c_add_bus(void)
@@ -742,20 +690,6 @@ static int vino_i2c_del_bus(void)
742 return i2c_del_adapter(&vino_i2c_adapter); 690 return i2c_del_adapter(&vino_i2c_adapter);
743} 691}
744 692
745static int i2c_camera_command(unsigned int cmd, void *arg)
746{
747 return vino_drvdata->camera.driver->
748 driver->command(vino_drvdata->camera.driver,
749 cmd, arg);
750}
751
752static int i2c_decoder_command(unsigned int cmd, void *arg)
753{
754 return vino_drvdata->decoder.driver->
755 driver->command(vino_drvdata->decoder.driver,
756 cmd, arg);
757}
758
759/* VINO framebuffer/DMA descriptor management */ 693/* VINO framebuffer/DMA descriptor management */
760 694
761static void vino_free_buffer_with_count(struct vino_framebuffer *fb, 695static void vino_free_buffer_with_count(struct vino_framebuffer *fb,
@@ -2456,9 +2390,9 @@ static int vino_is_input_owner(struct vino_channel_settings *vcs)
2456 switch(vcs->input) { 2390 switch(vcs->input) {
2457 case VINO_INPUT_COMPOSITE: 2391 case VINO_INPUT_COMPOSITE:
2458 case VINO_INPUT_SVIDEO: 2392 case VINO_INPUT_SVIDEO:
2459 return (vino_drvdata->decoder.owner == vcs->channel); 2393 return vino_drvdata->decoder_owner == vcs->channel;
2460 case VINO_INPUT_D1: 2394 case VINO_INPUT_D1:
2461 return (vino_drvdata->camera.owner == vcs->channel); 2395 return vino_drvdata->camera_owner == vcs->channel;
2462 default: 2396 default:
2463 return 0; 2397 return 0;
2464 } 2398 }
@@ -2474,24 +2408,22 @@ static int vino_acquire_input(struct vino_channel_settings *vcs)
2474 spin_lock_irqsave(&vino_drvdata->input_lock, flags); 2408 spin_lock_irqsave(&vino_drvdata->input_lock, flags);
2475 2409
2476 /* First try D1 and then SAA7191 */ 2410 /* First try D1 and then SAA7191 */
2477 if (vino_drvdata->camera.driver 2411 if (vino_drvdata->camera
2478 && (vino_drvdata->camera.owner == VINO_NO_CHANNEL)) { 2412 && (vino_drvdata->camera_owner == VINO_NO_CHANNEL)) {
2479 i2c_use_client(vino_drvdata->camera.driver); 2413 vino_drvdata->camera_owner = vcs->channel;
2480 vino_drvdata->camera.owner = vcs->channel;
2481 vcs->input = VINO_INPUT_D1; 2414 vcs->input = VINO_INPUT_D1;
2482 vcs->data_norm = VINO_DATA_NORM_D1; 2415 vcs->data_norm = VINO_DATA_NORM_D1;
2483 } else if (vino_drvdata->decoder.driver 2416 } else if (vino_drvdata->decoder
2484 && (vino_drvdata->decoder.owner == VINO_NO_CHANNEL)) { 2417 && (vino_drvdata->decoder_owner == VINO_NO_CHANNEL)) {
2485 int input; 2418 int input;
2486 int data_norm; 2419 int data_norm;
2487 v4l2_std_id norm; 2420 v4l2_std_id norm;
2488 struct v4l2_routing route = { 0, 0 }; 2421 struct v4l2_routing route = { 0, 0 };
2489 2422
2490 i2c_use_client(vino_drvdata->decoder.driver);
2491 input = VINO_INPUT_COMPOSITE; 2423 input = VINO_INPUT_COMPOSITE;
2492 2424
2493 route.input = vino_get_saa7191_input(input); 2425 route.input = vino_get_saa7191_input(input);
2494 ret = i2c_decoder_command(VIDIOC_INT_S_VIDEO_ROUTING, &route); 2426 ret = decoder_call(video, s_routing, &route);
2495 if (ret) { 2427 if (ret) {
2496 ret = -EINVAL; 2428 ret = -EINVAL;
2497 goto out; 2429 goto out;
@@ -2502,7 +2434,7 @@ static int vino_acquire_input(struct vino_channel_settings *vcs)
2502 /* Don't hold spinlocks while auto-detecting norm 2434 /* Don't hold spinlocks while auto-detecting norm
2503 * as it may take a while... */ 2435 * as it may take a while... */
2504 2436
2505 ret = i2c_decoder_command(VIDIOC_QUERYSTD, &norm); 2437 ret = decoder_call(video, querystd, &norm);
2506 if (!ret) { 2438 if (!ret) {
2507 for (data_norm = 0; data_norm < 3; data_norm++) { 2439 for (data_norm = 0; data_norm < 3; data_norm++) {
2508 if (vino_data_norms[data_norm].std & norm) 2440 if (vino_data_norms[data_norm].std & norm)
@@ -2510,7 +2442,7 @@ static int vino_acquire_input(struct vino_channel_settings *vcs)
2510 } 2442 }
2511 if (data_norm == 3) 2443 if (data_norm == 3)
2512 data_norm = VINO_DATA_NORM_PAL; 2444 data_norm = VINO_DATA_NORM_PAL;
2513 ret = i2c_decoder_command(VIDIOC_S_STD, &norm); 2445 ret = decoder_call(tuner, s_std, norm);
2514 } 2446 }
2515 2447
2516 spin_lock_irqsave(&vino_drvdata->input_lock, flags); 2448 spin_lock_irqsave(&vino_drvdata->input_lock, flags);
@@ -2520,7 +2452,7 @@ static int vino_acquire_input(struct vino_channel_settings *vcs)
2520 goto out; 2452 goto out;
2521 } 2453 }
2522 2454
2523 vino_drvdata->decoder.owner = vcs->channel; 2455 vino_drvdata->decoder_owner = vcs->channel;
2524 2456
2525 vcs->input = input; 2457 vcs->input = input;
2526 vcs->data_norm = data_norm; 2458 vcs->data_norm = data_norm;
@@ -2565,25 +2497,24 @@ static int vino_set_input(struct vino_channel_settings *vcs, int input)
2565 switch (input) { 2497 switch (input) {
2566 case VINO_INPUT_COMPOSITE: 2498 case VINO_INPUT_COMPOSITE:
2567 case VINO_INPUT_SVIDEO: 2499 case VINO_INPUT_SVIDEO:
2568 if (!vino_drvdata->decoder.driver) { 2500 if (!vino_drvdata->decoder) {
2569 ret = -EINVAL; 2501 ret = -EINVAL;
2570 goto out; 2502 goto out;
2571 } 2503 }
2572 2504
2573 if (vino_drvdata->decoder.owner == VINO_NO_CHANNEL) { 2505 if (vino_drvdata->decoder_owner == VINO_NO_CHANNEL) {
2574 i2c_use_client(vino_drvdata->decoder.driver); 2506 vino_drvdata->decoder_owner = vcs->channel;
2575 vino_drvdata->decoder.owner = vcs->channel;
2576 } 2507 }
2577 2508
2578 if (vino_drvdata->decoder.owner == vcs->channel) { 2509 if (vino_drvdata->decoder_owner == vcs->channel) {
2579 int data_norm; 2510 int data_norm;
2580 v4l2_std_id norm; 2511 v4l2_std_id norm;
2581 struct v4l2_routing route = { 0, 0 }; 2512 struct v4l2_routing route = { 0, 0 };
2582 2513
2583 route.input = vino_get_saa7191_input(input); 2514 route.input = vino_get_saa7191_input(input);
2584 ret = i2c_decoder_command(VIDIOC_INT_S_VIDEO_ROUTING, &route); 2515 ret = decoder_call(video, s_routing, &route);
2585 if (ret) { 2516 if (ret) {
2586 vino_drvdata->decoder.owner = VINO_NO_CHANNEL; 2517 vino_drvdata->decoder_owner = VINO_NO_CHANNEL;
2587 ret = -EINVAL; 2518 ret = -EINVAL;
2588 goto out; 2519 goto out;
2589 } 2520 }
@@ -2593,7 +2524,7 @@ static int vino_set_input(struct vino_channel_settings *vcs, int input)
2593 /* Don't hold spinlocks while auto-detecting norm 2524 /* Don't hold spinlocks while auto-detecting norm
2594 * as it may take a while... */ 2525 * as it may take a while... */
2595 2526
2596 ret = i2c_decoder_command(VIDIOC_QUERYSTD, &norm); 2527 ret = decoder_call(video, querystd, &norm);
2597 if (!ret) { 2528 if (!ret) {
2598 for (data_norm = 0; data_norm < 3; data_norm++) { 2529 for (data_norm = 0; data_norm < 3; data_norm++) {
2599 if (vino_data_norms[data_norm].std & norm) 2530 if (vino_data_norms[data_norm].std & norm)
@@ -2601,13 +2532,13 @@ static int vino_set_input(struct vino_channel_settings *vcs, int input)
2601 } 2532 }
2602 if (data_norm == 3) 2533 if (data_norm == 3)
2603 data_norm = VINO_DATA_NORM_PAL; 2534 data_norm = VINO_DATA_NORM_PAL;
2604 ret = i2c_decoder_command(VIDIOC_S_STD, &norm); 2535 ret = decoder_call(tuner, s_std, norm);
2605 } 2536 }
2606 2537
2607 spin_lock_irqsave(&vino_drvdata->input_lock, flags); 2538 spin_lock_irqsave(&vino_drvdata->input_lock, flags);
2608 2539
2609 if (ret) { 2540 if (ret) {
2610 vino_drvdata->decoder.owner = VINO_NO_CHANNEL; 2541 vino_drvdata->decoder_owner = VINO_NO_CHANNEL;
2611 ret = -EINVAL; 2542 ret = -EINVAL;
2612 goto out; 2543 goto out;
2613 } 2544 }
@@ -2624,36 +2555,31 @@ static int vino_set_input(struct vino_channel_settings *vcs, int input)
2624 vcs->data_norm = vcs2->data_norm; 2555 vcs->data_norm = vcs2->data_norm;
2625 } 2556 }
2626 2557
2627 if (vino_drvdata->camera.owner == vcs->channel) { 2558 if (vino_drvdata->camera_owner == vcs->channel) {
2628 /* Transfer the ownership or release the input */ 2559 /* Transfer the ownership or release the input */
2629 if (vcs2->input == VINO_INPUT_D1) { 2560 if (vcs2->input == VINO_INPUT_D1) {
2630 vino_drvdata->camera.owner = vcs2->channel; 2561 vino_drvdata->camera_owner = vcs2->channel;
2631 } else { 2562 } else {
2632 i2c_release_client(vino_drvdata->camera.driver); 2563 vino_drvdata->camera_owner = VINO_NO_CHANNEL;
2633 vino_drvdata->camera.owner = VINO_NO_CHANNEL;
2634 } 2564 }
2635 } 2565 }
2636 break; 2566 break;
2637 case VINO_INPUT_D1: 2567 case VINO_INPUT_D1:
2638 if (!vino_drvdata->camera.driver) { 2568 if (!vino_drvdata->camera) {
2639 ret = -EINVAL; 2569 ret = -EINVAL;
2640 goto out; 2570 goto out;
2641 } 2571 }
2642 2572
2643 if (vino_drvdata->camera.owner == VINO_NO_CHANNEL) { 2573 if (vino_drvdata->camera_owner == VINO_NO_CHANNEL)
2644 i2c_use_client(vino_drvdata->camera.driver); 2574 vino_drvdata->camera_owner = vcs->channel;
2645 vino_drvdata->camera.owner = vcs->channel;
2646 }
2647 2575
2648 if (vino_drvdata->decoder.owner == vcs->channel) { 2576 if (vino_drvdata->decoder_owner == vcs->channel) {
2649 /* Transfer the ownership or release the input */ 2577 /* Transfer the ownership or release the input */
2650 if ((vcs2->input == VINO_INPUT_COMPOSITE) || 2578 if ((vcs2->input == VINO_INPUT_COMPOSITE) ||
2651 (vcs2->input == VINO_INPUT_SVIDEO)) { 2579 (vcs2->input == VINO_INPUT_SVIDEO)) {
2652 vino_drvdata->decoder.owner = vcs2->channel; 2580 vino_drvdata->decoder_owner = vcs2->channel;
2653 } else { 2581 } else {
2654 i2c_release_client(vino_drvdata-> 2582 vino_drvdata->decoder_owner = VINO_NO_CHANNEL;
2655 decoder.driver);
2656 vino_drvdata->decoder.owner = VINO_NO_CHANNEL;
2657 } 2583 }
2658 } 2584 }
2659 2585
@@ -2690,20 +2616,18 @@ static void vino_release_input(struct vino_channel_settings *vcs)
2690 /* Release ownership of the channel 2616 /* Release ownership of the channel
2691 * and if the other channel takes input from 2617 * and if the other channel takes input from
2692 * the same source, transfer the ownership */ 2618 * the same source, transfer the ownership */
2693 if (vino_drvdata->camera.owner == vcs->channel) { 2619 if (vino_drvdata->camera_owner == vcs->channel) {
2694 if (vcs2->input == VINO_INPUT_D1) { 2620 if (vcs2->input == VINO_INPUT_D1) {
2695 vino_drvdata->camera.owner = vcs2->channel; 2621 vino_drvdata->camera_owner = vcs2->channel;
2696 } else { 2622 } else {
2697 i2c_release_client(vino_drvdata->camera.driver); 2623 vino_drvdata->camera_owner = VINO_NO_CHANNEL;
2698 vino_drvdata->camera.owner = VINO_NO_CHANNEL;
2699 } 2624 }
2700 } else if (vino_drvdata->decoder.owner == vcs->channel) { 2625 } else if (vino_drvdata->decoder_owner == vcs->channel) {
2701 if ((vcs2->input == VINO_INPUT_COMPOSITE) || 2626 if ((vcs2->input == VINO_INPUT_COMPOSITE) ||
2702 (vcs2->input == VINO_INPUT_SVIDEO)) { 2627 (vcs2->input == VINO_INPUT_SVIDEO)) {
2703 vino_drvdata->decoder.owner = vcs2->channel; 2628 vino_drvdata->decoder_owner = vcs2->channel;
2704 } else { 2629 } else {
2705 i2c_release_client(vino_drvdata->decoder.driver); 2630 vino_drvdata->decoder_owner = VINO_NO_CHANNEL;
2706 vino_drvdata->decoder.owner = VINO_NO_CHANNEL;
2707 } 2631 }
2708 } 2632 }
2709 vcs->input = VINO_INPUT_NONE; 2633 vcs->input = VINO_INPUT_NONE;
@@ -2742,7 +2666,7 @@ static int vino_set_data_norm(struct vino_channel_settings *vcs,
2742 * as it may take a while... */ 2666 * as it may take a while... */
2743 2667
2744 norm = vino_data_norms[data_norm].std; 2668 norm = vino_data_norms[data_norm].std;
2745 err = i2c_decoder_command(VIDIOC_S_STD, &norm); 2669 err = decoder_call(tuner, s_std, norm);
2746 2670
2747 spin_lock_irqsave(&vino_drvdata->input_lock, *flags); 2671 spin_lock_irqsave(&vino_drvdata->input_lock, *flags);
2748 2672
@@ -2784,7 +2708,7 @@ static int vino_int_enum_input(struct vino_channel_settings *vcs, __u32 index)
2784 unsigned long flags; 2708 unsigned long flags;
2785 2709
2786 spin_lock_irqsave(&vino_drvdata->input_lock, flags); 2710 spin_lock_irqsave(&vino_drvdata->input_lock, flags);
2787 if (vino_drvdata->decoder.driver && vino_drvdata->camera.driver) { 2711 if (vino_drvdata->decoder && vino_drvdata->camera) {
2788 switch (index) { 2712 switch (index) {
2789 case 0: 2713 case 0:
2790 input = VINO_INPUT_COMPOSITE; 2714 input = VINO_INPUT_COMPOSITE;
@@ -2796,7 +2720,7 @@ static int vino_int_enum_input(struct vino_channel_settings *vcs, __u32 index)
2796 input = VINO_INPUT_D1; 2720 input = VINO_INPUT_D1;
2797 break; 2721 break;
2798 } 2722 }
2799 } else if (vino_drvdata->decoder.driver) { 2723 } else if (vino_drvdata->decoder) {
2800 switch (index) { 2724 switch (index) {
2801 case 0: 2725 case 0:
2802 input = VINO_INPUT_COMPOSITE; 2726 input = VINO_INPUT_COMPOSITE;
@@ -2805,7 +2729,7 @@ static int vino_int_enum_input(struct vino_channel_settings *vcs, __u32 index)
2805 input = VINO_INPUT_SVIDEO; 2729 input = VINO_INPUT_SVIDEO;
2806 break; 2730 break;
2807 } 2731 }
2808 } else if (vino_drvdata->camera.driver) { 2732 } else if (vino_drvdata->camera) {
2809 switch (index) { 2733 switch (index) {
2810 case 0: 2734 case 0:
2811 input = VINO_INPUT_D1; 2735 input = VINO_INPUT_D1;
@@ -2823,7 +2747,7 @@ static __u32 vino_find_input_index(struct vino_channel_settings *vcs)
2823 __u32 index = 0; 2747 __u32 index = 0;
2824 // FIXME: detect when no inputs available 2748 // FIXME: detect when no inputs available
2825 2749
2826 if (vino_drvdata->decoder.driver && vino_drvdata->camera.driver) { 2750 if (vino_drvdata->decoder && vino_drvdata->camera) {
2827 switch (vcs->input) { 2751 switch (vcs->input) {
2828 case VINO_INPUT_COMPOSITE: 2752 case VINO_INPUT_COMPOSITE:
2829 index = 0; 2753 index = 0;
@@ -2835,7 +2759,7 @@ static __u32 vino_find_input_index(struct vino_channel_settings *vcs)
2835 index = 2; 2759 index = 2;
2836 break; 2760 break;
2837 } 2761 }
2838 } else if (vino_drvdata->decoder.driver) { 2762 } else if (vino_drvdata->decoder) {
2839 switch (vcs->input) { 2763 switch (vcs->input) {
2840 case VINO_INPUT_COMPOSITE: 2764 case VINO_INPUT_COMPOSITE:
2841 index = 0; 2765 index = 0;
@@ -2844,7 +2768,7 @@ static __u32 vino_find_input_index(struct vino_channel_settings *vcs)
2844 index = 1; 2768 index = 1;
2845 break; 2769 break;
2846 } 2770 }
2847 } else if (vino_drvdata->camera.driver) { 2771 } else if (vino_drvdata->camera) {
2848 switch (vcs->input) { 2772 switch (vcs->input) {
2849 case VINO_INPUT_D1: 2773 case VINO_INPUT_D1:
2850 index = 0; 2774 index = 0;
@@ -2893,7 +2817,7 @@ static int vino_enum_input(struct file *file, void *__fh,
2893 strcpy(i->name, vino_inputs[input].name); 2817 strcpy(i->name, vino_inputs[input].name);
2894 2818
2895 if (input == VINO_INPUT_COMPOSITE || input == VINO_INPUT_SVIDEO) 2819 if (input == VINO_INPUT_COMPOSITE || input == VINO_INPUT_SVIDEO)
2896 i2c_decoder_command(VIDIOC_INT_G_INPUT_STATUS, &i->status); 2820 decoder_call(video, g_input_status, &i->status);
2897 return 0; 2821 return 0;
2898} 2822}
2899 2823
@@ -2950,7 +2874,7 @@ static int vino_querystd(struct file *file, void *__fh,
2950 break; 2874 break;
2951 case VINO_INPUT_COMPOSITE: 2875 case VINO_INPUT_COMPOSITE:
2952 case VINO_INPUT_SVIDEO: { 2876 case VINO_INPUT_SVIDEO: {
2953 i2c_decoder_command(VIDIOC_QUERYSTD, std); 2877 decoder_call(video, querystd, std);
2954 break; 2878 break;
2955 } 2879 }
2956 default: 2880 default:
@@ -3679,7 +3603,7 @@ static int vino_g_ctrl(struct file *file, void *__fh,
3679 if (err) 3603 if (err)
3680 goto out; 3604 goto out;
3681 3605
3682 err = i2c_camera_command(VIDIOC_G_CTRL, &control); 3606 err = camera_call(core, g_ctrl, control);
3683 if (err) 3607 if (err)
3684 err = -EINVAL; 3608 err = -EINVAL;
3685 break; 3609 break;
@@ -3697,7 +3621,7 @@ static int vino_g_ctrl(struct file *file, void *__fh,
3697 if (err) 3621 if (err)
3698 goto out; 3622 goto out;
3699 3623
3700 err = i2c_decoder_command(VIDIOC_G_CTRL, &control); 3624 err = decoder_call(core, g_ctrl, control);
3701 if (err) 3625 if (err)
3702 err = -EINVAL; 3626 err = -EINVAL;
3703 break; 3627 break;
@@ -3743,7 +3667,7 @@ static int vino_s_ctrl(struct file *file, void *__fh,
3743 err = -ERANGE; 3667 err = -ERANGE;
3744 goto out; 3668 goto out;
3745 } 3669 }
3746 err = i2c_camera_command(VIDIOC_S_CTRL, &control); 3670 err = camera_call(core, s_ctrl, control);
3747 if (err) 3671 if (err)
3748 err = -EINVAL; 3672 err = -EINVAL;
3749 break; 3673 break;
@@ -3765,7 +3689,7 @@ static int vino_s_ctrl(struct file *file, void *__fh,
3765 goto out; 3689 goto out;
3766 } 3690 }
3767 3691
3768 err = i2c_decoder_command(VIDIOC_S_CTRL, &control); 3692 err = decoder_call(core, s_ctrl, control);
3769 if (err) 3693 if (err)
3770 err = -EINVAL; 3694 err = -EINVAL;
3771 break; 3695 break;
@@ -4257,6 +4181,7 @@ static int vino_init_channel_settings(struct vino_channel_settings *vcs,
4257 4181
4258static int __init vino_module_init(void) 4182static int __init vino_module_init(void)
4259{ 4183{
4184 unsigned short addr[] = { 0, I2C_CLIENT_END };
4260 int ret; 4185 int ret;
4261 4186
4262 printk(KERN_INFO "SGI VINO driver version %s\n", 4187 printk(KERN_INFO "SGI VINO driver version %s\n",
@@ -4326,10 +4251,12 @@ static int __init vino_module_init(void)
4326 } 4251 }
4327 vino_init_stage++; 4252 vino_init_stage++;
4328 4253
4329#ifdef MODULE 4254 addr[0] = 0x45;
4330 request_module("saa7191"); 4255 vino_drvdata->decoder = v4l2_i2c_new_probed_subdev(&vino_i2c_adapter,
4331 request_module("indycam"); 4256 "saa7191", "saa7191", addr);
4332#endif 4257 addr[0] = 0x2b;
4258 vino_drvdata->camera = v4l2_i2c_new_probed_subdev(&vino_i2c_adapter,
4259 "indycam", "indycam", addr);
4333 4260
4334 dprintk("init complete!\n"); 4261 dprintk("init complete!\n");
4335 4262