File: XenomaiLock.h

package info (click to toggle)
supercollider 1%3A3.13.0%2Brepack-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 80,292 kB
  • sloc: cpp: 476,363; lisp: 84,680; ansic: 77,685; sh: 25,509; python: 7,909; makefile: 3,440; perl: 1,964; javascript: 974; xml: 826; java: 677; yacc: 314; lex: 175; objc: 152; ruby: 136
file content (44 lines) | stat: -rw-r--r-- 1,123 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#pragma once
#include <mutex> //unique_lock
// Xenomai enforces the requirement to hold the lock so that optimizing
// the wake up process is possible - under the assumption that the caller
// owns the lock. There is no hack around this.
// See: https://www.xenomai.org/pipermail/xenomai/2017-October/037759.html
#define SC_CONDITION_VARIABLE_ANY_SHOULD_LOCK_BEFORE_NOTIFY

// to make sure Xenomai gets initialised on time, create one object of this
// class before any XenomaiMutex or XenomaiConditionVariable constructors
class XenomaiInitializer {
public:
    XenomaiInitializer();
};

class XenomaiMutex {
    friend class XenomaiConditionVariable;

public:
    XenomaiMutex();
    ~XenomaiMutex();

    bool try_lock();
    void lock();
    void unlock();

private:
    pthread_mutex_t m_mutex;
    bool m_enabled = false;
};

class XenomaiConditionVariable {
public:
    XenomaiConditionVariable();
    ~XenomaiConditionVariable();

    void wait(std::unique_lock<XenomaiMutex>& lck);
    void notify_one() noexcept;
    void notify_all() noexcept;

private:
    pthread_cond_t m_cond;
    bool m_enabled = false;
};