Imt.Base C++ API V4.1.1.0
Loading...
Searching...
No Matches
ExecutableConfiguration.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_EXECUTABLECONFIGURATION_H
37#define IMT_BASE_DFF_RUNTIME_EXECUTABLECONFIGURATION_H
38
41
42namespace imt {
43namespace base {
44namespace dff {
45namespace runtime {
46
61
62public:
63
69
73 // AXIVION Next Construct AutosarC++19_03-A11.0.1: Allowed usage
74 // AXIVION Next Construct AutosarC++19_03-M11.0.1: Allowed usage
75 struct StackSize {
76
77 //
82
87 explicit StackSize(size_t const units);
88
92 bool m_isSet;
93
97 size_t m_units;
98 };
99
103 // AXIVION Next Construct AutosarC++19_03-A11.0.1: Allowed usage
104 // AXIVION Next Construct AutosarC++19_03-M11.0.1: Allowed usage
105 struct TimeSlice {
106
111
116 explicit TimeSlice(uint32_t const units);
117
122
127 };
128
132 // AXIVION Next Construct AutosarC++19_03-A11.0.1: Allowed usage
133 // AXIVION Next Construct AutosarC++19_03-M11.0.1: Allowed usage
135
140
145 explicit CoreAffinity(uint32_t const exeCoreId);
146
151
156 };
157
163
168 explicit ExecutableConfiguration(char_t const* const pName);
169
174 explicit ExecutableConfiguration(StackSize const exeStackSize);
175
180 explicit ExecutableConfiguration(TimeSlice const exeTimeSlice);
181
186 explicit ExecutableConfiguration(CoreAffinity const exeCoreAffinity);
187
194 ExecutableConfiguration(char_t const* const pName, StackSize const exeStackSize, TimeSlice const exeTimeSlice);
195
203 explicit ExecutableConfiguration(char_t const* const pName, StackSize const exeStackSize, TimeSlice const exeTimeSlice, CoreAffinity const exeCoreAffinity);
204
210 char_t const* getName() const;
211
217 size_t getStackSize() const;
218
225
231
236 bool isNameDefined() const;
237
242 bool isStackSizeDefined() const;
243
248 bool isTimeSliceDefined() const;
249
255
256private:
257
258 char_t const* m_pName;
259 StackSize const m_stackSize;
260 TimeSlice const m_timeSlice;
261 CoreAffinity const m_coreAffinity;
262};
263
264} // namespace runtime
265} // namespace dff
266} // namespace base
267} // namespace imt
268
269#endif // IMT_BASE_DFF_RUNTIME_EXECUTABLECONFIGURATION_H
Optional parameters that can be passed from the active part to the runtime to be considered when crea...
CoreId getCoreAffinity() const
Get the requested core affinity for the executable.
ExecutableConfiguration(char_t const *const pName)
Custom constructor to set the executable name only.
char_t const * getName() const
Get the requested name for the executable.
ExecutableConfiguration(StackSize const exeStackSize)
Custom constructor to set the stack size only.
size_t getStackSize() const
Get the requested stack size for the executable.
ExecutableConfiguration(CoreAffinity const exeCoreAffinity)
Custom constructor to set the core affinity only.
uint32_t CoreId
A CoreId is used to indicate in which core the executable should run.
uint32_t getTimeSlice() const
Get the requested time slice for the executable.
bool isTimeSliceDefined() const
Returns wether a time slice is defined for the executable.
bool isNameDefined() const
Returns wether a name is defined for the executable.
ExecutableConfiguration(char_t const *const pName, StackSize const exeStackSize, TimeSlice const exeTimeSlice)
Custom constructor to set all configuration parameters.
ExecutableConfiguration(TimeSlice const exeTimeSlice)
Custom constructor to set the time slice only.
bool isStackSizeDefined() const
Returns wether a stack size is defined for the executable.
bool isCoreAffinityDefined() const
Returns whether a core affinity is defined for the executable.
ExecutableConfiguration(char_t const *const pName, StackSize const exeStackSize, TimeSlice const exeTimeSlice, CoreAffinity const exeCoreAffinity)
Custom constructor to set all configuration parameters.
This is a application specific file which is used to configure Imt.Base.Core.Math.
char char_t
The char_t typedef does not indicate size and signedness and is simply included to allow char objects...
Definition stdchar.h:55
unsigned __int32 uint32_t
Definition stdint.h:64
uint32_t m_coreId
Indicates the core in which the executable should run.
size_t m_units
The stack size in the size unit used by the runtime.
uint32_t m_units
The time slice in the size unit used by the runtime.