/** * @file JABitReverseGAM.cpp * @brief Source file for class JABitReverseGAM * @date Nov 26, 2018 * @author aneto * * @copyright Copyright 2015 F4E | European Joint Undertaking for ITER and * the Development of Fusion Energy ('Fusion for Energy'). * Licensed under the EUPL, Version 1.1 or - as soon they will be approved * by the European Commission - subsequent versions of the EUPL (the "Licence") * You may not use this work except in compliance with the Licence. * You may obtain a copy of the Licence at: http://ec.europa.eu/idabc/eupl * * @warning Unless required by applicable law or agreed to in writing, * software distributed under the Licence is distributed on an "AS IS" * basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express * or implied. See the Licence permissions and limitations under the Licence. * @details This source file contains the definition of all the methods for * the class JABitReverseGAM (public, protected, and private). Be aware that some * methods, such as those inline could be defined on the header file, instead. */ /*---------------------------------------------------------------------------*/ /* Standard header includes */ /*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/ /* Project header includes */ /*---------------------------------------------------------------------------*/ #include "JABitReverseGAM.h" #include "AdvancedErrorManagement.h" /*---------------------------------------------------------------------------*/ /* Static definitions */ /*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/ /* Method definitions */ /*---------------------------------------------------------------------------*/ JABitReverseGAM::JABitReverseGAM() { //Input signals. input1 = NULL_PTR(MARTe::uint8 *); //Output signals. output1= NULL_PTR(MARTe::uint8 *); } JABitReverseGAM::~JABitReverseGAM() { } bool JABitReverseGAM::Initialise(MARTe::StructuredDataI & data) { //GAM parameters are initialized. using namespace MARTe; bool ok = GAM::Initialise(data); return ok; } bool JABitReverseGAM::PrepareNextState(const MARTe::char8 * const currentStateName, const MARTe::char8 * const nextStateName) { //This method changes internal parameter based on next realtime state. return true; } bool JABitReverseGAM::Setup() { // Setup memory for input/output signals on the GAM. using namespace MARTe; bool ok = (numberOfInputSignals == 1u); if (ok) { ok = (numberOfOutputSignals == 1u); if (!ok) { REPORT_ERROR(MARTe::ErrorManagement::ParametersError, "One output signal shall be defined"); } } else { REPORT_ERROR(MARTe::ErrorManagement::ParametersError, "One input signals shall be defined"); } // Do type check for input signals. if (ok) { uint32 c; for (c = 0u; c < numberOfInputSignals; c++) { TypeDescriptor inputType = GetSignalType(InputSignals, c); ok = ((inputType == UnsignedInteger8Bit)); if (!ok) { StreamString signalName; (void) GetSignalName(InputSignals, c, signalName); REPORT_ERROR(MARTe::ErrorManagement::ParametersError, "Signal %s shall be defined as uint8.", signalName.Buffer()); } } } // Do type check for output signals if (ok) { uint32 c; for (c = 0u; c < numberOfOutputSignals; c++) { TypeDescriptor outputType = GetSignalType(OutputSignals, c); ok = ((outputType == UnsignedInteger8Bit)); if (!ok) { StreamString signalName; (void) GetSignalName(InputSignals, c, signalName); REPORT_ERROR(MARTe::ErrorManagement::ParametersError, "Signal %s shall be defined as uint8.", signalName.Buffer()); } } } // Do type cast. if (ok) { input1 = reinterpret_cast(GetInputSignalMemory(0)); output1 = reinterpret_cast(GetOutputSignalMemory(0)); } return ok; } bool JABitReverseGAM::Execute() { // This method is called every realtime state thread cycle. using namespace MARTe; *output1 = ~(*input1); return true; } CLASS_REGISTER(JABitReverseGAM, "1.0")