Imt.Base C++ API V4.1.1.0
Loading...
Searching...
No Matches
Mailbox.h
Go to the documentation of this file.
1// (c) IMT - Information Management Technology AG, CH-9470 Buchs, www.imt.ch.
2//
3// ActiveParts (AP) and the corresponding Data Flow Framework (DFF) is invented and designed by Jakob Daescher.
4// ANY USE OF THIS CODE CONSTITUTES ACCEPTANCE OF THE TERMS OF THE COPYRIGHT NOTICE.
5// ===================================================================================================
6// COPYRIGHT NOTICE
7// ===================================================================================================
8// Copyright (C) 2005-2075, IMT Information Management Technology AG, 9470 Buchs, Switzerland
9// All rights reserved.
10// This code is proprietary software of IMT Information Management Technology AG (hereinafter: "IMT").
11// Proprietary software is computer software licensed under exclusive legal right of IMT.
12//
13// The licensee is given the irrevocable, perpetual, worldwide, non-exclusive right and license to use,
14// execute and reproduce the software in binary form within the licensed products.
15//
16// Redistribution and use in source forms, without modification, are permitted provided that the following conditions are met:
17// (1) Copying of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
18// (2) Copying of source code is only allowed for regulatory documentation and archiving purposes
19// (3) Redistributions in binary form must reproduce the above copyright notice,
20// this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
21//
22// IMT provide no reassurances that the source code provided does not infringe
23// any patent, copyright, or any other intellectual property rights of third parties.
24// IMT disclaim any liability to any recipient for claims brought against
25// recipient by any third party for infringement of that parties intellectual property rights.
26//
27// THIS SOFTWARE IS PROVIDED BY IMT AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
28// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
29// IN NO EVENT SHALL IMT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
30// OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCURE-MENT OF SUBSTITUTE GOODS OR SERVICES;
31// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
32// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
33// IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34// ===================================================================================================
35
36#ifndef IMT_BASE_DFF_RUNTIME_RTOS_MAILBOX_H
37#define IMT_BASE_DFF_RUNTIME_RTOS_MAILBOX_H
38
42
43namespace imt {
44namespace base {
45namespace dff {
46namespace runtime {
47namespace rtos {
48
52template<typename MessageType, size_t const MailboxSize>
54
55public:
56
62
67 inline void initialize();
68
72 inline void deinitialize();
73
77 inline void clear();
78
85 inline MessageType getMail();
86
94 inline bool getMailConditional(MessageType* const pMail);
95
102 inline void putMail(MessageType const message);
103
111 inline bool putMailConditional(MessageType const message);
112
118 inline void waitMail();
119
120private:
121
122 void serialize(MessageType const message, uint8_t* const pData);
123 MessageType deserialize(uint8_t const* const pData);
124
125 uint8_t m_buffer[MailboxSize * sizeof(MessageType)];
127};
128
130
131// public interface
132template<typename MessageType, size_t const MailboxSize>
134 m_buffer {},
135 m_impl {impl} {
136}
137
138template<typename MessageType, size_t const MailboxSize>
140 m_impl.initialize(m_buffer, sizeof(MessageType), MailboxSize);
141}
142
143template<typename MessageType, size_t const MailboxSize>
145 m_impl.deinitialize();
146}
147
148template<typename MessageType, size_t const MailboxSize>
150 m_impl.clear();
151}
152
153template<typename MessageType, size_t const MailboxSize>
155 uint8_t data[sizeof(MessageType)];
156 m_impl.getMail(data, sizeof(MessageType));
157 return deserialize(data);
158}
159
160template<typename MessageType, size_t const MailboxSize>
161inline bool Mailbox<MessageType, MailboxSize>::getMailConditional(MessageType* const pMessage) {
162 if (pMessage == nullptr) {
163 ASSERT_DEBUG(false); // null pointer
164 return false;
165 }
166
167 uint8_t data[sizeof(MessageType)];
168 if (!m_impl.getMailConditional(data, sizeof(MessageType))) {
169 return false;
170 }
171
172 *pMessage = deserialize(data);
173 return true;
174}
175
176template<typename MessageType, size_t const MailboxSize>
177inline void Mailbox<MessageType, MailboxSize>::putMail(MessageType const message) {
178 uint8_t data[sizeof(MessageType)];
179 serialize(message, data);
180 m_impl.putMail(data, sizeof(MessageType));
181}
182
183template<typename MessageType, size_t const MailboxSize>
184inline bool Mailbox<MessageType, MailboxSize>::putMailConditional(MessageType const message) {
185 uint8_t data[sizeof(MessageType)];
186 serialize(message, data);
187 return m_impl.putMailConditional(data, sizeof(MessageType));
188}
189
190template<typename MessageType, size_t const MailboxSize>
191void Mailbox<MessageType, MailboxSize>::serialize(MessageType const message, uint8_t* const pData) {
192 if (pData == nullptr) {
193 ASSERT_DEBUG(false); // null pointer
194 return;
195 }
196
197 size_t offset {0};
198 for (size_t i {0}; i < sizeof(MessageType); ++i) {
199 pData[i] = static_cast<uint8_t>(message >> offset);
200 offset += 8;
201 }
202}
203
204template<typename MessageType, size_t const MailboxSize>
205MessageType Mailbox<MessageType, MailboxSize>::deserialize(uint8_t const* const pData) {
206 if (pData == nullptr) {
207 ASSERT_DEBUG(false); // null pointer
208 return 0;
209 }
210
211 MessageType message {0};
212 size_t offset {0U};
213 for (size_t i {0}; i < sizeof(MessageType); ++i) {
214 message |= (pData[i] << offset);
215 offset += 8U;
216 }
217 return message;
218}
219
220} // namespace rtos
221} // namespace runtime
222} // namespace dff
223} // namespace base
224} // namespace imt
225
226#endif // IMT_BASE_DFF_RUNTIME_RTOS_MAILBOX_H
void ASSERT_DEBUG(bool const condition) noexcept
Definition Diagnostics.h:88
Base class for a non copyable class that disables copy and assignment of instances.
Definition Noncopyable.h:51
A Mailbox represents an abstract way for runtime to send/receive events with fixed size messages from...
Definition Mailbox.h:53
void deinitialize()
Deletes the mailbox.
Definition Mailbox.h:144
void putMail(MessageType const message)
Adds a message to the mailbox.
Definition Mailbox.h:177
bool getMailConditional(MessageType *const pMail)
Gets the next message from the mailbox.
Definition Mailbox.h:161
MessageType getMail()
Gets the next message from the mailbox.
Definition Mailbox.h:154
void initialize()
Init the mailbox.
Definition Mailbox.h:139
bool putMailConditional(MessageType const message)
Adds a message to the mailbox.
Definition Mailbox.h:184
void waitMail()
This method returns imediately when the mailbox contains at least one message.
Mailbox(imt::base::dff::runtime::rtos::MailboxImplIfc &impl)
Constructor.
Definition Mailbox.h:133
void clear()
Removes all messages from the mailbox.
Definition Mailbox.h:149
This interface represents the actual implementation of the mailbox with a fixed size byte array as me...
This is a application specific file which is used to configure Imt.Base.Core.Math.
unsigned __int8 uint8_t
Definition stdint.h:62