Commit fa20baa5 authored by lucabe's avatar lucabe

Add support for drivers that can change the capture size on VIDIOC_S_FMT


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@5076 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 75ca8c51
...@@ -148,17 +148,25 @@ static int device_open(const char *devname, uint32_t *capabilities) ...@@ -148,17 +148,25 @@ static int device_open(const char *devname, uint32_t *capabilities)
return fd; return fd;
} }
static int device_init(int fd, int width, int height, int pix_fmt) static int device_init(int fd, int *width, int *height, int pix_fmt)
{ {
struct v4l2_format fmt; struct v4l2_format fmt;
int res;
memset(&fmt, 0, sizeof(struct v4l2_format)); memset(&fmt, 0, sizeof(struct v4l2_format));
fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
fmt.fmt.pix.width = width; fmt.fmt.pix.width = *width;
fmt.fmt.pix.height = height; fmt.fmt.pix.height = *height;
fmt.fmt.pix.pixelformat = pix_fmt; fmt.fmt.pix.pixelformat = pix_fmt;
fmt.fmt.pix.field = V4L2_FIELD_INTERLACED; fmt.fmt.pix.field = V4L2_FIELD_INTERLACED;
return ioctl (fd, VIDIOC_S_FMT, &fmt); res = ioctl(fd, VIDIOC_S_FMT, &fmt);
if ((*width != fmt.fmt.pix.width) || (*height != fmt.fmt.pix.height)) {
av_log(NULL, AV_LOG_INFO, "The V4L2 driver changed the video from %dx%d to %dx%d\n", *width, *height, fmt.fmt.pix.width, fmt.fmt.pix.height);
*width = fmt.fmt.pix.width;
*height = fmt.fmt.pix.height;
}
return res;
} }
static int first_field(int fd) static int first_field(int fd)
...@@ -418,13 +426,13 @@ static int v4l2_read_header(AVFormatContext *s1, AVFormatParameters *ap) ...@@ -418,13 +426,13 @@ static int v4l2_read_header(AVFormatContext *s1, AVFormatParameters *ap)
av_log(s1, AV_LOG_ERROR, "[%d]Capabilities: %x\n", s->fd, capabilities); av_log(s1, AV_LOG_ERROR, "[%d]Capabilities: %x\n", s->fd, capabilities);
desired_format = fmt_ff2v4l(ap->pix_fmt); desired_format = fmt_ff2v4l(ap->pix_fmt);
if (desired_format == 0 || (device_init(s->fd, width, height, desired_format) < 0)) { if (desired_format == 0 || (device_init(s->fd, &width, &height, desired_format) < 0)) {
int i, done; int i, done;
done = 0; i = 0; done = 0; i = 0;
while (!done) { while (!done) {
desired_format = fmt_conversion_table[i].v4l2_fmt; desired_format = fmt_conversion_table[i].v4l2_fmt;
if (device_init(s->fd, width, height, desired_format) < 0) { if (device_init(s->fd, &width, &height, desired_format) < 0) {
desired_format = 0; desired_format = 0;
i++; i++;
} else { } else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment