File indexing completed on 2025-05-11 08:22:58
0001
0002
0003
0004
0005
0006
0007
0008
0009 #include "fsl_adc.h"
0010
0011
0012 #ifndef FSL_COMPONENT_ID
0013 #define FSL_COMPONENT_ID "platform.drivers.adc_12b1msps_sar"
0014 #endif
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024 static uint32_t ADC_GetInstance(ADC_Type *base);
0025
0026
0027
0028
0029
0030 static ADC_Type *const s_adcBases[] = ADC_BASE_PTRS;
0031
0032 #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
0033
0034 static const clock_ip_name_t s_adcClocks[] = ADC_CLOCKS;
0035 #endif
0036
0037
0038
0039
0040 static uint32_t ADC_GetInstance(ADC_Type *base)
0041 {
0042 uint32_t instance;
0043
0044
0045 for (instance = 0; instance < ARRAY_SIZE(s_adcBases); instance++)
0046 {
0047 if (s_adcBases[instance] == base)
0048 {
0049 break;
0050 }
0051 }
0052
0053 assert(instance < ARRAY_SIZE(s_adcBases));
0054
0055 return instance;
0056 }
0057
0058
0059
0060
0061
0062
0063
0064 void ADC_Init(ADC_Type *base, const adc_config_t *config)
0065 {
0066 assert(NULL != config);
0067
0068 uint32_t tmp32;
0069
0070 #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
0071
0072 CLOCK_EnableClock(s_adcClocks[ADC_GetInstance(base)]);
0073 #endif
0074
0075 tmp32 = base->CFG & (ADC_CFG_AVGS_MASK | ADC_CFG_ADTRG_MASK);
0076 tmp32 |= ADC_CFG_REFSEL(config->referenceVoltageSource) | ADC_CFG_ADSTS(config->samplePeriodMode) |
0077 ADC_CFG_ADICLK(config->clockSource) | ADC_CFG_ADIV(config->clockDriver) | ADC_CFG_MODE(config->resolution);
0078 if (config->enableOverWrite)
0079 {
0080 tmp32 |= ADC_CFG_OVWREN_MASK;
0081 }
0082 if (config->enableLongSample)
0083 {
0084 tmp32 |= ADC_CFG_ADLSMP_MASK;
0085 }
0086 if (config->enableLowPower)
0087 {
0088 tmp32 |= ADC_CFG_ADLPC_MASK;
0089 }
0090 if (config->enableHighSpeed)
0091 {
0092 tmp32 |= ADC_CFG_ADHSC_MASK;
0093 }
0094 base->CFG = tmp32;
0095
0096
0097 tmp32 = base->GC & ~(ADC_GC_ADCO_MASK | ADC_GC_ADACKEN_MASK);
0098 if (config->enableContinuousConversion)
0099 {
0100 tmp32 |= ADC_GC_ADCO_MASK;
0101 }
0102 if (config->enableAsynchronousClockOutput)
0103 {
0104 tmp32 |= ADC_GC_ADACKEN_MASK;
0105 }
0106 base->GC = tmp32;
0107 }
0108
0109
0110
0111
0112
0113
0114 void ADC_Deinit(ADC_Type *base)
0115 {
0116 #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
0117
0118 CLOCK_DisableClock(s_adcClocks[ADC_GetInstance(base)]);
0119 #endif
0120 }
0121
0122
0123
0124
0125
0126
0127
0128
0129
0130
0131
0132
0133
0134
0135
0136
0137
0138
0139
0140
0141
0142 void ADC_GetDefaultConfig(adc_config_t *config)
0143 {
0144 assert(NULL != config);
0145
0146
0147 (void)memset(config, 0, sizeof(*config));
0148
0149 config->enableAsynchronousClockOutput = true;
0150 config->enableOverWrite = false;
0151 config->enableContinuousConversion = false;
0152 config->enableHighSpeed = false;
0153 config->enableLowPower = false;
0154 config->enableLongSample = false;
0155 config->referenceVoltageSource = kADC_ReferenceVoltageSourceAlt0;
0156 config->samplePeriodMode = kADC_SamplePeriod2or12Clocks;
0157 config->clockSource = kADC_ClockSourceAD;
0158 config->clockDriver = kADC_ClockDriver1;
0159 config->resolution = kADC_Resolution12Bit;
0160 }
0161
0162
0163
0164
0165
0166
0167
0168
0169
0170
0171
0172
0173
0174
0175
0176
0177
0178
0179
0180
0181
0182
0183
0184
0185
0186
0187
0188
0189 void ADC_SetChannelConfig(ADC_Type *base, uint32_t channelGroup, const adc_channel_config_t *config)
0190 {
0191 assert(NULL != config);
0192 assert(channelGroup < (uint32_t)FSL_FEATURE_ADC_CONVERSION_CONTROL_COUNT);
0193
0194 uint32_t tmp32;
0195
0196 tmp32 = ADC_HC_ADCH(config->channelNumber);
0197 if (config->enableInterruptOnConversionCompleted)
0198 {
0199 tmp32 |= ADC_HC_AIEN_MASK;
0200 }
0201 base->HC[channelGroup] = tmp32;
0202 }
0203
0204
0205
0206
0207
0208
0209
0210
0211
0212
0213
0214
0215
0216
0217
0218
0219
0220
0221
0222
0223
0224 status_t ADC_DoAutoCalibration(ADC_Type *base)
0225 {
0226 status_t status = kStatus_Success;
0227 #if !(defined(FSL_FEATURE_ADC_SUPPORT_HARDWARE_TRIGGER_REMOVE) && FSL_FEATURE_ADC_SUPPORT_HARDWARE_TRIGGER_REMOVE)
0228 bool bHWTrigger = false;
0229
0230
0231
0232 if (0U != (ADC_CFG_ADTRG_MASK & base->CFG))
0233 {
0234 bHWTrigger = true;
0235 ADC_EnableHardwareTrigger(base, false);
0236 }
0237 #endif
0238
0239
0240 base->GS = ADC_GS_CALF_MASK;
0241 base->GC |= ADC_GC_CAL_MASK;
0242
0243
0244 while (0U != (base->GC & ADC_GC_CAL_MASK))
0245 {
0246
0247 if (0U != (ADC_GetStatusFlags(base) & (uint32_t)kADC_CalibrationFailedFlag))
0248 {
0249 status = kStatus_Fail;
0250 break;
0251 }
0252 }
0253
0254
0255 if (0U == ADC_GetChannelStatusFlags(base, 0U))
0256 {
0257 status = kStatus_Fail;
0258 }
0259 if (0U != (ADC_GetStatusFlags(base) & (uint32_t)kADC_CalibrationFailedFlag))
0260 {
0261 status = kStatus_Fail;
0262 }
0263
0264
0265 (void)ADC_GetChannelConversionValue(base, 0U);
0266
0267 #if !(defined(FSL_FEATURE_ADC_SUPPORT_HARDWARE_TRIGGER_REMOVE) && FSL_FEATURE_ADC_SUPPORT_HARDWARE_TRIGGER_REMOVE)
0268
0269 if (true == bHWTrigger)
0270 {
0271 ADC_EnableHardwareTrigger(base, true);
0272 }
0273 #endif
0274
0275 return status;
0276 }
0277
0278
0279
0280
0281
0282
0283
0284 void ADC_SetOffsetConfig(ADC_Type *base, const adc_offest_config_t *config)
0285 {
0286 assert(NULL != config);
0287
0288 uint32_t tmp32;
0289
0290 tmp32 = ADC_OFS_OFS(config->offsetValue);
0291 if (config->enableSigned)
0292 {
0293 tmp32 |= ADC_OFS_SIGN_MASK;
0294 }
0295 base->OFS = tmp32;
0296 }
0297
0298
0299
0300
0301
0302
0303
0304
0305
0306
0307
0308
0309
0310
0311 void ADC_SetHardwareCompareConfig(ADC_Type *base, const adc_hardware_compare_config_t *config)
0312 {
0313 uint32_t tmp32;
0314
0315 tmp32 = base->GC & ~(ADC_GC_ACFE_MASK | ADC_GC_ACFGT_MASK | ADC_GC_ACREN_MASK);
0316 if (NULL == config)
0317 {
0318 base->GC = tmp32;
0319 return;
0320 }
0321
0322 tmp32 |= ADC_GC_ACFE_MASK;
0323
0324
0325 switch (config->hardwareCompareMode)
0326 {
0327 case kADC_HardwareCompareMode0:
0328 break;
0329 case kADC_HardwareCompareMode1:
0330 tmp32 |= ADC_GC_ACFGT_MASK;
0331 break;
0332 case kADC_HardwareCompareMode2:
0333 tmp32 |= ADC_GC_ACREN_MASK;
0334 break;
0335 case kADC_HardwareCompareMode3:
0336 tmp32 |= ADC_GC_ACFGT_MASK | ADC_GC_ACREN_MASK;
0337 break;
0338 default:
0339 assert(false);
0340 break;
0341 }
0342 base->GC = tmp32;
0343
0344
0345 tmp32 = ADC_CV_CV1(config->value1) | ADC_CV_CV2(config->value2);
0346 base->CV = tmp32;
0347 }
0348
0349
0350
0351
0352
0353
0354
0355
0356
0357
0358
0359 void ADC_SetHardwareAverageConfig(ADC_Type *base, adc_hardware_average_mode_t mode)
0360 {
0361 uint32_t tmp32;
0362
0363 if (mode == kADC_HardwareAverageDiasable)
0364 {
0365 base->GC &= ~ADC_GC_AVGE_MASK;
0366 }
0367 else
0368 {
0369 tmp32 = base->CFG & ~ADC_CFG_AVGS_MASK;
0370 tmp32 |= ADC_CFG_AVGS(mode);
0371 base->CFG = tmp32;
0372 base->GC |= ADC_GC_AVGE_MASK;
0373 }
0374 }
0375
0376
0377
0378
0379
0380
0381
0382 void ADC_ClearStatusFlags(ADC_Type *base, uint32_t mask)
0383 {
0384 uint32_t tmp32 = 0;
0385
0386 if (0U != (mask & (uint32_t)kADC_CalibrationFailedFlag))
0387 {
0388 tmp32 |= ADC_GS_CALF_MASK;
0389 }
0390 if (0U != (mask & (uint32_t)kADC_ConversionActiveFlag))
0391 {
0392 tmp32 |= ADC_GS_ADACT_MASK;
0393 }
0394 base->GS = tmp32;
0395 }