xref: /aosp_15_r20/external/deqp/framework/delibs/decpp/deThread.cpp (revision 35238bce31c2a825756842865a792f8cf7f89930)
1*35238bceSAndroid Build Coastguard Worker /*-------------------------------------------------------------------------
2*35238bceSAndroid Build Coastguard Worker  * drawElements C++ Base Library
3*35238bceSAndroid Build Coastguard Worker  * -----------------------------
4*35238bceSAndroid Build Coastguard Worker  *
5*35238bceSAndroid Build Coastguard Worker  * Copyright 2014 The Android Open Source Project
6*35238bceSAndroid Build Coastguard Worker  *
7*35238bceSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
8*35238bceSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
9*35238bceSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
10*35238bceSAndroid Build Coastguard Worker  *
11*35238bceSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
12*35238bceSAndroid Build Coastguard Worker  *
13*35238bceSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
14*35238bceSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
15*35238bceSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16*35238bceSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
17*35238bceSAndroid Build Coastguard Worker  * limitations under the License.
18*35238bceSAndroid Build Coastguard Worker  *
19*35238bceSAndroid Build Coastguard Worker  *//*!
20*35238bceSAndroid Build Coastguard Worker  * \file
21*35238bceSAndroid Build Coastguard Worker  * \brief Thread base class.
22*35238bceSAndroid Build Coastguard Worker  *//*--------------------------------------------------------------------*/
23*35238bceSAndroid Build Coastguard Worker 
24*35238bceSAndroid Build Coastguard Worker #include "deThread.hpp"
25*35238bceSAndroid Build Coastguard Worker #include "deMemory.h"
26*35238bceSAndroid Build Coastguard Worker 
27*35238bceSAndroid Build Coastguard Worker #include <exception>
28*35238bceSAndroid Build Coastguard Worker #include <stdexcept>
29*35238bceSAndroid Build Coastguard Worker #include <new>
30*35238bceSAndroid Build Coastguard Worker 
31*35238bceSAndroid Build Coastguard Worker namespace de
32*35238bceSAndroid Build Coastguard Worker {
33*35238bceSAndroid Build Coastguard Worker 
34*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*!
35*35238bceSAndroid Build Coastguard Worker  * \brief Thread constructor.
36*35238bceSAndroid Build Coastguard Worker  *//*--------------------------------------------------------------------*/
Thread(void)37*35238bceSAndroid Build Coastguard Worker Thread::Thread(void) : m_thread(0)
38*35238bceSAndroid Build Coastguard Worker {
39*35238bceSAndroid Build Coastguard Worker     deMemset(&m_attribs, 0, sizeof(m_attribs));
40*35238bceSAndroid Build Coastguard Worker }
41*35238bceSAndroid Build Coastguard Worker 
42*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*!
43*35238bceSAndroid Build Coastguard Worker  * \brief Destroy thread.
44*35238bceSAndroid Build Coastguard Worker  *
45*35238bceSAndroid Build Coastguard Worker  * If the thread is currently running, OS is instructed to destroy it
46*35238bceSAndroid Build Coastguard Worker  * but the actual behavior is unspecified.
47*35238bceSAndroid Build Coastguard Worker  *//*--------------------------------------------------------------------*/
~Thread(void)48*35238bceSAndroid Build Coastguard Worker Thread::~Thread(void)
49*35238bceSAndroid Build Coastguard Worker {
50*35238bceSAndroid Build Coastguard Worker     if (m_thread)
51*35238bceSAndroid Build Coastguard Worker         deThread_destroy(m_thread);
52*35238bceSAndroid Build Coastguard Worker }
53*35238bceSAndroid Build Coastguard Worker 
54*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*!
55*35238bceSAndroid Build Coastguard Worker  * \brief Set thread priority.
56*35238bceSAndroid Build Coastguard Worker  * \param priority deThreadPriority as described in deThread.h. Currently
57*35238bceSAndroid Build Coastguard Worker  *                   supported values are: DE_THREADPRIORITY_LOWEST,
58*35238bceSAndroid Build Coastguard Worker  *                   DE_THREADPRIORITY_LOW, DE_THREADPRIORITY_NORMAL,
59*35238bceSAndroid Build Coastguard Worker  *                   DE_THREADPRIORITY_HIGH, DE_THREADPRIORITY_HIGHEST.
60*35238bceSAndroid Build Coastguard Worker  *
61*35238bceSAndroid Build Coastguard Worker  * Sets priority for the thread start(). setPriority() has no effect
62*35238bceSAndroid Build Coastguard Worker  * if the thread is already running.
63*35238bceSAndroid Build Coastguard Worker  *//*--------------------------------------------------------------------*/
setPriority(deThreadPriority priority)64*35238bceSAndroid Build Coastguard Worker void Thread::setPriority(deThreadPriority priority)
65*35238bceSAndroid Build Coastguard Worker {
66*35238bceSAndroid Build Coastguard Worker     m_attribs.priority = priority;
67*35238bceSAndroid Build Coastguard Worker }
68*35238bceSAndroid Build Coastguard Worker 
threadFunc(void * arg)69*35238bceSAndroid Build Coastguard Worker static void threadFunc(void *arg)
70*35238bceSAndroid Build Coastguard Worker {
71*35238bceSAndroid Build Coastguard Worker     static_cast<Thread *>(arg)->run();
72*35238bceSAndroid Build Coastguard Worker }
73*35238bceSAndroid Build Coastguard Worker 
74*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*!
75*35238bceSAndroid Build Coastguard Worker  * \brief Start thread.
76*35238bceSAndroid Build Coastguard Worker  *
77*35238bceSAndroid Build Coastguard Worker  * Starts thread that will execute the virtual run() method.
78*35238bceSAndroid Build Coastguard Worker  *
79*35238bceSAndroid Build Coastguard Worker  * The function will fail if the thread is currently running or has finished
80*35238bceSAndroid Build Coastguard Worker  * but no join() has been called.
81*35238bceSAndroid Build Coastguard Worker  *//*--------------------------------------------------------------------*/
start(void)82*35238bceSAndroid Build Coastguard Worker void Thread::start(void)
83*35238bceSAndroid Build Coastguard Worker {
84*35238bceSAndroid Build Coastguard Worker     DE_ASSERT(!m_thread);
85*35238bceSAndroid Build Coastguard Worker     m_thread = deThread_create(threadFunc, this, &m_attribs);
86*35238bceSAndroid Build Coastguard Worker     if (!m_thread)
87*35238bceSAndroid Build Coastguard Worker         throw std::bad_alloc();
88*35238bceSAndroid Build Coastguard Worker }
89*35238bceSAndroid Build Coastguard Worker 
90*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*!
91*35238bceSAndroid Build Coastguard Worker  * \brief Wait for thread to finish and clean up current thread.
92*35238bceSAndroid Build Coastguard Worker  *
93*35238bceSAndroid Build Coastguard Worker  * This function will block until currently running thread has finished.
94*35238bceSAndroid Build Coastguard Worker  * Once the thread has finished, current thread state will be cleaned
95*35238bceSAndroid Build Coastguard Worker  * and thread can be re-launched using start().
96*35238bceSAndroid Build Coastguard Worker  *
97*35238bceSAndroid Build Coastguard Worker  * join() can only be called after a successful call to start().
98*35238bceSAndroid Build Coastguard Worker  *//*--------------------------------------------------------------------*/
join(void)99*35238bceSAndroid Build Coastguard Worker void Thread::join(void)
100*35238bceSAndroid Build Coastguard Worker {
101*35238bceSAndroid Build Coastguard Worker     DE_ASSERT(m_thread);
102*35238bceSAndroid Build Coastguard Worker     if (!deThread_join(m_thread))
103*35238bceSAndroid Build Coastguard Worker         throw std::runtime_error("Thread::join() failed");
104*35238bceSAndroid Build Coastguard Worker 
105*35238bceSAndroid Build Coastguard Worker     deThread_destroy(m_thread);
106*35238bceSAndroid Build Coastguard Worker     m_thread = 0;
107*35238bceSAndroid Build Coastguard Worker }
108*35238bceSAndroid Build Coastguard Worker 
109*35238bceSAndroid Build Coastguard Worker } // namespace de
110