3 * This file is part of the libCEC(R) library.
5 * libCEC(R) is Copyright (C) 2011-2012 Pulse-Eight Limited. All rights reserved.
6 * libCEC(R) is an original work, containing original code.
8 * libCEC(R) is a trademark of Pulse-Eight Limited.
10 * This program is dual-licensed; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
25 * Alternatively, you can license this library under a commercial license,
26 * please contact Pulse-Eight Licensing for more information.
28 * For more information contact:
29 * Pulse-Eight Licensing <license@pulse-eight.com>
30 * http://www.pulse-eight.com/
31 * http://www.pulse-eight.net/
34 #include "lib/platform/threads/mutex.h"
38 using namespace PLATFORM
;
40 class CAdapterMessageQueueEntry
43 CAdapterMessageQueueEntry(const cec_command
&command
)
44 : m_bWaiting(true), m_retval((uint32_t)-1), m_bSucceeded(false)
47 uint32_t(command
.opcode_set
? command
.opcode
: CEC_OPCODE_NONE
),
48 command
.initiator
, command
.destination
);
51 virtual ~CAdapterMessageQueueEntry(void) {}
54 * @brief Query result from worker thread
56 uint32_t Result() const
62 * @brief Signal waiting threads
66 CLockObject
lock(m_mutex
);
67 m_condition
.Broadcast();
71 * @brief Signal waiting thread(s) when message matches this entry
73 bool CheckMatch(uint32_t opcode
, cec_logical_address initiator
,
74 cec_logical_address destination
, uint32_t response
)
76 uint32_t hash
= hashValue(opcode
, initiator
, destination
);
80 CLockObject
lock(m_mutex
);
92 * @brief Wait for a response to this command.
93 * @param iTimeout The timeout to use while waiting.
94 * @return True when a response was received before the timeout passed, false otherwise.
96 bool Wait(uint32_t iTimeout
)
98 CLockObject
lock(m_mutex
);
100 bool bReturn
= m_bSucceeded
? true : m_condition
.Wait(m_mutex
, m_bSucceeded
, iTimeout
);
106 * @return True while a thread is waiting for a signal or isn't waiting yet, false otherwise.
110 CLockObject
lock(m_mutex
);
115 * @return Hash value for given cec_command
117 static uint32_t hashValue(uint32_t opcode
,
118 cec_logical_address initiator
,
119 cec_logical_address destination
)
121 return 1 | ((uint32_t)initiator
<< 8) |
122 ((uint32_t)destination
<< 16) | ((uint32_t)opcode
<< 16);
126 bool m_bWaiting
; /**< true while a thread is waiting or when it hasn't started waiting yet */
127 PLATFORM::CCondition
<bool> m_condition
; /**< the condition to wait on */
128 PLATFORM::CMutex m_mutex
; /**< mutex for changes to this class */