1#include "../../../hardware_api.h"
3#if defined(STM32G4xx) && !defined(ARDUINO_B_G431B_ESC1)
5#include "../../../../common/foc_utils.h"
6#include "../../../../drivers/hardware_api.h"
7#include "../../../../drivers/hardware_specific/stm32/stm32_mcu.h"
8#include "../../../hardware_api.h"
9#include "../stm32_mcu.h"
10#include "../stm32_adc_utils.h"
16#define _ADC_VOLTAGE_G4 3.3f
17#define _ADC_RESOLUTION_G4 4096.0f
20uint32_t adc_val[5][4]={0};
22#ifdef SIMPLEFOC_STM32_ADC_INTERRUPT
23#define USE_ADC_INTERRUPT 1
25#define USE_ADC_INTERRUPT 0
29Stm32AdcInterruptConfig adc_interrupt_config[5] = {
30 {0, 0, USE_ADC_INTERRUPT},
31 {0, 0, USE_ADC_INTERRUPT},
32 {0, 0, USE_ADC_INTERRUPT},
33 {0, 0, USE_ADC_INTERRUPT},
34 {0, 0, USE_ADC_INTERRUPT}
40 Stm32CurrentSenseParams*
cs_params=
new Stm32CurrentSenseParams {
42 .adc_voltage_conv = (_ADC_VOLTAGE_G4) / (_ADC_RESOLUTION_G4)
51 STM32DriverParams* driver_params = (STM32DriverParams*)_driver_params;
52 Stm32CurrentSenseParams*
cs_params = (Stm32CurrentSenseParams*)_cs_params;
58 stm32_pause(driver_params);
61 int adc_index = _adcToIndex(
cs_params->adc_handle);
63 bool tim_interrupt = _initTimerInterruptDownsampling(
cs_params, driver_params, adc_interrupt_config[adc_index]);
66 SIMPLEFOC_DEBUG(
"STM32-CS: timer has no repetition counter, ADC interrupt has to be used");
70 LL_TIM_SetTriggerOutput(
cs_params->timer_handle->Instance, LL_TIM_TRGO_UPDATE);
73 HAL_ADCEx_Calibration_Start(
cs_params->adc_handle, ADC_SINGLE_ENDED);
76 if (adc_interrupt_config[adc_index].use_adc_interrupt){
78 if(
cs_params->adc_handle->Instance == ADC1) {
80 HAL_NVIC_SetPriority(ADC1_2_IRQn, 0, 0);
81 HAL_NVIC_EnableIRQ(ADC1_2_IRQn);
84 else if (
cs_params->adc_handle->Instance == ADC2) {
86 HAL_NVIC_SetPriority(ADC1_2_IRQn, 0, 0);
87 HAL_NVIC_EnableIRQ(ADC1_2_IRQn);
91 else if (
cs_params->adc_handle->Instance == ADC3) {
93 HAL_NVIC_SetPriority(ADC3_IRQn, 0, 0);
94 HAL_NVIC_EnableIRQ(ADC3_IRQn);
98 else if (
cs_params->adc_handle->Instance == ADC4) {
100 HAL_NVIC_SetPriority(ADC4_IRQn, 0, 0);
101 HAL_NVIC_EnableIRQ(ADC4_IRQn);
105 else if (
cs_params->adc_handle->Instance == ADC5) {
107 HAL_NVIC_SetPriority(ADC5_IRQn, 0, 0);
108 HAL_NVIC_EnableIRQ(ADC5_IRQn);
112 HAL_ADCEx_InjectedStart_IT(
cs_params->adc_handle);
114 HAL_ADCEx_InjectedStart(
cs_params->adc_handle);
119 stm32_resume(driver_params);
130 uint8_t adc_index = (uint8_t)_adcToIndex(((Stm32CurrentSenseParams*)
cs_params)->adc_handle);
131 return _readADCInjectedChannelVoltage(pin, (
void*)
cs_params, adc_interrupt_config[adc_index], adc_val[adc_index]);
135 void HAL_ADCEx_InjectedConvCpltCallback(ADC_HandleTypeDef *AdcHandle){
136 uint8_t adc_index = (uint8_t)_adcToIndex(AdcHandle);
137 _handleInjectedConvCpltCallback(AdcHandle, adc_interrupt_config[adc_index], adc_val[adc_index]);
#define SIMPLEFOC_DEBUG(msg,...)
void * _driverSyncLowSide(void *driver_params, void *cs_params)
#define SIMPLEFOC_CURRENT_SENSE_INIT_FAILED
void * _configureADCLowSide(const void *driver_params, const int pinA, const int pinB, const int pinC=NOT_SET)
float _readADCVoltageLowSide(const int pinA, const void *cs_params)
const int const int const int pinC