Add http_server_options
This commit is contained in:
parent
9cf4cc359a
commit
4d3e8835ab
18
cmd/main.c
18
cmd/main.c
@ -20,6 +20,21 @@ http_method_t http_methods[] = {
|
||||
{ NULL, NULL }
|
||||
};
|
||||
|
||||
camera_options_t camera_options = {
|
||||
.path = "/dev/video0",
|
||||
.width = 1920,
|
||||
.height = 720,
|
||||
.format = 0,
|
||||
.nbufs = 4,
|
||||
.fps = 30,
|
||||
.allow_dma = true
|
||||
};
|
||||
|
||||
http_server_options_t http_server_options = {
|
||||
.listen_port = 9092,
|
||||
.maxcons = 10
|
||||
};
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
camera_t camera;
|
||||
@ -32,6 +47,7 @@ int main(int argc, char *argv[])
|
||||
}
|
||||
|
||||
camera_init(&camera);
|
||||
camera.options = camera_options;
|
||||
|
||||
//camera.width = 1920; camera.height = 1080;
|
||||
strcpy(camera.options.path, "/dev/video2"); camera.options.width = 2328; camera.options.height = 1748; camera.options.format = V4L2_PIX_FMT_SRGGB10P; // 1164x874
|
||||
@ -49,7 +65,7 @@ int main(int argc, char *argv[])
|
||||
goto error;
|
||||
}
|
||||
|
||||
http_fd = http_server(9092, 5, http_methods);
|
||||
http_fd = http_server(&http_server_options, http_methods);
|
||||
if (http_fd < 0) {
|
||||
goto error;
|
||||
}
|
||||
|
@ -122,18 +122,18 @@ error:
|
||||
return -1;
|
||||
}
|
||||
|
||||
int http_server(int listen_port, int maxcons, http_method_t *methods)
|
||||
int http_server(http_server_options_t *options, http_method_t *methods)
|
||||
{
|
||||
int listen_fd = http_listen(9092, maxcons);
|
||||
int listen_fd = http_listen(options->listen_port, options->maxcons);
|
||||
if (listen_fd < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
sigaction(SIGPIPE, &(struct sigaction){ SIG_IGN }, NULL);
|
||||
|
||||
while (maxcons-- > 0) {
|
||||
for (int worker = 0; worker < options->maxcons; worker++) {
|
||||
char name[20];
|
||||
sprintf(name, "HTTP%d/%d", listen_port, maxcons);
|
||||
sprintf(name, "HTTP%d/%d", options->listen_port, worker);
|
||||
|
||||
http_worker_t *worker = calloc(1, sizeof(http_worker_t));
|
||||
worker->name = strdup(name);
|
||||
|
@ -28,7 +28,12 @@ typedef struct http_worker_s {
|
||||
char client_method[256];
|
||||
} http_worker_t;
|
||||
|
||||
int http_server(int listen_port, int maxcons, http_method_t *methods);
|
||||
typedef struct http_server_options_s {
|
||||
int listen_port;
|
||||
int maxcons;
|
||||
} http_server_options_t;
|
||||
|
||||
int http_server(http_server_options_t *options, http_method_t *methods);
|
||||
|
||||
void http_index(http_worker_t *worker, FILE *stream);
|
||||
void http_video_html(http_worker_t *worker, FILE *stream);
|
||||
|
Loading…
x
Reference in New Issue
Block a user