Merge vk-gl-cts/vulkan-cts-1.0.2 into vk-gl-cts/master
[platform/upstream/VK-GL-CTS.git] / framework / delibs / decpp / deSemaphore.hpp
1 #ifndef _DESEMAPHORE_HPP
2 #define _DESEMAPHORE_HPP
3 /*-------------------------------------------------------------------------
4  * drawElements C++ Base Library
5  * -----------------------------
6  *
7  * Copyright 2014 The Android Open Source Project
8  *
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *      http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  *//*!
22  * \file
23  * \brief deSemaphore C++ wrapper.
24  *//*--------------------------------------------------------------------*/
25
26 #include "deDefs.hpp"
27 #include "deSemaphore.h"
28
29 namespace de
30 {
31
32 /*--------------------------------------------------------------------*//*!
33  * \brief Semaphore
34  *
35  * Semaphore provides standard semaphore functionality.
36  *
37  * Semaphore is thread-safe counter that can be used to control access
38  * to a set of resources. The count can be incremented and decremented.
39  * When decrementing causes counter to reach negative value, it will
40  * block until increment has been called from an another thread.
41  *//*--------------------------------------------------------------------*/
42 class Semaphore
43 {
44 public:
45                                         Semaphore               (int initialValue, deUint32 flags = 0);
46                                         ~Semaphore              (void);
47
48         void                    increment               (void) throw();
49         void                    decrement               (void) throw();
50         bool                    tryDecrement    (void) throw();
51
52 private:
53                                         Semaphore               (const Semaphore& other); // Not allowed!
54         Semaphore&              operator=               (const Semaphore& other); // Not allowed!
55
56         deSemaphore             m_semaphore;
57 };
58
59 // Inline implementations.
60
61 /*--------------------------------------------------------------------*//*!
62  * \brief Increment semaphore count.
63  *
64  * Incremeting increases semaphore value by 1. If a value is currently
65  * negative (there is a thread waiting in decrement) the waiting thread
66  * will be resumed.
67  *
68  * Incrementing semaphore will never block.
69  *//*--------------------------------------------------------------------*/
70 inline void Semaphore::increment (void) throw()
71 {
72         deSemaphore_increment(m_semaphore);
73 }
74
75 /*--------------------------------------------------------------------*//*!
76  * \brief Decrement semaphore count.
77  *
78  * Decrementing decreases semaphore value by 1. If resulting value is negative
79  * (only -1 is possible) decrement() will block until the value is again 0
80  * (increment() has been called).
81  *
82  * If there is an another thread waiting in decrement(), the current thread
83  * will block until other thread(s) have been resumed.
84  *//*--------------------------------------------------------------------*/
85 inline void Semaphore::decrement (void) throw()
86 {
87         deSemaphore_decrement(m_semaphore);
88 }
89
90 /*--------------------------------------------------------------------*//*!
91  * \brief Try to decrement semaphore value.
92  * \return true if decrementing was successful without blocking, false
93  *                 otherwise
94  *
95  * This function will never block, i.e. it will return false if decrementing
96  * semaphore counter would result in negative value or there is already
97  * one or more threads waiting for this semaphore.
98  *//*--------------------------------------------------------------------*/
99 inline bool Semaphore::tryDecrement (void) throw()
100 {
101         return deSemaphore_tryDecrement(m_semaphore) == DE_TRUE;
102 }
103
104 } // de
105
106 #endif // _DESEMAPHORE_HPP