With the internal headers now in include/libcamera/internal/, we may have identically named headers in include/libcamera/. Their header guards would clash. Rename the header guards of internal headers to prevent any issue. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
35 lines
683 B
C++
35 lines
683 B
C++
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
|
/*
|
|
* Copyright (C) 2019, Google Inc.
|
|
*
|
|
* semaphore.h - General-purpose counting semaphore
|
|
*/
|
|
#ifndef __LIBCAMERA_INTERNAL_SEMAPHORE_H__
|
|
#define __LIBCAMERA_INTERNAL_SEMAPHORE_H__
|
|
|
|
#include <condition_variable>
|
|
|
|
#include "libcamera/internal/thread.h"
|
|
|
|
namespace libcamera {
|
|
|
|
class Semaphore
|
|
{
|
|
public:
|
|
Semaphore(unsigned int n = 0);
|
|
|
|
unsigned int available();
|
|
void acquire(unsigned int n = 1);
|
|
bool tryAcquire(unsigned int n = 1);
|
|
void release(unsigned int n = 1);
|
|
|
|
private:
|
|
Mutex mutex_;
|
|
std::condition_variable cv_;
|
|
unsigned int available_;
|
|
};
|
|
|
|
} /* namespace libcamera */
|
|
|
|
#endif /* __LIBCAMERA_INTERNAL_SEMAPHORE_H__ */
|