FreeHIL
Loading...
Searching...
No Matches
FH_PWMO_SetStatus_H.c
Go to the documentation of this file.
1
/**
2
* @file
3
* @brief
4
* <b>File Map:</b>\n
5
* <b>FH_Root</b>, Section <b>FH_Perif</b>, <b>FH_PWMO</b> (Digital Output), <b>Cmd</b> (Command), <b>SetStatus</b>, <b>SetStatus_H</b> (SetStatus Health)\n
6
* Functions in this file, verify the health of the different message frames related to <b>PWMO_</b> (Digital Output)
7
*
8
* @attention <b>FH</b> user could left this file intact
9
*
10
*******************************************************************************
11
* SPDX-License-Identifier: Apache-2.0
12
*
13
* Copyright 2026 Vahid Hasirchi
14
*
15
* Licensed under the Apache License, Version 2.0 (the "License");
16
* you may not use this file except in compliance with the License.
17
* You may obtain a copy of the License at
18
*
19
* http://www.apache.org/licenses/LICENSE-2.0
20
*
21
* Unless required by applicable law or agreed to in writing, software
22
* distributed under the License is distributed on an "AS IS" BASIS,
23
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
24
* See the License for the specific language governing permissions and
25
* limitations under the License.
26
********************************************************************************
27
28
*
29
* <b>For more information refer to FreeHIL.com</b>
30
*
31
*/
32
33
/* Includes ------------------------------------------------------------------*/
34
#include "../../../../../../../FH_Embedded/FH_Root/FH_Perif/FH_PWMO/Cmd/SetStatus/SetStatus_H/FH_PWMO_SetStatus_H.h"
35
36
#include "../../../../../../../FH_Embedded/FH_Root/FH_General/FH_GeneralFunctions/FH_GeneralFunctions.h"
37
#include "
../../../../../../../FH_Embedded/FH_Setup/FH_DeviceAddress/FH_DeviceAddress.h
"
38
39
#if FH_PWMO_MaxPeripheralNumber > 0
// It is configurable in FH_DevicePeripherals.h
40
41
/**
42
* @brief This function verifies the health of <b>FH_PWMO_Commands_SetStatus</b> command
43
*
44
* @param fh_RFCommunication_Message
45
* The message frame set by <b>RobotFramework</b>
46
*
47
* @verbatim
48
==============================================================================
49
##### RobotFramework Example #####
50
==============================================================================
51
@{MessageData} = Create List ${PWMO01} 00 00 00 F0 32
52
&{Message} = Create Dictionary DeviceAddress=${DeviceAddress_01} Function=${Function_PWMO} Command=${PWMO_Commands_SetStatus} Data=@{MessageData}
53
${Result} SendMessage &{Message}
54
55
Comments:
56
57
PWMO01 => It indicates the PWM Output 01
58
00 00 00 F0 => Example data as PWM frequency (0x000000F0) to be set through the <b>PWM Output 01</b>\n
59
32 => Example data as PWM duty cycle (0x32 => as 50% duty cycle) to be set through the <b>PWM Output 01</b>\n
60
DeviceAddress_01 => It shall be equal to the address of the device: FH_RFCommunication_DeviceAddress
61
Function_PWMO => It is the function in the message frame
62
PWMO_Commands_SetStatus => It is the command of the function in the message frame
63
@endverbatim
64
*
65
* @return FH_ErrorInfo is returned
66
*
67
68
*/
69
FH_ErrorInfo
FH_PWMO_SetStatus_H(
FH_RFCommunication_Message
*
fh_RFCommunication_Message
)
70
{
71
FH_ErrorInfo
fh_ErrorInfo;
// Error Information
72
FH_ResetErrorInfo
(&fh_ErrorInfo);
// Reset Error Information to default
73
74
uint8_t FH_MessageDataLength;
// It temporarily stores the DataLength in the message frame
75
uint8_t FH_PeripheralNumber;
// It temporarily stores the PeripheralNumber (Data[0]) in the message frame
76
77
// Verifying the minimum possible length in the message frame
78
FH_MessageDataLength =
fh_RFCommunication_Message
-> DataLength;
79
if
(FH_MessageDataLength <
FH_PWMO_MinCommandSize_SetStatus
)
// If the length is less than expected value
80
{
81
fh_ErrorInfo.
error_code
=
FH_ERROR_MessageFrame
;
// There is message frame error
82
return
fh_ErrorInfo;
83
}
84
85
// Verifying the possible PeripheralNumber in the message frame
86
FH_PeripheralNumber =
fh_RFCommunication_Message
-> Data[0];
87
if
(FH_PeripheralNumber == 0 || FH_PeripheralNumber >
FH_PWMO_MaxPeripheralNumber
)
// If the PeripheralNumber is not within the expected value
88
{
89
fh_ErrorInfo.
error_code
=
FH_ERROR_MessageFrame
;
// There is message frame error
90
return
fh_ErrorInfo;
91
}
92
93
fh_ErrorInfo.
error_code
=
FH_ERROR_OK
;
// There is no error
94
return
fh_ErrorInfo;
95
}
96
97
#endif
Core
FH_Embedded
FH_Root
FH_Perif
FH_PWMO
Cmd
SetStatus
SetStatus_H
FH_PWMO_SetStatus_H.c
Generated by
1.15.0