aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
authorHans Verkuil <hans.verkuil@cisco.com>2012-09-20 08:06:25 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2012-10-05 21:02:34 -0400
commit7aaad13124598580dbce98d33618e9356412274c (patch)
treeb1da481319dec1620a6836c81749fdec08ac003f /drivers/media
parent33bf1786602d819dc0467e77816dfa3f2a7e459d (diff)
[media] vpif_capture: move routing info from subdev to input
Routing information is a property of the input, not of the subdev. One subdev may provide multiple inputs, each with its own routing information. Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com> Acked-by: Sekhar Nori <nsekhar@ti.com> Acked-by: Lad, Prabhakar <prabhakar.lad@ti.com> Tested-by: Lad, Prabhakar <prabhakar.lad@ti.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/platform/davinci/vpif_capture.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/media/platform/davinci/vpif_capture.c b/drivers/media/platform/davinci/vpif_capture.c
index d90e23596541..d668a3aa5fe0 100644
--- a/drivers/media/platform/davinci/vpif_capture.c
+++ b/drivers/media/platform/davinci/vpif_capture.c
@@ -1464,6 +1464,9 @@ static int vpif_s_input(struct file *file, void *priv, unsigned int index)
1464 1464
1465 chan_cfg = &config->chan_config[ch->channel_id]; 1465 chan_cfg = &config->chan_config[ch->channel_id];
1466 1466
1467 if (index >= chan_cfg->input_count)
1468 return -EINVAL;
1469
1467 if (common->started) { 1470 if (common->started) {
1468 vpif_err("Streaming in progress\n"); 1471 vpif_err("Streaming in progress\n");
1469 return -EBUSY; 1472 return -EBUSY;
@@ -1502,8 +1505,8 @@ static int vpif_s_input(struct file *file, void *priv, unsigned int index)
1502 } 1505 }
1503 } 1506 }
1504 1507
1505 input = subdev_info->input; 1508 input = chan_cfg->inputs[index].input_route;
1506 output = subdev_info->output; 1509 output = chan_cfg->inputs[index].output_route;
1507 ret = v4l2_subdev_call(vpif_obj.sd[sd_index], video, s_routing, 1510 ret = v4l2_subdev_call(vpif_obj.sd[sd_index], video, s_routing,
1508 input, output, 0); 1511 input, output, 0);
1509 if (ret < 0 && ret != -ENOIOCTLCMD) { 1512 if (ret < 0 && ret != -ENOIOCTLCMD) {