blob: edf515629e4ef34f19716258a80e339ca6169923 [file] [log] [blame]
/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef CHRE_PLATFORM_CONDITION_VARIABLE_H_
#define CHRE_PLATFORM_CONDITION_VARIABLE_H_
#include "chre/platform/mutex.h"
#include "chre/target_platform/condition_variable_base.h"
#include "chre/util/non_copyable.h"
#include "chre/util/time.h"
namespace chre {
/**
* Provides an implementation of a Condition Variable. The public API is
* similar to std::condition_variable. ConditionVariableBase is subclassed here
* to allow platforms to inject their own storage for their implementation.
*/
class ConditionVariable : public ConditionVariableBase, public NonCopyable {
public:
/**
* Allows the platform to do any condition variable initialization at
* construction time.
*/
ConditionVariable();
/**
* Allows the platform to do any condition variable deinitialization at
* destruction time.
*/
~ConditionVariable();
/**
* Unblock one thread that is waiting on this condition variable.
*/
void notify_one();
/**
* Causes the current thread to block until the condition variable is
* notified. The provided mutex will be unlocked and the thread will be
* blocked until the condition variable has notified. The mutex is relocked
* prior to this function returning. Note that while std::condition_variable
* allows for multiple threads to wait on the same condition variable object
* concurrently, the CHRE platform implementation is only required to allow
* for a single waiting thread. The calling code must also be equipped to
* handle spurious wakeups.
*
* @param The currently locked mutex.
*/
void wait(Mutex &mutex);
/**
* Same behavior as the wait function, but with a timeout to unblock the
* calling thread if not notified within the timeout period.
*
* @param mutex The currently locked mutex.
* @param timeout The timeout duration in nanoseconds.
*
* @return false if timed out, true if notified.
*/
bool wait_for(Mutex &mutex, Nanoseconds timeout);
};
} // namespace chre
#include "chre/target_platform/condition_variable_impl.h"
#endif // CHRE_PLATFORM_CONDITION_VARIABLE_H_