|
|
@ -106,7 +106,7 @@ struct buff_data { |
|
|
|
int index; |
|
|
|
int index; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
static int device_open(AVFormatContext *ctx) |
|
|
|
static int device_open(AVFormatContext *ctx, const char* device_path) |
|
|
|
{ |
|
|
|
{ |
|
|
|
struct video_data *s = ctx->priv_data; |
|
|
|
struct video_data *s = ctx->priv_data; |
|
|
|
struct v4l2_capability cap; |
|
|
|
struct v4l2_capability cap; |
|
|
@ -147,11 +147,11 @@ static int device_open(AVFormatContext *ctx) |
|
|
|
flags |= O_NONBLOCK; |
|
|
|
flags |= O_NONBLOCK; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fd = v4l2_open(ctx->filename, flags, 0); |
|
|
|
fd = v4l2_open(device_path, flags, 0); |
|
|
|
if (fd < 0) { |
|
|
|
if (fd < 0) { |
|
|
|
err = AVERROR(errno); |
|
|
|
err = AVERROR(errno); |
|
|
|
av_log(ctx, AV_LOG_ERROR, "Cannot open video device %s: %s\n", |
|
|
|
av_log(ctx, AV_LOG_ERROR, "Cannot open video device %s: %s\n", |
|
|
|
ctx->filename, av_err2str(err)); |
|
|
|
device_path, av_err2str(err)); |
|
|
|
return err; |
|
|
|
return err; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -840,7 +840,7 @@ static int v4l2_read_header(AVFormatContext *ctx) |
|
|
|
v4l2_log_file = fopen("/dev/null", "w"); |
|
|
|
v4l2_log_file = fopen("/dev/null", "w"); |
|
|
|
#endif |
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
s->fd = device_open(ctx); |
|
|
|
s->fd = device_open(ctx, ctx->url); |
|
|
|
if (s->fd < 0) |
|
|
|
if (s->fd < 0) |
|
|
|
return s->fd; |
|
|
|
return s->fd; |
|
|
|
|
|
|
|
|
|
|
@ -1042,11 +1042,13 @@ static int v4l2_get_device_list(AVFormatContext *ctx, AVDeviceInfoList *device_l |
|
|
|
return ret; |
|
|
|
return ret; |
|
|
|
} |
|
|
|
} |
|
|
|
while ((entry = readdir(dir))) { |
|
|
|
while ((entry = readdir(dir))) { |
|
|
|
|
|
|
|
char device_name[256]; |
|
|
|
|
|
|
|
|
|
|
|
if (!v4l2_is_v4l_dev(entry->d_name)) |
|
|
|
if (!v4l2_is_v4l_dev(entry->d_name)) |
|
|
|
continue; |
|
|
|
continue; |
|
|
|
|
|
|
|
|
|
|
|
snprintf(ctx->filename, sizeof(ctx->filename), "/dev/%s", entry->d_name); |
|
|
|
snprintf(device_name, sizeof(device_name), "/dev/%s", entry->d_name); |
|
|
|
if ((s->fd = device_open(ctx)) < 0) |
|
|
|
if ((s->fd = device_open(ctx, device_name)) < 0) |
|
|
|
continue; |
|
|
|
continue; |
|
|
|
|
|
|
|
|
|
|
|
if (v4l2_ioctl(s->fd, VIDIOC_QUERYCAP, &cap) < 0) { |
|
|
|
if (v4l2_ioctl(s->fd, VIDIOC_QUERYCAP, &cap) < 0) { |
|
|
@ -1060,7 +1062,7 @@ static int v4l2_get_device_list(AVFormatContext *ctx, AVDeviceInfoList *device_l |
|
|
|
ret = AVERROR(ENOMEM); |
|
|
|
ret = AVERROR(ENOMEM); |
|
|
|
goto fail; |
|
|
|
goto fail; |
|
|
|
} |
|
|
|
} |
|
|
|
device->device_name = av_strdup(ctx->filename); |
|
|
|
device->device_name = av_strdup(device_name); |
|
|
|
device->device_description = av_strdup(cap.card); |
|
|
|
device->device_description = av_strdup(cap.card); |
|
|
|
if (!device->device_name || !device->device_description) { |
|
|
|
if (!device->device_name || !device->device_description) { |
|
|
|
ret = AVERROR(ENOMEM); |
|
|
|
ret = AVERROR(ENOMEM); |
|
|
|