From d720cca9698014725861cedb68855a13c30eabc6 Mon Sep 17 00:00:00 2001 From: Diadlo Date: Mon, 26 Jun 2017 14:00:29 +0300 Subject: [PATCH] refactor: Split device and stream mutexes --- src/video/camerasource.cpp | 9 ++++++--- src/video/camerasource.h | 1 + 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/src/video/camerasource.cpp b/src/video/camerasource.cpp index bb1f47564..e4127eb7d 100644 --- a/src/video/camerasource.cpp +++ b/src/video/camerasource.cpp @@ -155,7 +155,7 @@ void CameraSource::setupDefault() */ void CameraSource::setupDevice(const QString& DeviceName, const VideoMode& Mode) { - QWriteLocker locker{&streamMutex}; + QWriteLocker locker{&deviceMutex}; if (DeviceName == deviceName && Mode == mode) { return; @@ -180,6 +180,7 @@ bool CameraSource::isNone() const CameraSource::~CameraSource() { QWriteLocker locker{&streamMutex}; + QWriteLocker locker2{&deviceMutex}; if (_isNone) { return; @@ -217,7 +218,7 @@ CameraSource::~CameraSource() void CameraSource::subscribe() { - QWriteLocker locker{&streamMutex}; + QWriteLocker locker{&deviceMutex}; ++subscriptions; openDevice(); @@ -225,7 +226,7 @@ void CameraSource::subscribe() void CameraSource::unsubscribe() { - QWriteLocker locker{&streamMutex}; + QWriteLocker locker{&deviceMutex}; --subscriptions; if (subscriptions == 0) { @@ -239,6 +240,7 @@ void CameraSource::unsubscribe() */ void CameraSource::openDevice() { + QWriteLocker locker{&streamMutex}; qDebug() << "Opening device " << deviceName; if (device) { @@ -345,6 +347,7 @@ void CameraSource::openDevice() */ void CameraSource::closeDevice() { + QWriteLocker locker{&streamMutex}; qDebug() << "Closing device " << deviceName; // Free all remaining VideoFrame diff --git a/src/video/camerasource.h b/src/video/camerasource.h index 9e95acb3a..cd0cb01a3 100644 --- a/src/video/camerasource.h +++ b/src/video/camerasource.h @@ -70,6 +70,7 @@ private: AVCodecContext* cctxOrig; int videoStreamIndex; + QReadWriteLock deviceMutex; QReadWriteLock streamMutex; std::atomic_bool _isNone;