diff --git a/src/iutils/CameraShm.cpp b/src/iutils/CameraShm.cpp index 403402a8..f9b8b4a0 100644 --- a/src/iutils/CameraShm.cpp +++ b/src/iutils/CameraShm.cpp @@ -245,6 +245,9 @@ void CameraSharedMemory::openSemLock() { sem_close(mSemLock); sem_unlink(SEM_NAME); mSemLock = sem_open(SEM_NAME, O_CREAT | O_EXCL, 0777, 1); + if (mSemLock == SEM_FAILED) { + LOGE("failed to re-open sem lock, errno: %s\n", strerror(errno)); + } } } @@ -255,9 +258,10 @@ void CameraSharedMemory::closeSemLock() { int CameraSharedMemory::lock() { int ret = OK; struct timespec ts; - CLEAR(ts); + CheckAndLogError(mSemLock == SEM_FAILED, VOID_VALUE, "invalid sem lock!"); // Wait the semaphore lock for 2 seconds + CLEAR(ts); clock_gettime(CLOCK_REALTIME, &ts); ts.tv_sec += CAMERA_SHM_LOCK_TIME; while (((ret = sem_timedwait(mSemLock, &ts)) == -1) && errno == EINTR) {