File indexing completed on 2025-05-11 08:23:02
0001
0002
0003
0004
0005
0006
0007
0008
0009 #ifndef _FSL_XECC_H_
0010 #define _FSL_XECC_H_
0011
0012 #include "fsl_common.h"
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026 #define FSL_XECC_DRIVER_VERSION (MAKE_VERSION(2U, 0U, 0U))
0027
0028
0029
0030
0031
0032
0033
0034 enum
0035 {
0036 kXECC_SingleErrorInterruptEnable = XECC_ERR_SIG_EN_SINGLE_ERR_SIG_EN_MASK,
0037 kXECC_MultiErrorInterruptEnable = XECC_ERR_SIG_EN_MULTI_ERR_SIG_EN_MASK,
0038
0039 kXECC_AllInterruptsEnable =
0040 XECC_ERR_SIG_EN_SINGLE_ERR_SIG_EN_MASK | XECC_ERR_SIG_EN_MULTI_ERR_SIG_EN_MASK,
0041 };
0042
0043
0044
0045
0046
0047
0048 enum
0049 {
0050 kXECC_SingleErrorInterruptStatusEnable =
0051 XECC_ERR_STAT_EN_SINGLE_ERR_STAT_EN_MASK,
0052 kXECC_MultiErrorInterruptStatusEnable =
0053 XECC_ERR_STAT_EN_MULIT_ERR_STAT_EN_MASK,
0054
0055 kXECC_AllInterruptsStatusEnable = XECC_ERR_STAT_EN_SINGLE_ERR_STAT_EN_MASK |
0056 XECC_ERR_STAT_EN_MULIT_ERR_STAT_EN_MASK,
0057 };
0058
0059
0060
0061
0062
0063
0064 enum
0065 {
0066 kXECC_SingleErrorInterruptFlag =
0067 XECC_ERR_STATUS_SINGLE_ERR_MASK,
0068 kXECC_MultiErrorInterruptFlag =
0069 XECC_ERR_STATUS_MULTI_ERR_MASK,
0070
0071 kXECC_AllInterruptsFlag =
0072 XECC_ERR_STATUS_SINGLE_ERR_MASK | XECC_ERR_STATUS_MULTI_ERR_MASK,
0073 };
0074
0075
0076 typedef struct _xecc_config
0077 {
0078 bool enableXECC;
0079 bool enableWriteECC;
0080 bool enableReadECC;
0081 bool enableSwap;
0082
0083
0084 uint32_t Region0BaseAddress;
0085 uint32_t Region0EndAddress;
0086 uint32_t Region1BaseAddress;
0087 uint32_t Region1EndAddress;
0088 uint32_t Region2BaseAddress;
0089 uint32_t Region2EndAddress;
0090 uint32_t Region3BaseAddress;
0091 uint32_t Region3EndAddress;
0092 } xecc_config_t;
0093
0094
0095
0096 typedef struct _xecc_single_error_info
0097 {
0098 uint32_t singleErrorAddress;
0099 uint32_t singleErrorData;
0100 uint32_t singleErrorEccCode;
0101 uint32_t singleErrorBitPos;
0102 uint32_t singleErrorBitField;
0103 } xecc_single_error_info_t;
0104
0105
0106
0107 typedef struct _xecc_multi_error_info
0108 {
0109 uint32_t multiErrorAddress;
0110 uint32_t multiErrorData;
0111 uint32_t multiErrorEccCode;
0112 uint32_t multiErrorBitField;
0113 } xecc_multi_error_info_t;
0114
0115
0116
0117
0118
0119 #if defined(__cplusplus)
0120 extern "C" {
0121 #endif
0122
0123
0124
0125
0126
0127
0128
0129
0130
0131
0132
0133
0134 void XECC_Init(XECC_Type *base, const xecc_config_t *config);
0135
0136
0137
0138
0139
0140
0141 void XECC_Deinit(XECC_Type *base);
0142
0143
0144
0145
0146
0147
0148 void XECC_GetDefaultConfig(xecc_config_t *config);
0149
0150
0151
0152
0153
0154
0155
0156
0157
0158
0159
0160
0161
0162 static inline uint32_t XECC_GetStatusFlags(XECC_Type *base)
0163 {
0164 return base->ERR_STATUS & (uint32_t)kXECC_AllInterruptsFlag;
0165 }
0166
0167
0168
0169
0170
0171
0172
0173 static inline void XECC_ClearStatusFlags(XECC_Type *base, uint32_t mask)
0174 {
0175 base->ERR_STATUS = mask;
0176 }
0177
0178
0179
0180
0181
0182
0183
0184 static inline void XECC_EnableInterruptStatus(XECC_Type *base, uint32_t mask)
0185 {
0186 base->ERR_STAT_EN |= mask;
0187 }
0188
0189
0190
0191
0192
0193
0194
0195 static inline void XECC_DisableInterruptStatus(XECC_Type *base, uint32_t mask)
0196 {
0197 base->ERR_STAT_EN &= ~mask;
0198 }
0199
0200
0201
0202
0203
0204
0205
0206
0207
0208
0209
0210
0211
0212
0213 static inline void XECC_EnableInterrupts(XECC_Type *base, uint32_t mask)
0214 {
0215 base->ERR_SIG_EN |= mask;
0216 }
0217
0218
0219
0220
0221
0222
0223
0224 static inline void XECC_DisableInterrupts(XECC_Type *base, uint32_t mask)
0225 {
0226 base->ERR_SIG_EN &= ~mask;
0227 }
0228
0229
0230
0231
0232
0233
0234
0235
0236
0237
0238
0239
0240 static inline void XECC_WriteECCEnable(XECC_Type *base, bool enable)
0241 {
0242 if (enable)
0243 {
0244 base->ECC_CTRL |= XECC_ECC_CTRL_WECC_EN(1);
0245 }
0246 else
0247 {
0248 base->ECC_CTRL |= XECC_ECC_CTRL_WECC_EN(0);
0249 }
0250 }
0251
0252
0253
0254
0255
0256
0257
0258 static inline void XECC_ReadECCEnable(XECC_Type *base, bool enable)
0259 {
0260 if (enable)
0261 {
0262 base->ECC_CTRL |= XECC_ECC_CTRL_RECC_EN(1);
0263 }
0264 else
0265 {
0266 base->ECC_CTRL |= XECC_ECC_CTRL_RECC_EN(0);
0267 }
0268 }
0269
0270
0271
0272
0273
0274
0275
0276 static inline void XECC_SwapECCEnable(XECC_Type *base, bool enable)
0277 {
0278 if (enable)
0279 {
0280 base->ECC_CTRL |= XECC_ECC_CTRL_SWAP_EN(1);
0281 }
0282 else
0283 {
0284 base->ECC_CTRL |= XECC_ECC_CTRL_SWAP_EN(0);
0285 }
0286 }
0287
0288
0289
0290
0291
0292
0293
0294
0295
0296 status_t XECC_ErrorInjection(XECC_Type *base, uint32_t errordata, uint8_t erroreccdata);
0297
0298
0299
0300
0301
0302
0303
0304 void XECC_GetSingleErrorInfo(XECC_Type *base, xecc_single_error_info_t *info);
0305
0306
0307
0308
0309
0310
0311
0312 void XECC_GetMultiErrorInfo(XECC_Type *base, xecc_multi_error_info_t *info);
0313
0314
0315
0316 #if defined(__cplusplus)
0317 }
0318 #endif
0319
0320
0321
0322 #endif