stm32: как синхронизировать ЦАП, АЦП вместе?
Я использую плату обнаружения stm32L476. Я пытаюсь создать треугольную волну с ЦАП. Я использую две таблицы поиска для ЦАП (по 1 на каждый наклон вверх и вниз). Я даю синусоидальную волну на входе АЦП и получаю несколько выборок во время наклона треугольной волны вверх и вниз по времени наклона. Я запускаю АЦП и ЦАП вместе для наклона вверх и вниз. Я рассчитываю БПФ образцов АЦП. Для данных с повышением наклона я начинаю вычислять БПФ в начале преобразования ЦАП с нисходящим уклоном, а для выборок БПФ по АЦП с нисходящим уклоном начинаю вычислять БПФ после завершения преобразования ЦАП с нисходящим уклоном. Я поставил все необходимое, чтобы обеспечить правильное время начала и окончания процессов ЦАП, АЦП и БПФ. Проблема в том, что когда я работаю с ЦАП на высокой скорости (около 500 кПс), сигнал появляется в течение нескольких секунд, а затем выходной сигнал становится плоским. Выходной сигнал становится плоским на пиковой стороне волны. Когда я уменьшаю скорость ЦАП примерно до 400 KSPS, проблема не возникает. Кроме того, когда я использую задержку HAL после завершения FFT с уклоном вниз, проблема решается, и волна отображается правильно для всех скоростей ЦАП. Но я не хочу тратить там время. Ниже приведен код. Кто-нибудь знает, в чем здесь проблема?
#include "main.h"
#include "stm32l4xx_hal.h"
#include "arm_math.h"
#include "math.h"
#include "arm_const_structs.h"
#define buf_size 128
ADC_HandleTypeDef hadc2;
DMA_HandleTypeDef hdma_adc2;
DAC_HandleTypeDef hdac1;
DMA_HandleTypeDef hdma_dac_ch2;
TIM_HandleTypeDef htim7;
TIM_HandleTypeDef htim15;
UART_HandleTypeDef huart3;
DMA_HandleTypeDef hdma_usart3_rx;
void calculate_myfft(int32_t* buf);
void SystemClock_Config(void);
static void MX_GPIO_Init(void);
static void MX_DMA_Init(void);
static void MX_ADC2_Init(void);
static void MX_DAC1_Init(void);
static void MX_TIM7_Init(void);
static void MX_TIM15_Init(void);
static void MX_USART3_UART_Init(void);
int buf_size1 = buf_size;
const uint16_t val1[]={8,16,25,33,41,49,57,66,
74,82,90,98,106,115,123,131,
139,147,156,164,172,180,188,197,
205,213,221,229,238,246,254,262,
270,278,287,295,303,311,319,328,
336,344,352,360,369,377,385,393,
401,410,418,426,434,442,450,459,
467,475,483,491,500,508,516,524,
532,541,549,557,565,573,581,590,
598,606,614,622,631,639,647,655,
663,672,680,688,696,704,713,721,
729,737,745,753,762,770,778,786,
794,803,811,819,827,835,844,852,
860,868,876,885,893,901,909,917,
925,934,942,950,958,966,975,983,
991,999,1007,1016,1024,1032,1040,1048,
1057,1065,1073,1081,1089,1097,1106,1114,
1122,1130,1138,1147,1155,1163,1171,1179,
1188,1196,1204,1212,1220,1229,1237,1245,
1253,1261,1269,1278,1286,1294,1302,1310,
1319,1327,1335,1343,1351,1360,1368,1376,
1384,1392,1400,1409,1417,1425,1433,1441,
1450,1458,1466,1474,1482,1491,1499,1507,
1515,1523,1532,1540,1548,1556,1564,1572,
1581,1589,1597,1605,1613,1622,1630,1638,
1646,1654,1663,1671,1679,1687,1695,1704,
1712,1720,1728,1736,1744,1753,1761,1769,
1777,1785,1794,1802,1810,1818,1826,1835,
1843,1851,1859,1867,1876,1884,1892,1900,
1908,1916,1925,1933,1941,1949,1957,1966,
1974,1982,1990,1998,2007,2015,2023,2031,
2039,2048,2056,2064,2072,2080,2088,2097,
2105,2113,2121,2129,2138,2146,2154,2162,
2170,2179,2187,2195,2203,2211,2219,2228,
2236,2244,2252,2260,2269,2277,2285,2293,
2301,2310,2318,2326,2334,2342,2351,2359,
2367,2375,2383,2391,2400,2408,2416,2424,
2432,2441,2449,2457,2465,2473,2482,2490,
2498,2506,2514,2523,2531,2539,2547,2555,
2563,2572,2580,2588,2596,2604,2613,2621,
2629,2637,2645,2654,2662,2670,2678,2686,
2695,2703,2711,2719,2727,2735,2744,2752,
2760,2768,2776,2785,2793,2801,2809,2817,
2826,2834,2842,2850,2858,2867,2875,2883,
2891,2899,2907,2916,2924,2932,2940,2948,
2957,2965,2973,2981,2989,2998,3006,3014,
3022,3030,3038,3047,3055,3063,3071,3079,
3088,3096,3104,3112,3120,3129,3137,3145,
3153,3161,3170,3178,3186,3194,3202,3210,
3219,3227,3235,3243,3251,3260,3268,3276,
3284,3292,3301,3309,3317,3325,3333,3342,
3350,3358,3366,3374,3382,3391,3399,3407,
3415,3423,3432,3440,3448,3456,3464,3473,
3481,3489,3497,3505,3514,3522,3530,3538,
3546,3554,3563,3571,3579,3587,3595,3604,
3612,3620,3628,3636,3645,3653,3661,3669,
3677,3686,3694,3702,3710,3718,3726,3735,
3743,3751,3759,3767,3776,3784,3792,3800,
3808,3817,3825,3833,3841,3849,3857,3866,
3874,3882,3890,3898,3907,3915,3923,3931,
3939,3948,3956,3964,3972,3980,3989,3997,
4005,4013,4021,4029,4038,4046,4054,4062,
4070,4079,4087,4095};
const uint16_t val2[] = {
4087,4079,4070,4062,
4054,4046,4038,4029,4021,4013,4005,3997,
3989,3980,3972,3964,3956,3948,3939,3931,
3923,3915,3907,3898,3890,3882,3874,3866,
3857,3849,3841,3833,3825,3817,3808,3800,
3792,3784,3776,3767,3759,3751,3743,3735,
3726,3718,3710,3702,3694,3686,3677,3669,
3661,3653,3645,3636,3628,3620,3612,3604,
3595,3587,3579,3571,3563,3554,3546,3538,
3530,3522,3514,3505,3497,3489,3481,3473,
3464,3456,3448,3440,3432,3423,3415,3407,
3399,3391,3382,3374,3366,3358,3350,3342,
3333,3325,3317,3309,3301,3292,3284,3276,
3268,3260,3251,3243,3235,3227,3219,3210,
3202,3194,3186,3178,3170,3161,3153,3145,
3137,3129,3120,3112,3104,3096,3088,3079,
3071,3063,3055,3047,3038,3030,3022,3014,
3006,2998,2989,2981,2973,2965,2957,2948,
2940,2932,2924,2916,2907,2899,2891,2883,
2875,2867,2858,2850,2842,2834,2826,2817,
2809,2801,2793,2785,2776,2768,2760,2752,
2744,2735,2727,2719,2711,2703,2695,2686,
2678,2670,2662,2654,2645,2637,2629,2621,
2613,2604,2596,2588,2580,2572,2563,2555,
2547,2539,2531,2523,2514,2506,2498,2490,
2482,2473,2465,2457,2449,2441,2432,2424,
2416,2408,2400,2391,2383,2375,2367,2359,
2351,2342,2334,2326,2318,2310,2301,2293,
2285,2277,2269,2260,2252,2244,2236,2228,
2219,2211,2203,2195,2187,2179,2170,2162,
2154,2146,2138,2129,2121,2113,2105,2097,
2088,2080,2072,2064,2056,2048,2039,2031,
2023,2015,2007,1998,1990,1982,1974,1966,
1957,1949,1941,1933,1925,1916,1908,1900,
1892,1884,1876,1867,1859,1851,1843,1835,
1826,1818,1810,1802,1794,1785,1777,1769,
1761,1753,1744,1736,1728,1720,1712,1704,
1695,1687,1679,1671,1663,1654,1646,1638,
1630,1622,1613,1605,1597,1589,1581,1572,
1564,1556,1548,1540,1532,1523,1515,1507,
1499,1491,1482,1474,1466,1458,1450,1441,
1433,1425,1417,1409,1400,1392,1384,1376,
1368,1360,1351,1343,1335,1327,1319,1310,
1302,1294,1286,1278,1269,1261,1253,1245,
1237,1229,1220,1212,1204,1196,1188,1179,
1171,1163,1155,1147,1138,1130,1122,1114,
1106,1097,1089,1081,1073,1065,1057,1048,
1040,1032,1024,1016,1007,999,991,983,
975,966,958,950,942,934,925,917,
909,901,893,885,876,868,860,852,
844,835,827,819,811,803,794,786,
778,770,762,753,745,737,729,721,
713,704,696,688,680,672,663,655,
647,639,631,622,614,606,598,590,
581,573,565,557,549,541,532,524,
516,508,500,491,483,475,467,459,
450,442,434,426,418,410,401,393,
385,377,369,360,352,344,336,328,
319,311,303,295,287,278,270,262,
254,246,238,229,221,213,205,197,
188,180,172,164,156,147,139,131,
123,115,106,98,90,82,74,66,
57,49,41,33,25,16,8,0};
int count = 0;
int count1 = 0;
int count2 = 0;
int count3 = 0;
int count4 = 0;
int count5 = 0;
int count6 = 0;
int count7 = 0;
int run_buf = 0;
uint16_t ADC1ConvertedValues[buf_size];
uint16_t ADC1ConvertedValues2[buf_size];
const int lengthofa = sizeof( ADC1ConvertedValues ) / sizeof( ADC1ConvertedValues[0] );
int32_t ADC1ConvertedValues91[buf_size];
int32_t ADC1ConvertedValues92[buf_size];
int32_t data_output1_temp1[buf_size];
int32_t data_output1_temp2[buf_size];
int16_t data_arrayh1[buf_size];
int16_t data_output[2*buf_size];
float hann[buf_size];
int run_adc = 0;
int dac_half_conv_cmpt = 0;
int adc_conv_cmpt = 0;
int fft_flag = 0;;
int slope = 1;
int restart_dac = 0;
int fft_2_goingon = 0;
int timer15_start = 0;
int l1 = 0;
int l2 = 0;
int some_delay = 0;
int start_next_chirp = 0;
int start_fft = 0;
int dac_conv_cmpt = 0;
int timer15_started = 0;
int run_buf_was_6 = 0;
uint8_t data[2];
uint8_t var1;
uint8_t var3;
uint8_t var2;
uint8_t var4;
uint8_t var5;
uint8_t var6;
int i = 0;
int16_t i_buf[buf_size];
int send_to_usart = 0;
int fft1 = 0;
int fft2 = 0;
uint8_t *g;
int fft1_count = 0;
int fft2_count = 0;
int ready_for_next_chirp = 0;
int main(void)
{
int p = 0;
int n1=sizeof(val1);
l1=n1/sizeof(val1[0]);
int n2=sizeof(val2);
l2=n2/sizeof(val2[0]);
HAL_Init();
MX_GPIO_Init();
MX_DMA_Init();
MX_ADC2_Init();
MX_DAC1_Init();
MX_TIM7_Init();
MX_TIM15_Init();
MX_USART3_UART_Init();
g = &data[0];
HAL_UART_Receive_DMA(&huart3, (uint8_t*)g, 1);
HAL_TIM_Base_Start(&htim7);
HAL_DAC_Start(&hdac1, DAC_CHANNEL_2);
HAL_DAC_Start_DMA(&hdac1, DAC_CHANNEL_2, (uint32_t*)val1, l1, DAC_ALIGN_12B_R);
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_11, GPIO_PIN_SET);
HAL_ADC_Start_DMA(&hadc2, (uint32_t*)&ADC1ConvertedValues, buf_size);
for (p = 0; p < buf_size; p++)
{
hann[p] = 0.54 - 0.46 * cosf((2*PI*p)/(buf_size-1));
}
while (1)
{
if((run_buf == 1) && (ready_for_next_chirp == 1))
{
//HAL_TIM_Base_Stop_IT(&htim15);
send_to_usart = 0;
//HAL_TIM_Base_DeInit(&htim15);
MX_TIM15_Init();
ready_for_next_chirp = 0;
//HAL_TIM_Base_Init(&htim15);
count2 += 1;
run_buf_was_6 = 0;
run_buf = 3;
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_11, GPIO_PIN_SET);
HAL_TIM_Base_Init(&htim7);
HAL_TIM_Base_Start(&htim7);
HAL_DAC_Stop_DMA(&hdac1, DAC_CHANNEL_2);
HAL_DAC_Start_DMA(&hdac1, DAC_CHANNEL_2, (uint32_t*)val1, l1, DAC_ALIGN_12B_R);
HAL_ADC_Start_DMA(&hadc2, (uint32_t*)&ADC1ConvertedValues, buf_size);
//slope = 1;
//start_fft = 1;
}
else if(run_buf == 2)
{
run_buf = 4;
count3 += 1;
//dac_conv_cmpt = 0;
HAL_DAC_Stop_DMA(&hdac1, DAC_CHANNEL_2);
HAL_TIM_Base_Init(&htim7);
HAL_TIM_Base_Start(&htim7);
HAL_DAC_Start_DMA(&hdac1, DAC_CHANNEL_2, (uint32_t*)val2, l2, DAC_ALIGN_12B_R);
fft_flag = 0;
slope = 1;
start_fft = 1;
}
if(some_delay == 1)
{
some_delay = 0;
count7 += 1;
//HAL_DAC_Stop_DMA(&hdac1, DAC_CHANNEL_2);
HAL_Delay(1);
timer15_started = 1;
fft_flag = 0;
run_buf = 1;
//HAL_TIM_Base_Start_IT(&htim15);
}
if((start_fft == 1) && (slope == 1))
{
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_6, SET);
start_fft = 0;
fft1 = 1;
count5 += 1;
//count += 1;
//adc_conv_cmpt = 0;
//fft_flag = 0;
for(int j=0; j<buf_size; j++)
{
ADC1ConvertedValues91[j] = (int32_t)((int32_t)(ADC1ConvertedValues[j]) - 2048);
}
calculate_myfft(ADC1ConvertedValues91);
fft_flag = 1;
fft1 = 0;
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_6, RESET);
}
else if((start_fft == 1) && (slope == 2))
{
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_7, SET);
start_fft = 0;
count6 += 1;
fft2 = 1;
timer15_started = 0;
//count1 += 1;
//adc_conv_cmpt = 0;
//fft_flag = 3;
for(int j=0; j<buf_size; j++)
{
ADC1ConvertedValues92[j] = (int32_t)((int32_t)(ADC1ConvertedValues2[j]) - 2048);
}
fft_2_goingon = 1;
//HAL_GPIO_WritePin(GPIOB, GPIO_PIN_7, SET);
calculate_myfft(ADC1ConvertedValues92);
fft_2_goingon =0;
fft_flag = 2;
fft2 = 0;
send_to_usart = 1;
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_7, RESET);
some_delay = 1;
ready_for_next_chirp = 1;
}
if((data[0] == 0x43) && (send_to_usart == 1))
{
send_to_usart = 0;
data[0] = 0x00;
data_output1_temp1[0] = 0;
data_output1_temp1[1] = 0;
for(i=0; i<buf_size; i++)
{
var3 = (data_output1_temp1[i] & 0x000000FF);
//while(adc_go != 0);
HAL_UART_Transmit(&huart3, &var3, 1, 5);
var1 = ((data_output1_temp1[i] & 0x0000FF00) >> 8);
HAL_UART_Transmit(&huart3, &var1, 1, 5);
var2 = ((data_output1_temp1[i] & 0x00FF0000) >> 16);
HAL_UART_Transmit(&huart3, &var2, 1, 5);
var4 = ((data_output1_temp1[i] & 0xFF000000) >> 24);
HAL_UART_Transmit(&huart3, &var4, 1, 5);
}
}
if((data[0] == 0x41) && (send_to_usart == 1))
{
send_to_usart = 0;
data[0] = 0x00;
for(i=0; i<buf_size; i++)
{
var5 = (ADC1ConvertedValues91[i] & 0x00FF);
HAL_UART_Transmit(&huart3, &var5, 1, 5);
var6 = ((ADC1ConvertedValues91[i] & 0xFF00) >> 8); HAL_UART_Transmit(&huart3, &var6, 1, 5);
}
}
if((data[0] == 0x44) && (send_to_usart == 1))
{
send_to_usart = 0;
data[0] = 0x00;
data_output1_temp2[0] = 0;
data_output1_temp2[1] = 0;
for(i=0; i<buf_size; i++)
{
var3 = (data_output1_temp2[i] & 0x000000FF);
HAL_UART_Transmit(&huart3, &var3, 1, 5);
var1 = ((data_output1_temp2[i] & 0x0000FF00) >> 8);
HAL_UART_Transmit(&huart3, &var1, 1, 5);
var2 = ((data_output1_temp2[i] & 0x00FF0000) >> 16);
HAL_UART_Transmit(&huart3, &var2, 1, 5);
var4 = ((data_output1_temp2[i] & 0xFF000000) >> 24);
HAL_UART_Transmit(&huart3, &var4, 1, 5);
}
//data[0] = 0x00;
}
if((data[0] == 0x42) && (send_to_usart == 1))
{
send_to_usart = 0;
data[0] = 0x00;
for(i=0; i<buf_size; i++)
{
var5 = (ADC1ConvertedValues92[i] & 0x00FF);
//while(adc_go != 0);
HAL_UART_Transmit(&huart3, &var5, 1, 5);
var6 = ((ADC1ConvertedValues92[i] & 0xFF00) >> 8);
//while(adc_go != 1);
HAL_UART_Transmit(&huart3, &var6, 1, 5);
//HAL_Delay(5);
}
//data[0] = 0x00;
}
}
}
void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
{
adc_conv_cmpt = 1;
count += 1;
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_11, GPIO_PIN_RESET);
}
void calculate_myfft(int32_t* buf)
{
//fft_flag = 2;
int n = 0;
int i = 0;
//int SAMPLE_LENGTH = 32;
uint32_t fftSize = buf_size;
/*for (n = 0; n < buf_size; n++)
{
hann[n] = 0.54 - 0.46 * cosf((2*PI*n)/(buf_size-1));
}*/
for(n = 0; n < buf_size; n++)
{
data_arrayh1[n] = (int16_t)(hann[n]*buf[n]);
}
uint32_t ifftFlag = 0; //to be set when inverse FFT is to be performed
uint32_t doBitReverse = 1; // Set bit reversal for DIF and DIT selection
volatile arm_status status;
arm_rfft_instance_q15 instance;
arm_rfft_init_q15(&instance, fftSize, ifftFlag, doBitReverse);
arm_rfft_q15(&instance, data_arrayh1, data_output);
if(fft1 == 1)
{
fft1_count += 1;
for(i=0; i<(2*buf_size); i=i+2)
{
data_output1_temp1[i/2] = (int32_t)((data_output[i] * data_output[i]) + (data_output[i+1] * data_output[i+1]));
//data_output1_plot[i/2] = data_output1_temp[i/2];
//fft_flag = 1;
}
}
else if(fft2 == 1)
{
fft2_count += 1;
for(i=0; i<(2*buf_size); i=i+2)
{
data_output1_temp2[i/2] = (int32_t)((data_output[i] * data_output[i]) + (data_output[i+1] * data_output[i+1]));
}
}
}
void HAL_DACEx_ConvCpltCallbackCh2(DAC_HandleTypeDef* hdac)
{
count1 += 1;
//dac_conv_cmpt = 1;
HAL_TIM_Base_Stop(&htim7);
HAL_TIM_Base_DeInit(&htim7);
if(run_buf == 3)
{
run_buf = 2;
//run_buf = 4;
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_11, GPIO_PIN_SET);
HAL_ADC_Start_DMA(&hadc2, (uint32_t*)&ADC1ConvertedValues2, buf_size);
//HAL_Delay(3);
//some_delay = 1;
}
else if(run_buf == 4)
{
run_buf = 6;
//HAL_Delay(3);
run_buf_was_6 = 1;
slope = 2;
start_fft = 1;
//some_delay = 1;
}
else if(run_buf == 0)
{
run_buf = 2;
//run_buf = 4;
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_11, GPIO_PIN_SET);
HAL_ADC_Start_DMA(&hadc2, (uint32_t*)&ADC1ConvertedValues2, buf_size);
}
}
void SystemClock_Config(void)
{
RCC_OscInitTypeDef RCC_OscInitStruct;
RCC_ClkInitTypeDef RCC_ClkInitStruct;
RCC_PeriphCLKInitTypeDef PeriphClkInit;
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_MSI;
RCC_OscInitStruct.MSIState = RCC_MSI_ON;
RCC_OscInitStruct.MSICalibrationValue = 0;
RCC_OscInitStruct.MSIClockRange = RCC_MSIRANGE_6;
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_MSI;
RCC_OscInitStruct.PLL.PLLM = 1;
RCC_OscInitStruct.PLL.PLLN = 40;
RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV7;
RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2;
RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2;
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV4;
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_4) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART3|RCC_PERIPHCLK_ADC;
PeriphClkInit.Usart3ClockSelection = RCC_USART3CLKSOURCE_SYSCLK;
PeriphClkInit.AdcClockSelection = RCC_ADCCLKSOURCE_PLLSAI1;
PeriphClkInit.PLLSAI1.PLLSAI1Source = RCC_PLLSOURCE_MSI;
PeriphClkInit.PLLSAI1.PLLSAI1M = 1;
PeriphClkInit.PLLSAI1.PLLSAI1N = 34;
PeriphClkInit.PLLSAI1.PLLSAI1P = RCC_PLLP_DIV7;
PeriphClkInit.PLLSAI1.PLLSAI1Q = RCC_PLLQ_DIV2;
PeriphClkInit.PLLSAI1.PLLSAI1R = RCC_PLLR_DIV2;
PeriphClkInit.PLLSAI1.PLLSAI1ClockOut = RCC_PLLSAI1_ADC1CLK;
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
if (HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000);
HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK);
HAL_NVIC_SetPriority(SysTick_IRQn, 0, 0);
}
static void MX_ADC2_Init(void)
{
ADC_ChannelConfTypeDef sConfig;
hadc2.Instance = ADC2;
hadc2.Init.ClockPrescaler = ADC_CLOCK_ASYNC_DIV1;
hadc2.Init.Resolution = ADC_RESOLUTION_12B;
hadc2.Init.DataAlign = ADC_DATAALIGN_RIGHT;
hadc2.Init.ScanConvMode = ADC_SCAN_DISABLE;
hadc2.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
hadc2.Init.LowPowerAutoWait = DISABLE;
hadc2.Init.ContinuousConvMode = ENABLE;
hadc2.Init.NbrOfConversion = 1;
hadc2.Init.DiscontinuousConvMode = DISABLE;
hadc2.Init.NbrOfDiscConversion = 1;
hadc2.Init.ExternalTrigConv = ADC_SOFTWARE_START;
hadc2.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
hadc2.Init.DMAContinuousRequests = DISABLE;
hadc2.Init.Overrun = ADC_OVR_DATA_PRESERVED;
hadc2.Init.OversamplingMode = DISABLE;
if (HAL_ADC_Init(&hadc2) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
sConfig.Channel = ADC_CHANNEL_8;
sConfig.Rank = 1;
sConfig.SamplingTime = ADC_SAMPLETIME_47CYCLES_5;
sConfig.SingleDiff = ADC_SINGLE_ENDED;
sConfig.OffsetNumber = ADC_OFFSET_NONE;
sConfig.Offset = 0;
if (HAL_ADC_ConfigChannel(&hadc2, &sConfig) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
}
static void MX_DAC1_Init(void)
{
DAC_ChannelConfTypeDef sConfig;
hdac1.Instance = DAC1;
if (HAL_DAC_Init(&hdac1) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
sConfig.DAC_SampleAndHold = DAC_SAMPLEANDHOLD_DISABLE;
sConfig.DAC_Trigger = DAC_TRIGGER_T7_TRGO;
sConfig.DAC_OutputBuffer = DAC_OUTPUTBUFFER_ENABLE;
sConfig.DAC_ConnectOnChipPeripheral = DAC_CHIPCONNECT_ENABLE;
sConfig.DAC_UserTrimming = DAC_TRIMMING_FACTORY;
if (HAL_DAC_ConfigChannel(&hdac1, &sConfig, DAC_CHANNEL_2) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
}
static void MX_TIM7_Init(void)
{
TIM_MasterConfigTypeDef sMasterConfig;
htim7.Instance = TIM7;
htim7.Init.Prescaler = 0;
htim7.Init.CounterMode = TIM_COUNTERMODE_UP;
htim7.Init.Period = 79;
if (HAL_TIM_Base_Init(&htim7) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
sMasterConfig.MasterOutputTrigger = TIM_TRGO_UPDATE;
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
if (HAL_TIMEx_MasterConfigSynchronization(&htim7, &sMasterConfig) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
}
static void MX_TIM15_Init(void)
{
TIM_ClockConfigTypeDef sClockSourceConfig;
TIM_MasterConfigTypeDef sMasterConfig;
htim15.Instance = TIM15;
htim15.Init.Prescaler = 39;
htim15.Init.CounterMode = TIM_COUNTERMODE_UP;
htim15.Init.Period = 2000;
htim15.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
htim15.Init.RepetitionCounter = 1;
if (HAL_TIM_Base_Init(&htim15) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
if (HAL_TIM_ConfigClockSource(&htim15, &sClockSourceConfig) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
if (HAL_TIMEx_MasterConfigSynchronization(&htim15, &sMasterConfig) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
}
static void MX_USART3_UART_Init(void)
{
huart3.Instance = USART3;
huart3.Init.BaudRate = 115200;
huart3.Init.WordLength = UART_WORDLENGTH_8B;
huart3.Init.StopBits = UART_STOPBITS_1;
huart3.Init.Parity = UART_PARITY_NONE;
huart3.Init.Mode = UART_MODE_TX_RX;
huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
huart3.Init.OverSampling = UART_OVERSAMPLING_16;
huart3.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
huart3.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
if (HAL_UART_Init(&huart3) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}
}
static void MX_DMA_Init(void)
{
__HAL_RCC_DMA1_CLK_ENABLE();
HAL_NVIC_SetPriority(DMA1_Channel2_IRQn, 0, 0);
HAL_NVIC_EnableIRQ(DMA1_Channel2_IRQn);
HAL_NVIC_SetPriority(DMA1_Channel3_IRQn, 0, 0);
HAL_NVIC_EnableIRQ(DMA1_Channel3_IRQn);
HAL_NVIC_SetPriority(DMA1_Channel4_IRQn, 0, 0);
HAL_NVIC_EnableIRQ(DMA1_Channel4_IRQn);
}
static void MX_GPIO_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct;
__HAL_RCC_GPIOA_CLK_ENABLE();
__HAL_RCC_GPIOC_CLK_ENABLE();
__HAL_RCC_GPIOB_CLK_ENABLE();
__HAL_RCC_GPIOE_CLK_ENABLE();
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_2|GPIO_PIN_6|GPIO_PIN_7, GPIO_PIN_RESET);
/*Configure GPIO pin Output Level */
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_11|GPIO_PIN_12, GPIO_PIN_RESET);
/*Configure GPIO pin : PA4 */
GPIO_InitStruct.Pin = GPIO_PIN_4;
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
GPIO_InitStruct.Pull = GPIO_NOPULL;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
GPIO_InitStruct.Pin = GPIO_PIN_2|GPIO_PIN_6|GPIO_PIN_7;
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
GPIO_InitStruct.Pull = GPIO_NOPULL;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
GPIO_InitStruct.Pin = GPIO_PIN_11|GPIO_PIN_12;
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
GPIO_InitStruct.Pull = GPIO_NOPULL;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
HAL_I2CEx_EnableFastModePlus(I2C_FASTMODEPLUS_PB6);
HAL_I2CEx_EnableFastModePlus(I2C_FASTMODEPLUS_PB7);
}
void _Error_Handler(char * file, int line)
{
while(1)
{
}
}
#ifdef USE_FULL_ASSERT
void assert_failed(uint8_t* file, uint32_t line)
{
}
#endif