Compare commits

..

2 Commits
v5.7 ... v5.8

Author SHA1 Message Date
Maxim Devaev
92a090dec3 Bump version: 5.7 → 5.8 2022-06-07 07:53:00 +03:00
Maxim Devaev
8b0ef8a271 renambed memsink.object to video.sink 2022-06-07 07:48:48 +03:00
8 changed files with 37 additions and 32 deletions

View File

@@ -1,7 +1,7 @@
[bumpversion] [bumpversion]
commit = True commit = True
tag = True tag = True
current_version = 5.7 current_version = 5.8
parse = (?P<major>\d+)\.(?P<minor>\d+) parse = (?P<major>\d+)\.(?P<minor>\d+)
serialize = serialize =
{major}.{minor} {major}.{minor}

View File

@@ -116,14 +116,15 @@ typedef struct _client_sx {
} _client_s; } _client_s;
static char *_g_memsink_obj = NULL; static char *_g_video_sink_name = NULL;
const long double _g_wait_timeout = 1; const long double _g_sink_wait_timeout = 1;
const long double _g_lock_timeout = 1; const long double _g_sink_lock_timeout = 1;
const useconds_t _g_lock_polling = 1000; const useconds_t _g_sink_lock_polling = 1000;
const useconds_t _g_watchers_polling = 100000;
static char *_g_audio_dev = NULL; static char *_g_audio_dev_name = NULL;
static char *_g_tc358743_dev = NULL; static char *_g_tc358743_dev_path = NULL;
const useconds_t _g_watchers_polling = 100000;
static _client_s *_g_clients = NULL; static _client_s *_g_clients = NULL;
static janus_callbacks *_g_gw = NULL; static janus_callbacks *_g_gw = NULL;
@@ -149,10 +150,10 @@ static atomic_bool _g_has_watchers = false;
static int _wait_frame(int fd, memsink_shared_s* mem, uint64_t last_id) { static int _wait_frame(int fd, memsink_shared_s* mem, uint64_t last_id) {
long double deadline_ts = get_now_monotonic() + _g_wait_timeout; long double deadline_ts = get_now_monotonic() + _g_sink_wait_timeout;
long double now; long double now;
do { do {
int result = flock_timedwait_monotonic(fd, _g_lock_timeout); int result = flock_timedwait_monotonic(fd, _g_sink_lock_timeout);
now = get_now_monotonic(); now = get_now_monotonic();
if (result < 0 && errno != EWOULDBLOCK) { if (result < 0 && errno != EWOULDBLOCK) {
JLOG_PERROR("video", "Can't lock memsink"); JLOG_PERROR("video", "Can't lock memsink");
@@ -166,7 +167,7 @@ static int _wait_frame(int fd, memsink_shared_s* mem, uint64_t last_id) {
return -1; return -1;
} }
} }
usleep(_g_lock_polling); usleep(_g_sink_lock_polling);
} while (now < deadline_ts); } while (now < deadline_ts);
return -2; return -2;
} }
@@ -225,7 +226,7 @@ static void *_clients_video_thread(UNUSED void *arg) {
int fd = -1; int fd = -1;
memsink_shared_s *mem = NULL; memsink_shared_s *mem = NULL;
if ((fd = shm_open(_g_memsink_obj, O_RDWR, 0)) <= 0) { if ((fd = shm_open(_g_video_sink_name, O_RDWR, 0)) <= 0) {
IF_NOT_REPORTED(2, { JLOG_PERROR("video", "Can't open memsink"); }); IF_NOT_REPORTED(2, { JLOG_PERROR("video", "Can't open memsink"); });
goto close_memsink; goto close_memsink;
} }
@@ -274,8 +275,8 @@ static void *_clients_video_thread(UNUSED void *arg) {
static void *_clients_audio_thread(UNUSED void *arg) { static void *_clients_audio_thread(UNUSED void *arg) {
A_THREAD_RENAME("us_a_clients"); A_THREAD_RENAME("us_a_clients");
atomic_store(&_g_audio_tid_created, true); atomic_store(&_g_audio_tid_created, true);
assert(_g_audio_dev); assert(_g_audio_dev_name);
assert(_g_tc358743_dev); assert(_g_tc358743_dev_path);
while (!STOP) { while (!STOP) {
if (!HAS_WATCHERS) { if (!HAS_WATCHERS) {
@@ -287,16 +288,16 @@ static void *_clients_audio_thread(UNUSED void *arg) {
audio_s *audio = NULL; audio_s *audio = NULL;
if ( if (
tc358743_read_info(_g_tc358743_dev, &info) < 0 tc358743_read_info(_g_tc358743_dev_path, &info) < 0
|| !info.has_audio || !info.has_audio
|| (audio = audio_init(_g_audio_dev, info.audio_hz)) == NULL || (audio = audio_init(_g_audio_dev_name, info.audio_hz)) == NULL
) { ) {
goto close_audio; goto close_audio;
} }
while (!STOP && HAS_WATCHERS) { while (!STOP && HAS_WATCHERS) {
if ( if (
tc358743_read_info(_g_tc358743_dev, &info) < 0 tc358743_read_info(_g_tc358743_dev_path, &info) < 0
|| !info.has_audio || !info.has_audio
|| audio->pcm_hz != info.audio_hz || audio->pcm_hz != info.audio_hz
) { ) {
@@ -335,6 +336,8 @@ static char *_get_config_value(janus_config *config, const char *section, const
} }
static int _read_config(const char *config_dir_path) { static int _read_config(const char *config_dir_path) {
int retval = 0;
char *config_file_path; char *config_file_path;
janus_config *config = NULL; janus_config *config = NULL;
@@ -348,19 +351,21 @@ static int _read_config(const char *config_dir_path) {
} }
janus_config_print(config); janus_config_print(config);
if ((_g_memsink_obj = _get_config_value(config, "memsink", "object")) == NULL) { if (
JLOG_ERROR("main", "Missing config value: memsink.object"); (_g_video_sink_name = _get_config_value(config, "memsink", "object")) == NULL
&& (_g_video_sink_name = _get_config_value(config, "video", "sink")) == NULL
) {
JLOG_ERROR("main", "Missing config value: video.sink (ex. memsink.object)");
goto error; goto error;
} }
if ((_g_audio_dev = _get_config_value(config, "audio", "device")) != NULL) { if ((_g_audio_dev_name = _get_config_value(config, "audio", "device")) != NULL) {
JLOG_INFO("main", "Enabled the experimental AUDIO feature"); JLOG_INFO("main", "Enabled the experimental AUDIO feature");
if ((_g_tc358743_dev = _get_config_value(config, "audio", "tc358743")) == NULL) { if ((_g_tc358743_dev_path = _get_config_value(config, "audio", "tc358743")) == NULL) {
JLOG_INFO("main", "Missing config value: audio.tc358743"); JLOG_INFO("main", "Missing config value: audio.tc358743");
goto error; goto error;
} }
} }
int retval = 0;
goto ok; goto ok;
error: error:
retval = -1; retval = -1;
@@ -389,7 +394,7 @@ static int _plugin_init(janus_callbacks *gw, const char *config_dir_path) {
} }
_g_gw = gw; _g_gw = gw;
_g_rtpv = rtpv_init(_relay_rtp_clients); _g_rtpv = rtpv_init(_relay_rtp_clients);
if (_g_audio_dev) { if (_g_audio_dev_name) {
_g_rtpa = rtpa_init(_relay_rtp_clients); _g_rtpa = rtpa_init(_relay_rtp_clients);
A_THREAD_CREATE(&_g_audio_tid, _clients_audio_thread, NULL); A_THREAD_CREATE(&_g_audio_tid, _clients_audio_thread, NULL);
} }
@@ -417,9 +422,9 @@ static void _plugin_destroy(void) {
DEL(rtpa_destroy, _g_rtpa); DEL(rtpa_destroy, _g_rtpa);
DEL(rtpv_destroy, _g_rtpv); DEL(rtpv_destroy, _g_rtpv);
_g_gw = NULL; _g_gw = NULL;
DEL(free, _g_tc358743_dev); DEL(free, _g_tc358743_dev_path);
DEL(free, _g_audio_dev); DEL(free, _g_audio_dev_name);
DEL(free, _g_memsink_obj); DEL(free, _g_video_sink_name);
# undef DEL # undef DEL
} }

View File

@@ -1,6 +1,6 @@
.\" Manpage for ustreamer-dump. .\" Manpage for ustreamer-dump.
.\" Open an issue or pull request to https://github.com/pikvm/ustreamer to correct errors or typos .\" Open an issue or pull request to https://github.com/pikvm/ustreamer to correct errors or typos
.TH USTREAMER-DUMP 1 "version 5.7" "January 2021" .TH USTREAMER-DUMP 1 "version 5.8" "January 2021"
.SH NAME .SH NAME
ustreamer-dump \- Dump uStreamer's memory sink to file ustreamer-dump \- Dump uStreamer's memory sink to file

View File

@@ -1,6 +1,6 @@
.\" Manpage for ustreamer. .\" Manpage for ustreamer.
.\" Open an issue or pull request to https://github.com/pikvm/ustreamer to correct errors or typos .\" Open an issue or pull request to https://github.com/pikvm/ustreamer to correct errors or typos
.TH USTREAMER 1 "version 5.7" "November 2020" .TH USTREAMER 1 "version 5.8" "November 2020"
.SH NAME .SH NAME
ustreamer \- stream MJPEG video from any V4L2 device to the network ustreamer \- stream MJPEG video from any V4L2 device to the network

View File

@@ -3,7 +3,7 @@
pkgname=ustreamer pkgname=ustreamer
pkgver=5.7 pkgver=5.8
pkgrel=1 pkgrel=1
pkgdesc="Lightweight and fast MJPEG-HTTP streamer" pkgdesc="Lightweight and fast MJPEG-HTTP streamer"
url="https://github.com/pikvm/ustreamer" url="https://github.com/pikvm/ustreamer"

View File

@@ -6,7 +6,7 @@
include $(TOPDIR)/rules.mk include $(TOPDIR)/rules.mk
PKG_NAME:=ustreamer PKG_NAME:=ustreamer
PKG_VERSION:=5.7 PKG_VERSION:=5.8
PKG_RELEASE:=1 PKG_RELEASE:=1
PKG_MAINTAINER:=Maxim Devaev <mdevaev@gmail.com> PKG_MAINTAINER:=Maxim Devaev <mdevaev@gmail.com>

View File

@@ -19,7 +19,7 @@ def _find_sources(suffix: str) -> List[str]:
if __name__ == "__main__": if __name__ == "__main__":
setup( setup(
name="ustreamer", name="ustreamer",
version="5.7", version="5.8",
description="uStreamer tools", description="uStreamer tools",
author="Maxim Devaev", author="Maxim Devaev",
author_email="mdevaev@gmail.com", author_email="mdevaev@gmail.com",

View File

@@ -23,7 +23,7 @@
#pragma once #pragma once
#define VERSION_MAJOR 5 #define VERSION_MAJOR 5
#define VERSION_MINOR 7 #define VERSION_MINOR 8
#define MAKE_VERSION2(_major, _minor) #_major "." #_minor #define MAKE_VERSION2(_major, _minor) #_major "." #_minor
#define MAKE_VERSION1(_major, _minor) MAKE_VERSION2(_major, _minor) #define MAKE_VERSION1(_major, _minor) MAKE_VERSION2(_major, _minor)