29#if !defined( __INOS_SYN_H )
40#define INOS_NO_WAIT 0x00000000
41#define INOS_WAIT_FOREVER 0xFFFFFFFF
46#ifdef INOS_CACHE_LOCK_SUPPORT
47#define ICACHE __attribute__ ((section (".icache")))
48#define DCACHE __attribute__ ((section (".dcache")))
82 uint32 aInitialCount=0,
102 ICACHE
virtual uint32
Wait(uint32 aTimeout=INOS_WAIT_FOREVER);
106 ICACHE
virtual void Signal() { iSignal(
false); }
131 {
return m_Lock.GetAddr(); };
135 virtual bool UsesPolling()
const {
return false;};
138 return this == i_pSync;
141 #if defined(INOS_SYNCGUARD)
153 friend class CINOSScheduler;
166 #if defined(INOS_SYNCGUARD)
167 uint32 m_uReferenced{};
168 uint32 m_uReferencedByParent{};
173 int operator < (
const CINOSSync& aSync)
const
175 int operator == (
const CINOSSync& aSync)
const
177 int operator < (
const char* aName)
const
178 {
return (strcmp(
m_pName, aName)<0);}
179 int operator == (
const char* aName)
const
180 {
return (strcmp(
m_pName, aName)==0);}
185 ICACHE
virtual bool Signaled(
CINOSSync*& aChild);
187 virtual CINOSSyncNode* GetNode() {
return m_pNode;};
189 virtual void SetNode(CINOSSyncNode* aNode) {
m_pNode = aNode;};
197 iSignal(
true, auMsr);
207 void iSignal(
bool abAlreadyLocked, uint32 uMsr = 0);
231 m_uAppError = auAppError;
264 uint32 m_uAppError{};
271class CINOSExceptionCleanup;
316 ICACHE
virtual uint32
Wait(uint32 aTimeout=INOS_WAIT_FOREVER)
override;
320 ICACHE
virtual uint32
Wait(
CINOSSync*& aChild, uint32 aTimeout=INOS_WAIT_FOREVER);
328 virtual bool UsesPolling()
const override {
return m_bUsesPolling;};
334 void SetBus(
CINOSBus* apBus) { m_pBus = apBus; }
338 friend class CINOSSyncNode;
342 CINOSSyncNode* pFirstChild;
343 CINOSSyncNode* pLastChild;
346 CINOSExceptionCleanup* pCleanup;
357 ICACHE
virtual bool Signaled(
CINOSSync*& aChild)
override;
383 CINOSSyncNode* pNext;
386 #ifndef INOS_MULTICORE
387 CINOSSyncNode* pNextGroup;
399 ICACHE
void WakeUp();
442 template<
class Rep,
class Period >
443 EStatus
WaitFor(std::unique_lock<CINOSMutex>& lock,
444 const std::chrono::duration<Rep, Period>& rel_time)
446 uint32 waitUs = std::chrono::duration_cast<std::chrono::microseconds>(rel_time).count();
447 const uint32 uWaitTime = DoWait(lock, waitUs);
448 return (uWaitTime == 0) ? eTimeout : eNoTimeout;
453 template<
class Rep,
class Period,
class Predicate >
454 bool WaitFor( std::unique_lock<CINOSMutex>& lock,
455 const std::chrono::duration<Rep, Period>& rel_time,
457 uint32 waitUs = checked_static_cast<uint32>(std::chrono::duration_cast<std::chrono::microseconds>(rel_time).count());
459 uint32 uWaitTime = DoWait(lock, waitUs);
464 waitUs = (waitUs - uWaitTime) > 0 ? waitUs - uWaitTime : 0;
471 void Wait( std::unique_lock<CINOSMutex>& lock ) {
477 template<
class Predicate >
478 void wait( std::unique_lock<CINOSMutex>& lock, Predicate pred ) {
494 uint32 DoWait(std::unique_lock<CINOSMutex>& lock, uint32 auTimeout = INOS_WAIT_FOREVER);
521 const char* apName = 0,
522 uint32 auInitialCount = 1,
523 uint32 auMaxCount = 0xffffffff
536 ICACHE uint32
Request(uint32 aTimeout=INOS_WAIT_FOREVER);
550 {
return m_uMaxCount; }
578 CINOSQueue(
const char* apName, uint32 auNumber, uint32 auSize);
592 ICACHE uint32
Put(
void* aData, uint32 aTimeout=INOS_WAIT_FOREVER, uint32 auFlags=0);
601 ICACHE uint32
Get(
void* aData, uint32 aTimeout=INOS_WAIT_FOREVER);
610 void Inquiry(
void* aData, uint32& aCountOfElements);
692 bool Access(
void*&ptrData, uint32 auIndex);
702 eFlgOverflowCheck = 0x00000001,
703 eFlgOverflowFatal = 0x00000002,
704 eFlgAccess = 0x00000004,
705 eFlgUnique = 0x00000008,
728#include <cinostaskqueue.h>
742 uint32 aInitialCount=0,
760#ifndef INOS_NO_BIT_EVENT_SUPPORT
778 virtual uint32
Wait(uint32 aTimeout=INOS_WAIT_FOREVER)
override ;
785 virtual bool UsesPolling()
const override {
return m_bUsesPolling;};
795 CINOSExceptionCleanup* m_pCleanup;
803 virtual bool Signaled(
CINOSSync*& aChild)
override;
805 virtual CINOSSyncNode* GetNode()
override {
return m_pEvent->GetNode();};
807 virtual void SetNode(CINOSSyncNode* aNode)
override {m_pEvent->SetNode(aNode);};
835 virtual uint32
Wait(uint32 aTimeout=INOS_WAIT_FOREVER)
override ;
842 virtual bool UsesPolling()
const override {
return m_bUsesPolling;};
852 CINOSExceptionCleanup* m_pCleanup;
860 virtual bool Signaled(
CINOSSync*& aChild)
override ;
862 virtual CINOSSyncNode* GetNode()
override {
return m_pEvent->GetNode();};
864 virtual void SetNode(CINOSSyncNode* aNode)
override {m_pEvent->SetNode(aNode);};
877#ifndef INOS_NO_1MS_SUPPORT
900 void Reset(uint32 aTime=eUsePreviousTime);
907 void Start(uint32 aTime=eUsePreviousTime);
915 void iRemoveHandler();
919 uint32 mWaitTime = eEventDisabled;
922 CINOSExceptionCleanup* pCleanup =
nullptr;
942class CINOSSyncObjects
956 TINOSNameBalancedBinaryTree<CINOSSync>* pSyncObjects;
968template<
typename TLock>
977 m_Lock(aLock), m_bLocked(false)
979 m_bLocked = (m_Lock.Request() != 0);
984 m_Lock(aLock), m_bLocked(false)
986 m_bLocked = (m_Lock.Request(auTimeout) != 0);
989 if (m_bLocked) m_Lock.Release();
991 bool IsLocked()
const {
1026 const char* apParentName,
1027 const char* apBaseName,
1028 int32 aiInitialCount = 0,
1029 void* apHandlerObj = NULL,
1030 void* apHandlerFunc = NULL
1070 void* m_pHandlerFunc;
1092 std::unique_lock<CINOSMutex> lock(m_Mutex);
1093 while (HasForeignWriter()) {
1094 m_Unlocked.
wait(lock, [
this]() {
return !HasForeignWriter(); });
1100 std::unique_lock<CINOSMutex> lock(m_Mutex);
1102 if (m_uReaders == 0)
1110 std::unique_lock<CINOSMutex> lock(m_Mutex);
1111 while (HasForeignWriter() || HasReaders()) {
1112 m_Unlocked.
wait(lock, [
this]() {
return !(HasForeignWriter() || HasReaders()); });
1119 std::unique_lock<CINOSMutex> lock(m_Mutex);
1121 if (m_nWriter == 0) {
1122 m_pWriter =
nullptr;
1127 bool HasReaders()
const {
1128 return m_uReaders > 0;
1130 bool HasForeignWriter()
const {
1131 const bool bHasWriter = m_nWriter > 0;
1132 const bool bWriterIsMe =
ActualTask() == m_pWriter;
1133 return bHasWriter && !bWriterIsMe;
1137 size_t m_uReaders{};
1140 size_t m_nWriter{0};
1162 m_Lock.WriteUnlock();
1179 m_Lock.ReadUnlock();
1188extern CINOSSyncObjects* pINOSSyncObjects;
#define DECLARE_DYNAMIC_PLACEMENT(aClass)
Definition cinospartitionmemory.h:348
#define DECLARE_DYNAMIC(aClass)
Definition cinospartitionmemory.h:328
Definition inos_syn.h:820
virtual void Signal() override
Put object into the signaled state.
virtual const char * GetName() override
Get name of sync object.
Definition inos_syn.h:833
virtual void Reset() override
Reset object state.
virtual uint32 Wait(uint32 aTimeout=0xFFFFFFFF) override
wait for signaled state for max. aTimeout usec
Definition inos_syn.h:763
virtual uint32 Wait(uint32 aTimeout=0xFFFFFFFF) override
wait for signaled state for max. aTimeout usec
virtual const char * GetName() override
Get name of sync object.
Definition inos_syn.h:776
virtual void Reset() override
Reset object state.
virtual void Signal() override
Put object into the signaled state.
Definition cinosbus.h:565
Definition inos_syn.h:422
void NotifyAll()
Wake up all waiting tasks See http://en.cppreference.com/w/cpp/thread/condition_variable/notify_all f...
virtual ~CINOSConditionVariable()
Destroy condition variable object.
void Wait(std::unique_lock< CINOSMutex > &lock)
wait for being notified (even spuriously) See http://en.cppreference.com/w/cpp/thread/condition_varia...
Definition inos_syn.h:471
void wait(std::unique_lock< CINOSMutex > &lock, Predicate pred)
wait for being notified and 'pred' is true See http://en.cppreference.com/w/cpp/thread/condition_vari...
Definition inos_syn.h:478
bool WaitFor(std::unique_lock< CINOSMutex > &lock, const std::chrono::duration< Rep, Period > &rel_time, Predicate pred)
wait for being notified waiting at most aTimeout. See http://en.cppreference.com/w/cpp/thread/conditi...
Definition inos_syn.h:454
CINOSConditionVariable(const char *aName=nullptr)
void NotifyOne()
Wake up one waiting task See http://en.cppreference.com/w/cpp/thread/condition_variable/notify_one fo...
EStatus WaitFor(std::unique_lock< CINOSMutex > &lock, const std::chrono::duration< Rep, Period > &rel_time)
wait for being notified waiting at most aTimeout. See http://en.cppreference.com/w/cpp/thread/conditi...
Definition inos_syn.h:443
Definition inos_syn.h:735
Definition inoskernel.h:229
Definition inos_syn.h:970
CINOSLockGuard(TLock &aLock)
Definition inos_syn.h:976
CINOSLockGuard(TLock &aLock, uint32 auTimeout)
Definition inos_syn.h:983
Definition inos_syn.h:289
virtual uint32 Wait(CINOSSync *&aChild, uint32 aTimeout=0xFFFFFFFF)
CINOSBus * GetBus()
Definition inos_syn.h:333
void Remove(CINOSSync *aChild, bool aDelete=false)
void And(CINOSSync *aChild)
void Or(CINOSSync *aChild)
virtual uint32 Wait(uint32 aTimeout=0xFFFFFFFF) override
virtual void Reset() override
void RemoveAll(bool aDelete=false)
Definition cinosmutex.h:36
Definition inos_syn.h:567
const uint32 * GetAdrNumber() const
Return address of entries counter.
Definition inos_syn.h:655
void * pGet
pointer to actual get block
Definition inos_syn.h:715
void ClrFlag(uint32 auFlag)
Clear queue flag(s)
Definition inos_syn.h:677
const uint32 GetSize() const
Return size of one queue entry.
Definition inos_syn.h:641
void * pPut
pointer to actual put block
Definition inos_syn.h:714
void EndAccess(uint32 msr)
EndAccess Needs to be called after Access.
void Flush()
Flush the queue.
const uint32 GetMaxNumber() const
Return maximum number of entries.
Definition inos_syn.h:648
bool Access(void *&ptrData, uint32 auIndex)
Access Try to gain access to the data at a given index. The call needs to be embraced by calls of uin...
void Inquiry(void *aData, uint32 &aCountOfElements)
Gets the first element without removing it from the queue. Moreover, aCountOfElements returns the num...
const uint64 * GetAdrCount() const
Return address of overall counter.
Definition inos_syn.h:662
CINOSSemaphore * pSemaphore
semaphore to handle the number of queue entries
Definition inos_syn.h:720
uint32 mSize
size of block in queue
Definition inos_syn.h:717
uint32 BeginAccess()
BeginAccess Needs to be called before Access.
bool InquiryAt(void *aData, uint32 auIndex)
Gets the element at auIndex (starting from 0..numberOfElementsInQueue) without removing it from the q...
uint32 Put(void *aData, uint32 aTimeout=0xFFFFFFFF, uint32 auFlags=0)
Put data to queue and wait for max. auTimeout usec if queue full.
void SetFlag(uint32 auFlag)
Set queue flag(s)
Definition inos_syn.h:669
uint32 GetNumber()
Get number of queue entries.
uint32 mMaxNumber
maximum number of blocks in queue
Definition inos_syn.h:718
uint32 Get(void *aData, uint32 aTimeout=0xFFFFFFFF)
Get data from queue and wait for max. auTimeout usec if queue empty.
uint32 mQueueFlags
queue flags
Definition inos_syn.h:719
void * pBegin
pointer to begin of queue buffer
Definition inos_syn.h:712
uint64 mCount
overall put count
Definition inos_syn.h:721
bool Empty()
Get queue state.
virtual ~CINOSQueue()
Destroy queue.
void * pEnd
pointer to end of queue buffer
Definition inos_syn.h:713
uint32 mNumber
actual number of blocks in queue
Definition inos_syn.h:716
CINOSQueue(const char *apName, uint32 auNumber, uint32 auSize)
Create a queue with the given name. See also Queue.
Definition inos_syn.h:1171
Definition inos_syn.h:1086
void ReadLock()
Definition inos_syn.h:1091
void WriteLock()
Definition inos_syn.h:1109
void ReadUnlock()
Definition inos_syn.h:1099
void WriteUnlock()
Definition inos_syn.h:1118
Definition inos_syn.h:1015
int32 Increment()
Increment the reference counter and return the new value.
int32 GetCount()
Get current count.
void * m_pHandlerObj
Handler method to call when count reaches 0.
Definition inos_syn.h:1069
virtual ~CINOSRefCount()
Destroy reference counter.
void SetCount(int32 aiNewCount)
Set current count.
int32 Decrement()
Decrement the reference counter and return the new value.
inosName32 m_sName
Reference counter name (for debugging purposes)
Definition inos_syn.h:1065
CINOSRefCount(const char *apParentName, const char *apBaseName, int32 aiInitialCount=0, void *apHandlerObj=NULL, void *apHandlerFunc=NULL)
Create a reference counter with the given name.
int32 m_iCount
Reference count.
Definition inos_syn.h:1067
Definition inos_syn.h:510
virtual ~CINOSSemaphore()
Destroy semaphore.
void Release()
Release seamphore.
uint32 GetMaxCount()
Get max. allowed count.
Definition inos_syn.h:549
uint32 Request(uint32 aTimeout=0xFFFFFFFF)
Wait for semaphore for a max. amount of time.
CINOSSemaphore(const char *apName=0, uint32 auInitialCount=1, uint32 auMaxCount=0xffffffff)
Create a semaphore with the given name. See also Semaphore.
uint32 GetCount()
Get current count.
Definition inos_syn.h:544
Definition inos_syn.h:218
uint32 GetRplId() const
Definition inos_syn.h:239
uint32 GetAppErrorAndRpl() const
Definition inos_syn.h:255
virtual void SignalEx(CINOSTaskExMsg *apMsg, uint32 auRplId, uint32 auAppError) override
Definition inos_syn.h:227
uint32 GetAppError() const
Definition inos_syn.h:247
virtual ~CINOSSync()
Destroy sync object.
CINOSSync(const char *aName=0, uint32 aInitialCount=0, bool aManual=false)
virtual const char * GetName()
Get name of sync object.
Definition inos_syn.h:94
tTaskId m_idFstWaiting
id of first task waiting for the sync object
Definition inos_syn.h:162
virtual void SignalEx(CINOSTaskExMsg *apMsg, uint32 auRplId, uint32 auAppError)
Definition inos_syn.h:115
SINOSCoreLock m_Lock
core lock
Definition inos_syn.h:164
CINOSSyncNode * m_pNode
pointer to object node (if any)
Definition inos_syn.h:165
virtual bool MsgEvent(CINOSTaskExMsg *apMsg)
Definition inos_syn.h:121
const char * m_pName
name of sync object
Definition inos_syn.h:159
void SignalAndUnlock(uint32 auMsr)
Put object into the signaled state and release the core lock.
Definition inos_syn.h:196
virtual uint32 Wait(uint32 aTimeout=0xFFFFFFFF)
wait for signaled state for max. aTimeout usec
virtual void Signal()
Put object into the signaled state.
Definition inos_syn.h:106
tTaskId m_idLstWaiting
id of last task waiting for the sync object
Definition inos_syn.h:163
virtual void Reset()
Reset object state.
uint32 m_uCount
signaled count of object
Definition inos_syn.h:160
volatile uint32 * GetLockAdr()
Return pointer to core locking structure.
Definition inos_syn.h:130
bool m_bManual
manual object yes/no
Definition inos_syn.h:161
Definition cinostaskex.h:396
Definition cinostask.h:52
Definition inos_syn.h:880
CINOSTimeEvent(uint32 aTime)
Definition inos_syn.h:1154
Definition inostype.h:258
Definition inostype.h:192