Add camera_t
This commit is contained in:
parent
0dd713fcaa
commit
94df5c155c
58
cmd/camera.c
Normal file
58
cmd/camera.c
Normal file
@ -0,0 +1,58 @@
|
||||
#include "camera.h"
|
||||
|
||||
#include "hw/device.h"
|
||||
#include "hw/links.h"
|
||||
#include "hw/v4l2.h"
|
||||
|
||||
void camera_init(camera_t *camera)
|
||||
{
|
||||
memset(camera, 0, sizeof(*camera));
|
||||
camera->width = 2328;
|
||||
camera->height = 1748;
|
||||
camera->nbufs = 4;
|
||||
}
|
||||
|
||||
void camera_close(camera_t *camera)
|
||||
{
|
||||
for (int i = MAX_DEVICES; i-- > 0; ) {
|
||||
if (camera->devices[i]) {
|
||||
device_close(camera->devices[i]);
|
||||
camera->devices[i] = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
memset(camera->links, 0, sizeof(camera->links));
|
||||
}
|
||||
|
||||
int camera_open(camera_t *camera, const char *path)
|
||||
{
|
||||
camera->camera = device_open("CAMERA", path);
|
||||
if (!camera->camera) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
return 0;;
|
||||
}
|
||||
|
||||
int camera_set_params(camera_t *camera)
|
||||
{
|
||||
DEVICE_SET_OPTION(camera->camera, EXPOSURE, 1148);
|
||||
DEVICE_SET_OPTION(camera->camera, ANALOGUE_GAIN, 938);
|
||||
DEVICE_SET_OPTION(camera->camera, DIGITAL_GAIN, 256);
|
||||
|
||||
DEVICE_SET_OPTION2(camera->codec_jpeg, JPEG, COMPRESSION_QUALITY, 80);
|
||||
|
||||
DEVICE_SET_OPTION2(camera->codec_h264, MPEG_VIDEO, BITRATE, 5000 * 1000);
|
||||
DEVICE_SET_OPTION2(camera->codec_h264, MPEG_VIDEO, H264_I_PERIOD, 30);
|
||||
DEVICE_SET_OPTION2(camera->codec_h264, MPEG_VIDEO, H264_LEVEL, V4L2_MPEG_VIDEO_H264_LEVEL_4_0);
|
||||
DEVICE_SET_OPTION2(camera->codec_h264, MPEG_VIDEO, REPEAT_SEQ_HEADER, 1);
|
||||
DEVICE_SET_OPTION2(camera->codec_h264, MPEG_VIDEO, H264_MIN_QP, 16);
|
||||
DEVICE_SET_OPTION2(camera->codec_h264, MPEG_VIDEO, H264_MIN_QP, 32);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int camera_run(camera_t *camera)
|
||||
{
|
||||
bool running = false;
|
||||
return links_loop(camera->links, &running);
|
||||
}
|
49
cmd/camera.h
Normal file
49
cmd/camera.h
Normal file
@ -0,0 +1,49 @@
|
||||
#pragma once
|
||||
|
||||
#include "hw/links.h"
|
||||
#include "hw/device.h"
|
||||
|
||||
#define MAX_DEVICES 20
|
||||
#define MAX_HTTP_METHODS 20
|
||||
|
||||
#define CAMERA_DEVICE_CAMERA 0
|
||||
|
||||
typedef struct camera_s {
|
||||
union {
|
||||
device_t *devices[MAX_DEVICES];
|
||||
struct {
|
||||
device_t *camera;
|
||||
|
||||
struct {
|
||||
device_t *codec_jpeg;
|
||||
device_t *codec_h264;
|
||||
};
|
||||
|
||||
union {
|
||||
struct {
|
||||
device_t *isp_srgb;
|
||||
device_t *isp_yuuv;
|
||||
device_t *isp_yuuv_low;
|
||||
} isp;
|
||||
|
||||
struct {
|
||||
device_t *isp;
|
||||
} legacy_isp;
|
||||
};
|
||||
};
|
||||
};
|
||||
link_t links[MAX_DEVICES];
|
||||
|
||||
unsigned width, height;
|
||||
unsigned nbufs;
|
||||
} camera_t;
|
||||
|
||||
#define CAMERA(DEVICE) camera->devices[DEVICE]
|
||||
|
||||
void camera_init(camera_t *camera);
|
||||
void camera_close(camera_t *camera);
|
||||
int camera_open(camera_t *camera, const char *path);
|
||||
int camera_configure_srgb_isp(camera_t *camera, bool use_half);
|
||||
int camera_configure_srgb_legacy_isp(camera_t *camera);
|
||||
int camera_set_params(camera_t *camera);
|
||||
int camera_run(camera_t *camera);
|
71
cmd/camera_srgb_isp.c
Normal file
71
cmd/camera_srgb_isp.c
Normal file
@ -0,0 +1,71 @@
|
||||
#include "camera.h"
|
||||
|
||||
#include "hw/buffer.h"
|
||||
#include "hw/buffer_list.h"
|
||||
#include "hw/device.h"
|
||||
#include "hw/links.h"
|
||||
#include "hw/v4l2.h"
|
||||
#include "hw/buffer_list.h"
|
||||
#include "http/http.h"
|
||||
|
||||
extern bool check_streaming();
|
||||
|
||||
int camera_configure_srgb_isp(camera_t *camera, bool use_half)
|
||||
{
|
||||
if (device_open_buffer_list(camera->camera, true, camera->width, camera->height, V4L2_PIX_FMT_SRGGB10P, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
buffer_list_t *src = camera->camera->capture_list;
|
||||
|
||||
camera->isp.isp_srgb = device_open("ISP", "/dev/video13");
|
||||
camera->isp.isp_yuuv = device_open("ISP-YUUV", "/dev/video14");
|
||||
camera->codec_jpeg = device_open("JPEG", "/dev/video31");
|
||||
camera->codec_h264 = device_open("H264", "/dev/video11");
|
||||
|
||||
if (device_open_buffer_list(camera->isp.isp_srgb, false, src->fmt_width, src->fmt_height, src->fmt_format, camera->nbufs) < 0 ||
|
||||
device_open_buffer_list(camera->isp.isp_yuuv, true, src->fmt_width, src->fmt_height, V4L2_PIX_FMT_YUYV, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (use_half) {
|
||||
camera->isp.isp_yuuv_low = device_open("ISP-YUUV-LOW", "/dev/video15");
|
||||
|
||||
if (device_open_buffer_list(camera->isp.isp_yuuv_low, true, src->fmt_width / 2, src->fmt_height / 2, V4L2_PIX_FMT_YUYV, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
src = camera->isp.isp_yuuv_low->capture_list;
|
||||
} else {
|
||||
src = camera->isp.isp_yuuv->capture_list;
|
||||
}
|
||||
|
||||
if (device_open_buffer_list(camera->codec_jpeg, false, src->fmt_width, src->fmt_height, src->fmt_format, camera->nbufs) < 0 ||
|
||||
device_open_buffer_list(camera->codec_jpeg, true, src->fmt_width, src->fmt_height, V4L2_PIX_FMT_JPEG, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (device_open_buffer_list(camera->codec_h264, false, src->fmt_width, src->fmt_height, src->fmt_format, camera->nbufs) < 0 ||
|
||||
device_open_buffer_list(camera->codec_h264, true, src->fmt_width, src->fmt_height, V4L2_PIX_FMT_H264, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
DEVICE_SET_OPTION(camera->isp.isp_srgb, RED_BALANCE, 2120);
|
||||
DEVICE_SET_OPTION(camera->isp.isp_srgb, BLUE_BALANCE, 1472);
|
||||
DEVICE_SET_OPTION(camera->isp.isp_srgb, DIGITAL_GAIN, 1007);
|
||||
|
||||
link_t *links = camera->links;
|
||||
|
||||
*links++ = (link_t){ camera->camera, { camera->isp.isp_srgb }, { NULL, check_streaming } };
|
||||
|
||||
if (use_half) {
|
||||
*links++ = (link_t){ camera->isp.isp_yuuv, { } };
|
||||
*links++ = (link_t){ camera->isp.isp_yuuv_low, { camera->codec_jpeg, camera->codec_h264 } };
|
||||
} else {
|
||||
*links++ = (link_t){ camera->isp.isp_yuuv, { camera->codec_jpeg, camera->codec_h264 } };
|
||||
}
|
||||
|
||||
*links++ = (link_t){ camera->codec_jpeg, { }, { http_jpeg_capture, http_jpeg_needs_buffer } };
|
||||
*links++ = (link_t){ camera->codec_h264, { }, { http_h264_capture, http_h264_needs_buffer } };
|
||||
return 0;
|
||||
}
|
48
cmd/camera_srgb_legacy_isp.c
Normal file
48
cmd/camera_srgb_legacy_isp.c
Normal file
@ -0,0 +1,48 @@
|
||||
#include "camera.h"
|
||||
|
||||
#include "hw/buffer.h"
|
||||
#include "hw/buffer_list.h"
|
||||
#include "hw/device.h"
|
||||
#include "hw/links.h"
|
||||
#include "hw/v4l2.h"
|
||||
#include "hw/buffer_list.h"
|
||||
#include "http/http.h"
|
||||
|
||||
extern bool check_streaming();
|
||||
|
||||
int camera_configure_srgb_legacy_isp(camera_t *camera)
|
||||
{
|
||||
if (device_open_buffer_list(camera->camera, true, camera->width, camera->height, V4L2_PIX_FMT_SRGGB10P, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
buffer_list_t *src = camera->camera->capture_list;
|
||||
|
||||
camera->legacy_isp.isp = device_open("ISP", "/dev/video12");
|
||||
camera->codec_jpeg = device_open("JPEG", "/dev/video31");
|
||||
camera->codec_h264 = device_open("H264", "/dev/video11");
|
||||
|
||||
if (device_open_buffer_list(camera->legacy_isp.isp, false, src->fmt_width, src->fmt_height, src->fmt_format, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
src = camera->legacy_isp.isp->capture_list;
|
||||
|
||||
if (device_open_buffer_list(camera->codec_jpeg, false, src->fmt_width, src->fmt_height, src->fmt_format, camera->nbufs) < 0 ||
|
||||
device_open_buffer_list(camera->codec_jpeg, true, src->fmt_width, src->fmt_height, V4L2_PIX_FMT_JPEG, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (device_open_buffer_list(camera->codec_h264, false, src->fmt_width, src->fmt_height, src->fmt_format, camera->nbufs) < 0 ||
|
||||
device_open_buffer_list(camera->codec_h264, true, src->fmt_width, src->fmt_height, V4L2_PIX_FMT_H264, camera->nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
link_t *links = camera->links;
|
||||
|
||||
*links++ = (link_t){ camera->camera, { camera->legacy_isp.isp }, { NULL, check_streaming } };
|
||||
*links++ = (link_t){ camera->legacy_isp.isp, { camera->codec_jpeg, camera->codec_h264 } };
|
||||
*links++ = (link_t){ camera->codec_jpeg, { }, { http_jpeg_capture, http_jpeg_needs_buffer } };
|
||||
*links++ = (link_t){ camera->codec_h264, { }, { http_h264_capture, http_h264_needs_buffer } };
|
||||
return 0;
|
||||
}
|
59
cmd/main.c
Normal file
59
cmd/main.c
Normal file
@ -0,0 +1,59 @@
|
||||
#include "hw/buffer.h"
|
||||
#include "hw/buffer_list.h"
|
||||
#include "hw/device.h"
|
||||
#include "hw/links.h"
|
||||
#include "hw/v4l2.h"
|
||||
#include "http/http.h"
|
||||
#include "camera.h"
|
||||
|
||||
#include <signal.h>
|
||||
|
||||
http_method_t http_methods[] = {
|
||||
{ "GET / ", http_index },
|
||||
{ "GET /snapshot ", http_snapshot },
|
||||
{ "GET /stream ", http_stream },
|
||||
{ "GET /?action=snapshot ", http_snapshot },
|
||||
{ "GET /?action=stream ", http_stream },
|
||||
{ "GET /video ", http_video_html },
|
||||
{ "GET /video.h264 ", http_video },
|
||||
{ "GET /jmuxer.min.js ", http_jmuxer_js },
|
||||
{ NULL, NULL }
|
||||
};
|
||||
|
||||
bool check_streaming()
|
||||
{
|
||||
return http_jpeg_needs_buffer() || http_h264_needs_buffer();
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
camera_t camera;
|
||||
int http_fd = -1;
|
||||
int ret = -1;
|
||||
|
||||
camera_init(&camera);
|
||||
|
||||
if (camera_open(&camera, "/dev/video0") < 0) {
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (camera_configure_srgb_isp(&camera, true) < 0) {
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (camera_set_params(&camera) < 0) {
|
||||
goto error;
|
||||
}
|
||||
|
||||
http_fd = http_server(9092, 5, http_methods);
|
||||
if (http_fd < 0) {
|
||||
goto error;
|
||||
}
|
||||
|
||||
ret = camera_run(&camera);
|
||||
|
||||
error:
|
||||
close(http_fd);
|
||||
camera_close(&camera);
|
||||
return ret;
|
||||
}
|
174
cmd/main_isp13.c
174
cmd/main_isp13.c
@ -1,174 +0,0 @@
|
||||
#include "hw/buffer.h"
|
||||
#include "hw/buffer_list.h"
|
||||
#include "hw/device.h"
|
||||
#include "hw/links.h"
|
||||
#include "hw/v4l2.h"
|
||||
#include "http/http.h"
|
||||
|
||||
#include <signal.h>
|
||||
|
||||
int camera_width = 2328;
|
||||
int camera_height = 1748;
|
||||
int camera_format = V4L2_PIX_FMT_SRGGB10P;
|
||||
int camera_nbufs = 1;
|
||||
bool camera_use_low = true;
|
||||
|
||||
device_t *camera = NULL;
|
||||
device_t *isp_srgb = NULL;
|
||||
device_t *isp_yuuv = NULL;
|
||||
device_t *isp_yuuv_low = NULL;
|
||||
device_t *codec_jpeg = NULL;
|
||||
device_t *codec_h264 = NULL;
|
||||
|
||||
int open_isp(buffer_list_t *src, const char *srgb_path, const char *yuuv_path, const char *yuuv_low_path)
|
||||
{
|
||||
DEVICE_SET_OPTION(isp_srgb, RED_BALANCE, 2120);
|
||||
DEVICE_SET_OPTION(isp_srgb, BLUE_BALANCE, 1472);
|
||||
DEVICE_SET_OPTION(isp_srgb, DIGITAL_GAIN, 1007);
|
||||
|
||||
if (device_open_buffer_list(isp_srgb, false, src->fmt_width, src->fmt_height, src->fmt_format, camera_nbufs) < 0 ||
|
||||
device_open_buffer_list(isp_yuuv, true, src->fmt_width, src->fmt_height, V4L2_PIX_FMT_YUYV, camera_nbufs) < 0 ||
|
||||
device_open_buffer_list(isp_yuuv_low, true, src->fmt_width / 2, src->fmt_height / 2, V4L2_PIX_FMT_YUYV, camera_nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int open_jpeg(buffer_list_t *src, const char *tmp)
|
||||
{
|
||||
DEVICE_SET_OPTION2(codec_jpeg, JPEG, COMPRESSION_QUALITY, 80);
|
||||
|
||||
if (device_open_buffer_list(codec_jpeg, false, src->fmt_width, src->fmt_height, src->fmt_format, camera_nbufs) < 0 ||
|
||||
device_open_buffer_list(codec_jpeg, true, codec_jpeg->output_list->fmt_width, codec_jpeg->output_list->fmt_height, V4L2_PIX_FMT_JPEG, camera_nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int open_h264(buffer_list_t *src, const char *tmp)
|
||||
{
|
||||
DEVICE_SET_OPTION2(codec_h264, MPEG_VIDEO, BITRATE, 5000 * 1000);
|
||||
DEVICE_SET_OPTION2(codec_h264, MPEG_VIDEO, H264_I_PERIOD, 30);
|
||||
DEVICE_SET_OPTION2(codec_h264, MPEG_VIDEO, H264_LEVEL, V4L2_MPEG_VIDEO_H264_LEVEL_4_0);
|
||||
DEVICE_SET_OPTION2(codec_h264, MPEG_VIDEO, REPEAT_SEQ_HEADER, 1);
|
||||
DEVICE_SET_OPTION2(codec_h264, MPEG_VIDEO, H264_MIN_QP, 16);
|
||||
DEVICE_SET_OPTION2(codec_h264, MPEG_VIDEO, H264_MIN_QP, 32);
|
||||
|
||||
if (device_open_buffer_list(codec_h264, false, src->fmt_width, src->fmt_height, src->fmt_format, camera_nbufs) < 0 ||
|
||||
device_open_buffer_list(codec_h264, true, src->fmt_width, src->fmt_height, V4L2_PIX_FMT_H264, camera_nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int open_camera()
|
||||
{
|
||||
camera = device_open("CAMERA", "/dev/video0");
|
||||
|
||||
if (device_open_buffer_list(camera, true, camera_width, camera_height, camera_format, camera_nbufs) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
DEVICE_SET_OPTION(camera, EXPOSURE, 1148);
|
||||
DEVICE_SET_OPTION(camera, ANALOGUE_GAIN, 938);
|
||||
DEVICE_SET_OPTION(camera, DIGITAL_GAIN, 256);
|
||||
|
||||
isp_srgb = device_open("ISP-SRGB", "/dev/video13");
|
||||
//isp_srgb->allow_dma = false;
|
||||
isp_yuuv = device_open("ISP-YUUV", "/dev/video14");
|
||||
isp_yuuv->output_device = isp_srgb;
|
||||
isp_yuuv_low = device_open("ISP-YUUV-LOW", "/dev/video15");
|
||||
isp_yuuv_low->output_device = isp_srgb;
|
||||
codec_jpeg = device_open("JPEG", "/dev/video31");
|
||||
//codec_jpeg->allow_dma = false;
|
||||
codec_h264 = device_open("H264", "/dev/video11");
|
||||
//codec_h264->allow_dma = false;
|
||||
|
||||
if (open_isp(camera->capture_list, "/dev/video13", "/dev/video14", "/dev/video15") < 0) {
|
||||
return -1;
|
||||
}
|
||||
if (open_jpeg(camera_use_low ? isp_yuuv_low->capture_list : isp_yuuv->capture_list, "/dev/video31") < 0) {
|
||||
return -1;
|
||||
}
|
||||
if (open_h264(camera_use_low ? isp_yuuv_low->capture_list : isp_yuuv->capture_list, "/dev/video11") < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
bool check_streaming()
|
||||
{
|
||||
return http_jpeg_needs_buffer() || http_h264_needs_buffer();
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
if (open_camera() < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
link_t links[] = {
|
||||
{
|
||||
camera,
|
||||
{ isp_srgb },
|
||||
{ NULL, check_streaming }
|
||||
},
|
||||
{
|
||||
isp_yuuv,
|
||||
{
|
||||
camera_use_low ? NULL : codec_jpeg,
|
||||
//camera_use_low ? NULL : codec_h264,
|
||||
},
|
||||
{ NULL, NULL }
|
||||
},
|
||||
{
|
||||
isp_yuuv_low,
|
||||
{
|
||||
camera_use_low ? codec_jpeg : NULL,
|
||||
//camera_use_low ? codec_h264 : NULL,
|
||||
},
|
||||
{ NULL, NULL }
|
||||
},
|
||||
{
|
||||
codec_jpeg,
|
||||
{ },
|
||||
{ http_jpeg_capture, http_jpeg_needs_buffer }
|
||||
},
|
||||
{
|
||||
// codec_h264,
|
||||
// { },
|
||||
// { http_h264_capture, http_h264_needs_buffer }
|
||||
},
|
||||
{ NULL }
|
||||
};
|
||||
|
||||
http_method_t http_methods[] = {
|
||||
{ "GET / ", http_index },
|
||||
{ "GET /snapshot ", http_snapshot },
|
||||
{ "GET /stream ", http_stream },
|
||||
{ "GET /?action=snapshot ", http_snapshot },
|
||||
{ "GET /?action=stream ", http_stream },
|
||||
{ "GET /video ", http_video_html },
|
||||
{ "GET /video.h264 ", http_video },
|
||||
{ "GET /jmuxer.min.js ", http_jmuxer_js },
|
||||
{ NULL, NULL }
|
||||
};
|
||||
|
||||
sigaction(SIGPIPE, &(struct sigaction){SIG_IGN}, NULL);
|
||||
|
||||
int http_fd = http_server(9092, 5, http_methods);
|
||||
|
||||
bool running = false;
|
||||
links_loop(links, &running);
|
||||
|
||||
close(http_fd);
|
||||
|
||||
error:
|
||||
device_close(isp_yuuv_low);
|
||||
device_close(isp_yuuv);
|
||||
device_close(isp_srgb);
|
||||
device_close(camera);
|
||||
return 0;
|
||||
}
|
@ -7,6 +7,8 @@
|
||||
#include <netinet/ip.h>
|
||||
#include <netinet/tcp.h>
|
||||
#include <arpa/inet.h>
|
||||
#include <pthread.h>
|
||||
#include <signal.h>
|
||||
|
||||
#include "http/http.h"
|
||||
|
||||
@ -127,6 +129,8 @@ int http_server(int listen_port, int maxcons, http_method_t *methods)
|
||||
return -1;
|
||||
}
|
||||
|
||||
sigaction(SIGPIPE, &(struct sigaction){ SIG_IGN }, NULL);
|
||||
|
||||
while (maxcons-- > 0) {
|
||||
char name[20];
|
||||
sprintf(name, "HTTP%d/%d", listen_port, maxcons);
|
||||
|
22
hw/device.c
22
hw/device.c
@ -56,6 +56,10 @@ int device_open_buffer_list(device_t *dev, bool do_capture, unsigned width, unsi
|
||||
struct buffer_list_s **buf_list = NULL;
|
||||
bool do_mmap = false;
|
||||
|
||||
if (!dev) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (do_capture) {
|
||||
buf_list = &dev->capture_list;
|
||||
do_mmap = true;
|
||||
@ -134,6 +138,10 @@ int device_consume_event(device_t *dev)
|
||||
{
|
||||
struct v4l2_event event;
|
||||
|
||||
if (!dev) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
E_LOG_DEBUG(dev, "Consuming V4L2 event ...");
|
||||
E_XIOCTL(dev, dev->fd, VIDIOC_DQEVENT, &event, "Got some V4L2 device event, but where is it?");
|
||||
|
||||
@ -154,6 +162,10 @@ error:
|
||||
|
||||
int device_video_force_key(device_t *dev)
|
||||
{
|
||||
if (!dev) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
struct v4l2_control ctl = {0};
|
||||
ctl.id = V4L2_CID_MPEG_VIDEO_FORCE_KEY_FRAME;
|
||||
ctl.value = 1;
|
||||
@ -167,6 +179,11 @@ error:
|
||||
int device_set_fps(device_t *dev, int desired_fps)
|
||||
{
|
||||
struct v4l2_streamparm setfps = {0};
|
||||
|
||||
if (!dev) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
setfps.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
|
||||
setfps.parm.output.timeperframe.numerator = 1;
|
||||
setfps.parm.output.timeperframe.denominator = desired_fps;
|
||||
@ -180,6 +197,11 @@ error:
|
||||
int device_set_option(device_t *dev, const char *name, uint32_t id, int32_t value)
|
||||
{
|
||||
struct v4l2_control ctl = {0};
|
||||
|
||||
if (!dev) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
ctl.id = id;
|
||||
ctl.value = value;
|
||||
E_LOG_DEBUG(dev, "Configuring option %s (%08x) = %d", name, id, value);
|
||||
|
@ -2,7 +2,9 @@
|
||||
|
||||
#include "v4l2.h"
|
||||
|
||||
typedef void (*link_on_buffer)(struct buffer_s *buf);
|
||||
typedef struct buffer_s buffer_t;
|
||||
|
||||
typedef void (*link_on_buffer)(buffer_t *buf);
|
||||
typedef bool (*link_check_streaming)();
|
||||
|
||||
typedef struct link_s {
|
||||
|
Loading…
x
Reference in New Issue
Block a user