summaryrefslogtreecommitdiff
path: root/libavdevice
diff options
context:
space:
mode:
authorAnton Khirnov <anton@khirnov.net>2011-05-23 21:53:44 +0200
committerAnton Khirnov <anton@khirnov.net>2011-05-25 15:55:47 +0200
commita02fd06ab76c0abd7ef32f332a08177e6014b3a8 (patch)
tree117bec77b50e389adbdd8ceb38be64b5df95d479 /libavdevice
parentfc68a8f7030227fc4fa8d83b9051aaf598cd12dd (diff)
v4l2: add a private option for channel.
Diffstat (limited to 'libavdevice')
-rw-r--r--libavdevice/v4l2.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/libavdevice/v4l2.c b/libavdevice/v4l2.c
index 1c3059d850..59af2c83ec 100644
--- a/libavdevice/v4l2.c
+++ b/libavdevice/v4l2.c
@@ -68,6 +68,7 @@ struct video_data {
void **buf_start;
unsigned int *buf_len;
char *standard;
+ int channel;
};
struct buff_data {
@@ -452,23 +453,24 @@ static int v4l2_set_parameters(AVFormatContext *s1, AVFormatParameters *ap)
streamparm.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
- if (ap->channel>=0) {
+ if (ap->channel > 0)
+ s->channel = ap->channel;
+
/* set tv video input */
memset (&input, 0, sizeof (input));
- input.index = ap->channel;
+ input.index = s->channel;
if (ioctl(s->fd, VIDIOC_ENUMINPUT, &input) < 0) {
av_log(s1, AV_LOG_ERROR, "The V4L2 driver ioctl enum input failed:\n");
return AVERROR(EIO);
}
av_log(s1, AV_LOG_DEBUG, "The V4L2 driver set input_id: %d, input: %s\n",
- ap->channel, input.name);
+ s->channel, input.name);
if (ioctl(s->fd, VIDIOC_S_INPUT, &input.index) < 0) {
av_log(s1, AV_LOG_ERROR, "The V4L2 driver ioctl set input(%d) failed\n",
- ap->channel);
+ s->channel);
return AVERROR(EIO);
}
- }
#if FF_API_FORMAT_PARAMETERS
if (ap->standard) {
@@ -694,6 +696,7 @@ static int v4l2_read_close(AVFormatContext *s1)
static const AVOption options[] = {
{ "standard", "", offsetof(struct video_data, standard), FF_OPT_TYPE_STRING, {.str = "NTSC" }, 0, 0, AV_OPT_FLAG_DECODING_PARAM },
+ { "channel", "", offsetof(struct video_data, channel), FF_OPT_TYPE_INT, {.dbl = 0 }, 0, INT_MAX, AV_OPT_FLAG_DECODING_PARAM },
{ NULL },
};