iLLD_TC27xD  1.0
IfxFce.h
Go to the documentation of this file.
1 /**
2  * \file IfxFce.h
3  * \brief FCE basic functionality
4  * \ingroup IfxLld_Fce
5  *
6  * \version iLLD_1_0_0_11_0
7  * \copyright Copyright (c) 2013 Infineon Technologies AG. All rights reserved.
8  *
9  *
10  * IMPORTANT NOTICE
11  *
12  *
13  * Infineon Technologies AG (Infineon) is supplying this file for use
14  * exclusively with Infineon's microcontroller products. This file can be freely
15  * distributed within development tools that are supporting such microcontroller
16  * products.
17  *
18  * THIS SOFTWARE IS PROVIDED "AS IS". NO WARRANTIES, WHETHER EXPRESS, IMPLIED
19  * OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
20  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.
21  * INFINEON SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL,
22  * OR CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
23  *
24  *
25  * \defgroup IfxLld_Fce_Std_Enum Enumerations
26  * \ingroup IfxLld_Fce_Std
27  * \defgroup IfxLld_Fce_Std_Module Module Functions
28  * \ingroup IfxLld_Fce_Std
29  * \defgroup IfxLld_Fce_Std_Support Support Function
30  * \ingroup IfxLld_Fce_Std
31  * \defgroup IfxLld_Fce_Std_InterruptStatus Interrupt Status Functions
32  * \ingroup IfxLld_Fce_Std
33  */
34 
35 #ifndef IFXFCE_H
36 #define IFXFCE_H 1
37 
38 /******************************************************************************/
39 /*----------------------------------Includes----------------------------------*/
40 /******************************************************************************/
41 
42 #include "_Impl/IfxFce_cfg.h"
44 #include "Scu/Std/IfxScuWdt.h"
45 #include "IfxFce_reg.h"
46 #include "Src/Std/IfxSrc.h"
47 
48 /******************************************************************************/
49 /*--------------------------------Enumerations--------------------------------*/
50 /******************************************************************************/
51 
52 /** \addtogroup IfxLld_Fce_Std_Enum
53  * \{ */
54 /** \brief Ifx_FCE_INx(x= 0,1), Specifies the kernel used for CRC-32
55  */
56 typedef enum
57 {
58  IfxFce_Crc32Kernel_0 = 0, /**< \brief Specifies the kernel 0 used for CRC-32 */
59  IfxFce_Crc32Kernel_1 /**< \brief Specifies the kernel 1 used for CRC-32 */
61 
62 /** \brief Specifies the CRC mode
63  */
64 typedef enum
65 {
66  IfxFce_CrcMode_8 = 0, /**< \brief Specifies the 8-bit CRC mode */
67  IfxFce_CrcMode_16 = 1, /**< \brief Specifies the 16-bit CRC mode */
68  IfxFce_CrcMode_32 = 2 /**< \brief Specifies the 32-bit CRC mode */
70 
71 /** \} */
72 
73 /** \addtogroup IfxLld_Fce_Std_Module
74  * \{ */
75 
76 /******************************************************************************/
77 /*-------------------------Inline Function Prototypes-------------------------*/
78 /******************************************************************************/
79 
80 /** \brief Enable the control of FCE module
81  * \param fce Specifies pointer to FCE module registers
82  * \return None
83  */
84 IFX_INLINE void IfxFce_enableModule(Ifx_FCE *fce);
85 
86 /******************************************************************************/
87 /*-------------------------Global Function Prototypes-------------------------*/
88 /******************************************************************************/
89 
90 /** \brief Reset the module by clearing the kernel
91  * \param fce Specifies pointer to FCE module registers
92  * \return None
93  */
94 IFX_EXTERN void IfxFce_resetModule(Ifx_FCE *fce);
95 
96 /** \} */
97 
98 /** \addtogroup IfxLld_Fce_Std_Support
99  * \{ */
100 
101 /******************************************************************************/
102 /*-------------------------Global Function Prototypes-------------------------*/
103 /******************************************************************************/
104 
105 /** \brief Reflects the CRC data and returns it
106  * \param crcStartValue start value for reflection
107  * \param crcLength length of reflected value
108  * \return Reflected CRC data
109  */
110 IFX_EXTERN uint32 IfxFce_reflectCrc32(uint32 crcStartValue, uint8 crcLength);
111 
112 /** \} */
113 
114 /** \addtogroup IfxLld_Fce_Std_InterruptStatus
115  * \{ */
116 
117 /******************************************************************************/
118 /*-------------------------Inline Function Prototypes-------------------------*/
119 /******************************************************************************/
120 
121 /** \brief Clears the CRC-16 error flags
122  * \param fce Specifies pointer to FCE module registers
123  * \return None
124  */
125 IFX_INLINE void IfxFce_clearCrc16ErrorFlags(Ifx_FCE *fce);
126 
127 /** \brief Clears the CRC-32 error flags
128  * \param fce Specifies pointer to FCE module registers
129  * \param crc32Kernel Specifies the kernel used for CRC-32
130  * \return None
131  */
132 IFX_INLINE void IfxFce_clearCrc32ErrorFlags(Ifx_FCE *fce, IfxFce_Crc32Kernel crc32Kernel);
133 
134 /** \brief Clears the CRC-8 error flags
135  * \param fce Specifies pointer to FCE module registers
136  * \return None
137  */
138 IFX_INLINE void IfxFce_clearCrc8ErrorFlags(Ifx_FCE *fce);
139 
140 /** \brief Returns the SRC pointer for FCE
141  * \param fce Specifies pointer to FCE module registers
142  */
143 IFX_INLINE volatile Ifx_SRC_SRCR *IfxFce_getSrcPointer(Ifx_FCE *fce);
144 
145 /******************************************************************************/
146 /*-------------------------Global Function Prototypes-------------------------*/
147 /******************************************************************************/
148 
149 /** \brief Gets the CRC-16 interrupt status
150  * \param fce Specifies pointer to FCE module registers
151  * \return Current CRC-16 interrupt status
152  */
153 IFX_EXTERN Ifx_FCE_STS IfxFce_getCrc16InterruptStatus(Ifx_FCE *fce);
154 
155 /** \brief Gets the CRC-32 interrupt status
156  * \param fce Specifies pointer to FCE module registers
157  * \param crc32Kernel Specifies the kernel used for CRC-32
158  * \return Current CRC-32 interrupt status
159  */
160 IFX_EXTERN Ifx_FCE_STS IfxFce_getCrc32InterruptStatus(Ifx_FCE *fce, IfxFce_Crc32Kernel crc32Kernel);
161 
162 /** \brief Gets the CRC-8 interrupt status
163  * \param fce Specifies pointer to FCE module registers
164  * \return Current CRC-8 interrupt status
165  */
166 IFX_EXTERN Ifx_FCE_STS IfxFce_getCrc8InterruptStatus(Ifx_FCE *fce);
167 
168 /** \} */
169 
170 /******************************************************************************/
171 /*---------------------Inline Function Implementations------------------------*/
172 /******************************************************************************/
173 
175 {
176  fce->IN2.STS.U = 0x00000001U;
177 }
178 
179 
181 {
182  if (crc32Kernel == IfxFce_Crc32Kernel_0)
183  {
184  fce->IN0.STS.U = 0x00000001U;
185  }
186  else
187  {
188  fce->IN1.STS.U = 0x00000001U;
189  }
190 }
191 
192 
194 {
195  fce->IN3.STS.U = 0x00000001U;
196 }
197 
198 
199 IFX_INLINE void IfxFce_enableModule(Ifx_FCE *fce)
200 {
201  fce->CLC.B.DISR = 0;
202 }
203 
204 
205 IFX_INLINE volatile Ifx_SRC_SRCR *IfxFce_getSrcPointer(Ifx_FCE *fce)
206 {
207  return &SRC_FCE;
208 }
209 
210 
211 #endif /* IFXFCE_H */