libobs/media-io: Fix recursive lock in video
In certain cases the video thread could end up trying to lock itself recursively. This just allows the mutexes to safely be locked recursively.
This commit is contained in:
parent
817a724dea
commit
c52406c178
@ -192,6 +192,7 @@ static inline bool valid_video_params(const struct video_output_info *info)
|
|||||||
int video_output_open(video_t **video, struct video_output_info *info)
|
int video_output_open(video_t **video, struct video_output_info *info)
|
||||||
{
|
{
|
||||||
struct video_output *out;
|
struct video_output *out;
|
||||||
|
pthread_mutexattr_t attr;
|
||||||
|
|
||||||
if (!valid_video_params(info))
|
if (!valid_video_params(info))
|
||||||
return VIDEO_OUTPUT_INVALIDPARAM;
|
return VIDEO_OUTPUT_INVALIDPARAM;
|
||||||
@ -205,9 +206,13 @@ int video_output_open(video_t **video, struct video_output_info *info)
|
|||||||
(double)info->fps_num);
|
(double)info->fps_num);
|
||||||
out->initialized = false;
|
out->initialized = false;
|
||||||
|
|
||||||
if (pthread_mutex_init(&out->data_mutex, NULL) != 0)
|
if (pthread_mutexattr_init(&attr) != 0)
|
||||||
goto fail;
|
goto fail;
|
||||||
if (pthread_mutex_init(&out->input_mutex, NULL) != 0)
|
if (pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE) != 0)
|
||||||
|
goto fail;
|
||||||
|
if (pthread_mutex_init(&out->data_mutex, &attr) != 0)
|
||||||
|
goto fail;
|
||||||
|
if (pthread_mutex_init(&out->input_mutex, &attr) != 0)
|
||||||
goto fail;
|
goto fail;
|
||||||
if (os_event_init(&out->stop_event, OS_EVENT_TYPE_MANUAL) != 0)
|
if (os_event_init(&out->stop_event, OS_EVENT_TYPE_MANUAL) != 0)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user