1 /*
2  * Copyright (C) 2012 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 /*
18  *  Synchronize two or more threads using a condition variable and a mutex.
19  */
20 #pragma once
21 #include "CondVar.h"
22 #include "Mutex.h"
23 
24 class SyncEvent {
25  public:
26   /*******************************************************************************
27   **
28   ** Function:        ~SyncEvent
29   **
30   ** Description:     Cleanup all resources.
31   **
32   ** Returns:         None.
33   **
34   *******************************************************************************/
~SyncEvent()35   ~SyncEvent() {}
36 
37   /*******************************************************************************
38   **
39   ** Function:        start
40   **
41   ** Description:     Start a synchronization operation.
42   **
43   ** Returns:         None.
44   **
45   *******************************************************************************/
start()46   void start() { mMutex.lock(); }
47 
48   /*******************************************************************************
49   **
50   ** Function:        wait
51   **
52   ** Description:     Block the thread and wait for the event to occur.
53   **
54   ** Returns:         None.
55   **
56   *******************************************************************************/
wait()57   void wait() { mCondVar.wait(mMutex); }
58 
59   /*******************************************************************************
60   **
61   ** Function:        wait
62   **
63   ** Description:     Block the thread and wait for the event to occur.
64   **                  millisec: Timeout in milliseconds.
65   **
66   ** Returns:         True if wait is successful; false if timeout occurs.
67   **
68   *******************************************************************************/
wait(long millisec)69   bool wait(long millisec) {
70     bool retVal = mCondVar.wait(mMutex, millisec);
71     return retVal;
72   }
73 
74   /*******************************************************************************
75   **
76   ** Function:        notifyOne
77   **
78   ** Description:     Notify a blocked thread that the event has occurred.
79   **                  Unblocks it.
80   **
81   ** Returns:         None.
82   **
83   *******************************************************************************/
notifyOne()84   void notifyOne() { mCondVar.notifyOne(); }
85 
86   /*******************************************************************************
87   **
88   ** Function:        end
89   **
90   ** Description:     End a synchronization operation.
91   **
92   ** Returns:         None.
93   **
94   *******************************************************************************/
end()95   void end() { mMutex.unlock(); }
96 
97  private:
98   CondVar mCondVar;
99   Mutex mMutex;
100 };
101 
102 /*****************************************************************************/
103 /*****************************************************************************/
104 
105 /*****************************************************************************
106 **
107 **  Name:           SyncEventGuard
108 **
109 **  Description:    Automatically start and end a synchronization event.
110 **
111 *****************************************************************************/
112 class SyncEventGuard {
113  public:
114   /*******************************************************************************
115   **
116   ** Function:        SyncEventGuard
117   **
118   ** Description:     Start a synchronization operation.
119   **
120   ** Returns:         None.
121   **
122   *******************************************************************************/
SyncEventGuard(SyncEvent & event)123   SyncEventGuard(SyncEvent& event) : mEvent(event) {
124     event.start();  // automatically start operation
125   };
126 
127   /*******************************************************************************
128   **
129   ** Function:        ~SyncEventGuard
130   **
131   ** Description:     End a synchronization operation.
132   **
133   ** Returns:         None.
134   **
135   *******************************************************************************/
~SyncEventGuard()136   ~SyncEventGuard() {
137     mEvent.end();  // automatically end operation
138   };
139 
140  private:
141   SyncEvent& mEvent;
142 };
143