QP/C++  8.0.0
Real-Time Embedded Framework
Loading...
Searching...
No Matches
qs_dummy.hpp
Go to the documentation of this file.
1//============================================================================
2// QP/C++ Spy software tracing target-resident component
3//
4// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
5//
6// Q u a n t u m L e a P s
7// ------------------------
8// Modern Embedded Software
9//
10//
11// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
12//
13// The QP/C software is dual-licensed under the terms of the open-source GNU
14// General Public License (GPL) or under the terms of one of the closed-
15// source Quantum Leaps commercial licenses.
16//
17// Redistributions in source code must retain this top-level comment block.
18// Plagiarizing this software to sidestep the license obligations is illegal.
19//
20// NOTE:
21// The GPL does NOT permit the incorporation of this code into proprietary
22// programs. Please contact Quantum Leaps for commercial licensing options,
23// which expressly supersede the GPL and are designed explicitly for
24// closed-source distribution.
25//
26// Quantum Leaps contact information:
27// <www.state-machine.com/licensing>
28// <info@state-machine.com>
29//============================================================================
30#ifndef QS_DUMMY_HPP_
31#define QS_DUMMY_HPP_
32
33#ifdef Q_SPY
34 #error "Q_SPY must NOT be defined to include qs_dummy.hpp"
35#endif
36
37#ifdef Q_UTEST
38 #error "Q_UTEST must NOT be defined to include qs_dummy.hpp"
39#endif
40
41#define QS_INIT(arg_) (true)
42#define QS_EXIT() static_cast<void>(0)
43#define QS_DUMP() static_cast<void>(0)
44#define QS_GLB_FILTER(rec_) static_cast<void>(0)
45#define QS_LOC_FILTER(qsId_) static_cast<void>(0)
46
47#define QS_BEGIN_ID(rec_, qsId_) if (false) {
48#define QS_END() }
49#define QS_BEGIN_INCRIT(rec_, qsId_) if (false) {
50#define QS_END_INCRIT() }
51
52#define QS_I8(width_, data_) static_cast<void>(0)
53#define QS_U8(width_, data_) static_cast<void>(0)
54#define QS_I16(width_, data_) static_cast<void>(0)
55#define QS_U16(width_, data_) static_cast<void>(0)
56#define QS_I32(width_, data_) static_cast<void>(0)
57#define QS_U32(width_, data_) static_cast<void>(0)
58#define QS_F32(width_, data_) static_cast<void>(0)
59#define QS_F64(width_, data_) static_cast<void>(0)
60#define QS_I64(width_, data_) static_cast<void>(0)
61#define QS_U64(width_, data_) static_cast<void>(0)
62#define QS_ENUM(group_, value_) static_cast<void>(0)
63#define QS_STR(str_) static_cast<void>(0)
64#define QS_MEM(mem_, size_) static_cast<void>(0)
65#define QS_SIG(sig_, obj_) static_cast<void>(0)
66#define QS_OBJ(obj_) static_cast<void>(0)
67#define QS_FUN(fun_) static_cast<void>(0)
68
69#define QS_SIG_DICTIONARY(sig_, obj_) static_cast<void>(0)
70#define QS_OBJ_DICTIONARY(obj_) static_cast<void>(0)
71#define QS_OBJ_ARR_DICTIONARY(obj_, idx_) static_cast<void>(0)
72#define QS_FUN_DICTIONARY(fun_) static_cast<void>(0)
73#define QS_USR_DICTIONARY(rec_) static_cast<void>(0)
74#define QS_ENUM_DICTIONARY(value_, group_) static_cast<void>(0)
75#define QS_ASSERTION(module_, loc_, delay_) static_cast<void>(0)
76#define QS_FLUSH() static_cast<void>(0)
77
78#define QS_TEST_PROBE_DEF(fun_)
79#define QS_TEST_PROBE(code_)
80#define QS_TEST_PROBE_ID(id_, code_)
81#define QS_TEST_PAUSE() static_cast<void>(0)
82
83#define QS_OUTPUT() static_cast<void>(0)
84#define QS_RX_INPUT() static_cast<void>(0)
85#define QS_ONLY(code_) static_cast<void>(0)
86
87//============================================================================
88namespace QP {
89namespace QS {
90
91// QS API used inside applications
92#ifndef QS_TIME_SIZE
93 using QSTimeCtr = std::uint32_t;
94#elif (QS_TIME_SIZE == 2U)
95 using QSTimeCtr = std::uint16_t;
96#else
97 using QSTimeCtr = std::uint32_t;
98#endif
99
100void initBuf(std::uint8_t * const sto,
101 std::uint_fast32_t const stoSize) noexcept;
102std::uint16_t getByte() noexcept;
103std::uint8_t const *getBlock(std::uint16_t * const pNbytes) noexcept;
104void doOutput();
105bool onStartup(void const * arg);
107void onFlush();
109
110void rxInitBuf(std::uint8_t * const sto,
111 std::uint16_t const stoSize) noexcept;
112bool rxPut(std::uint8_t const b) noexcept;
113void rxParse();
114
115} // namespace QP
116} // namespace QS
117
118//============================================================================
119// QS API used inside test fixtures
120#ifdef Q_UTEST
121
122#if (QS_FUN_PTR_SIZE == 2U)
123 typedef uint16_t QSFun;
124#elif (QS_FUN_PTR_SIZE == 4U)
125 typedef uint32_t QSFun;
126#elif (QS_FUN_PTR_SIZE == 8U)
127 typedef uint64_t QSFun;
128#endif
129
130struct QS_TProbe {
131 QSFun addr;
132 uint32_t data;
133 uint8_t idx;
134};
135
136void QS_onTestSetup(void);
138void QS_onTestEvt(QEvt *e);
139void QS_onTestPost(void const *sender, QActive *recipient,
140 QEvt const *e, bool status);
141void QS_onTestLoop(void);
142
143#endif // def Q_UTEST
144
145//============================================================================
146// interface used only for internal implementation, but not in applications
147#ifdef QP_IMPL
148 // predefined QS trace records
149 #define QS_BEGIN_PRE(rec_, qsId_) if (false) {
150 #define QS_END_PRE() }
151 #define QS_U8_PRE(data_) static_cast<void>(0)
152 #define QS_2U8_PRE(data1_, data2_) static_cast<void>(0)
153 #define QS_U16_PRE(data_) static_cast<void>(0)
154 #define QS_U32_PRE(data_) static_cast<void>(0)
155 #define QS_TIME_PRE() static_cast<void>(0)
156 #define QS_SIG_PRE(sig_) static_cast<void>(0)
157 #define QS_EVS_PRE(size_) static_cast<void>(0)
158 #define QS_OBJ_PRE(obj_) static_cast<void>(0)
159 #define QS_FUN_PRE(fun_) static_cast<void>(0)
160 #define QS_EQC_PRE(ctr_) static_cast<void>(0)
161 #define QS_MPC_PRE(ctr_) static_cast<void>(0)
162 #define QS_MPS_PRE(size_) static_cast<void>(0)
163 #define QS_TEC_PRE(ctr_) static_cast<void>(0)
164
165 #define QS_CRIT_STAT
166 #define QS_CRIT_ENTRY() static_cast<void>(0)
167 #define QS_CRIT_EXIT() static_cast<void>(0)
168
169 #define QS_MEM_SYS() static_cast<void>(0)
170 #define QS_MEM_APP() static_cast<void>(0)
171
172 #define QS_TR_CRIT_ENTRY() static_cast<void>(0)
173 #define QS_TR_CRIT_EXIT() static_cast<void>(0)
174 #define QS_TR_ISR_ENTRY(isrnest_, prio_) static_cast<void>(0)
175 #define QS_TR_ISR_EXIT(isrnest_, prio_) static_cast<void>(0)
176#endif // QP_IMPL
177
178#endif // QS_DUMMY_HPP_
void rxInitBuf(std::uint8_t *const sto, std::uint16_t const stoSize) noexcept
std::uint8_t const * getBlock(std::uint16_t *const pNbytes) noexcept
std::uint16_t getByte() noexcept
std::uint32_t QSTimeCtr
Definition qs_dummy.hpp:97
void initBuf(std::uint8_t *const sto, std::uint_fast32_t const stoSize) noexcept
bool rxPut(std::uint8_t const b) noexcept
void onCleanup()
void doOutput()
void onFlush()
void rxParse()
QSTimeCtr onGetTime()
bool onStartup(void const *arg)
QP/C++ framework.
Definition qequeue.hpp:42
void QS_onTestPost(void const *sender, QActive *recipient, QEvt const *e, bool status)
void QS_onTestSetup(void)
void QS_onTestLoop(void)
void QS_onTestTeardown(void)
void QS_onTestEvt(QEvt *e)
uint8_t idx
Definition qs_dummy.hpp:133
QSFun addr
Definition qs_dummy.hpp:131
uint32_t data
Definition qs_dummy.hpp:132