|
@@ -0,0 +1,440 @@
|
|
1
|
+/* USER CODE BEGIN Header */
|
|
2
|
+/**
|
|
3
|
+ ******************************************************************************
|
|
4
|
+ * @file : main.c
|
|
5
|
+ * @brief : Main program body
|
|
6
|
+ ******************************************************************************
|
|
7
|
+ * @attention
|
|
8
|
+ *
|
|
9
|
+ * <h2><center>© Copyright (c) 2019 STMicroelectronics.
|
|
10
|
+ * All rights reserved.</center></h2>
|
|
11
|
+ *
|
|
12
|
+ * This software component is licensed by ST under BSD 3-Clause license,
|
|
13
|
+ * the "License"; You may not use this file except in compliance with the
|
|
14
|
+ * License. You may obtain a copy of the License at:
|
|
15
|
+ * opensource.org/licenses/BSD-3-Clause
|
|
16
|
+ *
|
|
17
|
+ ******************************************************************************
|
|
18
|
+ */
|
|
19
|
+/* USER CODE END Header */
|
|
20
|
+
|
|
21
|
+/* Includes ------------------------------------------------------------------*/
|
|
22
|
+#include "main.h"
|
|
23
|
+
|
|
24
|
+/* Private includes ----------------------------------------------------------*/
|
|
25
|
+/* USER CODE BEGIN Includes */
|
|
26
|
+
|
|
27
|
+/* USER CODE END Includes */
|
|
28
|
+
|
|
29
|
+/* Private typedef -----------------------------------------------------------*/
|
|
30
|
+/* USER CODE BEGIN PTD */
|
|
31
|
+
|
|
32
|
+/* USER CODE END PTD */
|
|
33
|
+
|
|
34
|
+/* Private define ------------------------------------------------------------*/
|
|
35
|
+/* USER CODE BEGIN PD */
|
|
36
|
+
|
|
37
|
+/* USER CODE END PD */
|
|
38
|
+
|
|
39
|
+/* Private macro -------------------------------------------------------------*/
|
|
40
|
+/* USER CODE BEGIN PM */
|
|
41
|
+
|
|
42
|
+/* USER CODE END PM */
|
|
43
|
+
|
|
44
|
+/* Private variables ---------------------------------------------------------*/
|
|
45
|
+ADC_HandleTypeDef hadc1;
|
|
46
|
+DMA_HandleTypeDef hdma_adc1;
|
|
47
|
+
|
|
48
|
+UART_HandleTypeDef huart1;
|
|
49
|
+
|
|
50
|
+/* USER CODE BEGIN PV */
|
|
51
|
+
|
|
52
|
+/* USER CODE END PV */
|
|
53
|
+
|
|
54
|
+/* Private function prototypes -----------------------------------------------*/
|
|
55
|
+void SystemClock_Config(void);
|
|
56
|
+static void MX_GPIO_Init(void);
|
|
57
|
+static void MX_DMA_Init(void);
|
|
58
|
+static void MX_ADC1_Init(void);
|
|
59
|
+static void MX_USART1_UART_Init(void);
|
|
60
|
+static void MX_NVIC_Init(void);
|
|
61
|
+/* USER CODE BEGIN PFP */
|
|
62
|
+
|
|
63
|
+/* USER CODE END PFP */
|
|
64
|
+
|
|
65
|
+/* Private user code ---------------------------------------------------------*/
|
|
66
|
+/* USER CODE BEGIN 0 */
|
|
67
|
+
|
|
68
|
+/* USER CODE END 0 */
|
|
69
|
+
|
|
70
|
+/**
|
|
71
|
+ * @brief The application entry point.
|
|
72
|
+ * @retval int
|
|
73
|
+ */
|
|
74
|
+int main(void)
|
|
75
|
+{
|
|
76
|
+ /* USER CODE BEGIN 1 */
|
|
77
|
+
|
|
78
|
+ /* USER CODE END 1 */
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+ /* MCU Configuration--------------------------------------------------------*/
|
|
82
|
+
|
|
83
|
+ /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
|
|
84
|
+ HAL_Init();
|
|
85
|
+
|
|
86
|
+ /* USER CODE BEGIN Init */
|
|
87
|
+
|
|
88
|
+ /* USER CODE END Init */
|
|
89
|
+
|
|
90
|
+ /* Configure the system clock */
|
|
91
|
+ SystemClock_Config();
|
|
92
|
+
|
|
93
|
+ /* USER CODE BEGIN SysInit */
|
|
94
|
+
|
|
95
|
+ /* USER CODE END SysInit */
|
|
96
|
+
|
|
97
|
+ /* Initialize all configured peripherals */
|
|
98
|
+ MX_GPIO_Init();
|
|
99
|
+ MX_DMA_Init();
|
|
100
|
+ MX_ADC1_Init();
|
|
101
|
+ MX_USART1_UART_Init();
|
|
102
|
+
|
|
103
|
+ /* Initialize interrupts */
|
|
104
|
+ MX_NVIC_Init();
|
|
105
|
+ /* USER CODE BEGIN 2 */
|
|
106
|
+
|
|
107
|
+ /* USER CODE END 2 */
|
|
108
|
+
|
|
109
|
+ /* Infinite loop */
|
|
110
|
+ /* USER CODE BEGIN WHILE */
|
|
111
|
+ while (1)
|
|
112
|
+ {
|
|
113
|
+ /* USER CODE END WHILE */
|
|
114
|
+
|
|
115
|
+ /* USER CODE BEGIN 3 */
|
|
116
|
+ }
|
|
117
|
+ /* USER CODE END 3 */
|
|
118
|
+}
|
|
119
|
+
|
|
120
|
+/**
|
|
121
|
+ * @brief System Clock Configuration
|
|
122
|
+ * @retval None
|
|
123
|
+ */
|
|
124
|
+void SystemClock_Config(void)
|
|
125
|
+{
|
|
126
|
+ RCC_OscInitTypeDef RCC_OscInitStruct = {0};
|
|
127
|
+ RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
|
|
128
|
+ RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
|
129
|
+
|
|
130
|
+ /** Initializes the CPU, AHB and APB busses clocks
|
|
131
|
+ */
|
|
132
|
+ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
|
|
133
|
+ RCC_OscInitStruct.HSIState = RCC_HSI_ON;
|
|
134
|
+ RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
|
|
135
|
+ RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
|
|
136
|
+ RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI_DIV2;
|
|
137
|
+ RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL15;
|
|
138
|
+ if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
|
|
139
|
+ {
|
|
140
|
+ Error_Handler();
|
|
141
|
+ }
|
|
142
|
+ /** Initializes the CPU, AHB and APB busses clocks
|
|
143
|
+ */
|
|
144
|
+ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|
|
145
|
+ |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
|
|
146
|
+ RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
|
|
147
|
+ RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
|
|
148
|
+ RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
|
|
149
|
+ RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
|
|
150
|
+
|
|
151
|
+ if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
|
|
152
|
+ {
|
|
153
|
+ Error_Handler();
|
|
154
|
+ }
|
|
155
|
+ PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC;
|
|
156
|
+ PeriphClkInit.AdcClockSelection = RCC_ADCPCLK2_DIV6;
|
|
157
|
+ if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
158
|
+ {
|
|
159
|
+ Error_Handler();
|
|
160
|
+ }
|
|
161
|
+}
|
|
162
|
+
|
|
163
|
+/**
|
|
164
|
+ * @brief NVIC Configuration.
|
|
165
|
+ * @retval None
|
|
166
|
+ */
|
|
167
|
+static void MX_NVIC_Init(void)
|
|
168
|
+{
|
|
169
|
+ /* USART1_IRQn interrupt configuration */
|
|
170
|
+ HAL_NVIC_SetPriority(USART1_IRQn, 0, 0);
|
|
171
|
+ HAL_NVIC_EnableIRQ(USART1_IRQn);
|
|
172
|
+}
|
|
173
|
+
|
|
174
|
+/**
|
|
175
|
+ * @brief ADC1 Initialization Function
|
|
176
|
+ * @param None
|
|
177
|
+ * @retval None
|
|
178
|
+ */
|
|
179
|
+static void MX_ADC1_Init(void)
|
|
180
|
+{
|
|
181
|
+
|
|
182
|
+ /* USER CODE BEGIN ADC1_Init 0 */
|
|
183
|
+
|
|
184
|
+ /* USER CODE END ADC1_Init 0 */
|
|
185
|
+
|
|
186
|
+ ADC_ChannelConfTypeDef sConfig = {0};
|
|
187
|
+
|
|
188
|
+ /* USER CODE BEGIN ADC1_Init 1 */
|
|
189
|
+
|
|
190
|
+ /* USER CODE END ADC1_Init 1 */
|
|
191
|
+ /** Common config
|
|
192
|
+ */
|
|
193
|
+ hadc1.Instance = ADC1;
|
|
194
|
+ hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
|
|
195
|
+ hadc1.Init.ContinuousConvMode = DISABLE;
|
|
196
|
+ hadc1.Init.DiscontinuousConvMode = DISABLE;
|
|
197
|
+ hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
|
|
198
|
+ hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
|
|
199
|
+ hadc1.Init.NbrOfConversion = 2;
|
|
200
|
+ if (HAL_ADC_Init(&hadc1) != HAL_OK)
|
|
201
|
+ {
|
|
202
|
+ Error_Handler();
|
|
203
|
+ }
|
|
204
|
+ /** Configure Regular Channel
|
|
205
|
+ */
|
|
206
|
+ sConfig.Channel = ADC_CHANNEL_0;
|
|
207
|
+ sConfig.Rank = ADC_REGULAR_RANK_1;
|
|
208
|
+ sConfig.SamplingTime = ADC_SAMPLETIME_1CYCLE_5;
|
|
209
|
+ if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
|
210
|
+ {
|
|
211
|
+ Error_Handler();
|
|
212
|
+ }
|
|
213
|
+ /** Configure Regular Channel
|
|
214
|
+ */
|
|
215
|
+ sConfig.Rank = ADC_REGULAR_RANK_2;
|
|
216
|
+ if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
|
217
|
+ {
|
|
218
|
+ Error_Handler();
|
|
219
|
+ }
|
|
220
|
+ /* USER CODE BEGIN ADC1_Init 2 */
|
|
221
|
+
|
|
222
|
+ /* USER CODE END ADC1_Init 2 */
|
|
223
|
+
|
|
224
|
+}
|
|
225
|
+
|
|
226
|
+/**
|
|
227
|
+ * @brief USART1 Initialization Function
|
|
228
|
+ * @param None
|
|
229
|
+ * @retval None
|
|
230
|
+ */
|
|
231
|
+static void MX_USART1_UART_Init(void)
|
|
232
|
+{
|
|
233
|
+
|
|
234
|
+ /* USER CODE BEGIN USART1_Init 0 */
|
|
235
|
+
|
|
236
|
+ /* USER CODE END USART1_Init 0 */
|
|
237
|
+
|
|
238
|
+ /* USER CODE BEGIN USART1_Init 1 */
|
|
239
|
+
|
|
240
|
+ /* USER CODE END USART1_Init 1 */
|
|
241
|
+ huart1.Instance = USART1;
|
|
242
|
+ huart1.Init.BaudRate = 115200;
|
|
243
|
+ huart1.Init.WordLength = UART_WORDLENGTH_8B;
|
|
244
|
+ huart1.Init.StopBits = UART_STOPBITS_1;
|
|
245
|
+ huart1.Init.Parity = UART_PARITY_NONE;
|
|
246
|
+ huart1.Init.Mode = UART_MODE_TX_RX;
|
|
247
|
+ huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
|
248
|
+ huart1.Init.OverSampling = UART_OVERSAMPLING_16;
|
|
249
|
+ if (HAL_UART_Init(&huart1) != HAL_OK)
|
|
250
|
+ {
|
|
251
|
+ Error_Handler();
|
|
252
|
+ }
|
|
253
|
+ /* USER CODE BEGIN USART1_Init 2 */
|
|
254
|
+
|
|
255
|
+ /* USER CODE END USART1_Init 2 */
|
|
256
|
+
|
|
257
|
+}
|
|
258
|
+
|
|
259
|
+/**
|
|
260
|
+ * Enable DMA controller clock
|
|
261
|
+ */
|
|
262
|
+static void MX_DMA_Init(void)
|
|
263
|
+{
|
|
264
|
+ /* DMA controller clock enable */
|
|
265
|
+ __HAL_RCC_DMA1_CLK_ENABLE();
|
|
266
|
+
|
|
267
|
+ /* DMA interrupt init */
|
|
268
|
+ /* DMA1_Channel1_IRQn interrupt configuration */
|
|
269
|
+ HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 0, 0);
|
|
270
|
+ HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
|
|
271
|
+
|
|
272
|
+}
|
|
273
|
+
|
|
274
|
+/**
|
|
275
|
+ * @brief GPIO Initialization Function
|
|
276
|
+ * @param None
|
|
277
|
+ * @retval None
|
|
278
|
+ */
|
|
279
|
+static void MX_GPIO_Init(void)
|
|
280
|
+{
|
|
281
|
+ GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
282
|
+
|
|
283
|
+ /* GPIO Ports Clock Enable */
|
|
284
|
+ __HAL_RCC_GPIOE_CLK_ENABLE();
|
|
285
|
+ __HAL_RCC_GPIOC_CLK_ENABLE();
|
|
286
|
+ __HAL_RCC_GPIOF_CLK_ENABLE();
|
|
287
|
+ __HAL_RCC_GPIOA_CLK_ENABLE();
|
|
288
|
+ __HAL_RCC_GPIOB_CLK_ENABLE();
|
|
289
|
+ __HAL_RCC_GPIOD_CLK_ENABLE();
|
|
290
|
+ __HAL_RCC_GPIOG_CLK_ENABLE();
|
|
291
|
+
|
|
292
|
+ /*Configure GPIO pin Output Level */
|
|
293
|
+ HAL_GPIO_WritePin(GPIOE, ATT_EN_1_8G_DL1_Pin|ATT_EN_1_8G_DL2_Pin|ATT_EN_1_8G_UL1_Pin|ATT_EN_1_8G_UL2_Pin
|
|
294
|
+ |ATT_EN_1_8G_UL3_Pin|PATH_EN_2_1G_DL_Pin|PATH_EN_2_1G_UL_Pin, GPIO_PIN_RESET);
|
|
295
|
+
|
|
296
|
+ /*Configure GPIO pin Output Level */
|
|
297
|
+ HAL_GPIO_WritePin(GPIOC, ATT_EN_1_8G_UL4_Pin|PATH_EN_1_8G_DL_Pin|PATH_EN_1_8G_UL_Pin|PLL_EN_3_5G_L_Pin
|
|
298
|
+ |PLL_EN_3_5G_H_Pin, GPIO_PIN_RESET);
|
|
299
|
+
|
|
300
|
+ /*Configure GPIO pin Output Level */
|
|
301
|
+ HAL_GPIO_WritePin(GPIOF, PLL_EN_1_8G_DL_Pin|PLL_EN_1_8G_UL_Pin|ATT_EN_2_1G_DL1_Pin|ATT_EN_2_1G_DL2_Pin
|
|
302
|
+ |ATT_EN_2_1G_UL1_Pin|ATT_EN_2_1G_UL2_Pin|ATT_EN_2_1G_UL3_Pin|ATT_EN_2_1G_UL4_Pin, GPIO_PIN_RESET);
|
|
303
|
+
|
|
304
|
+ /*Configure GPIO pin Output Level */
|
|
305
|
+ HAL_GPIO_WritePin(GPIOD, PLL_DATA_Pin|PLL_CLK_Pin|ATT_DATA_Pin|ATT_CLK_Pin
|
|
306
|
+ |DA_LDAC_Pin|ATT_CLK_3_5G_Pin|ATT_EN_3_5G_Pin|ATT_DATA_3_5G_DL_Pin
|
|
307
|
+ |ATT_DATA_3_5G_UL_Pin|ATT_DATA_3_5G_COM1_Pin|ATT_DATA_3_5G_COM2_Pin|ATT_DATA_3_5G_COM3_Pin
|
|
308
|
+ |PATH_EN_3_5G_L_Pin, GPIO_PIN_RESET);
|
|
309
|
+
|
|
310
|
+ /*Configure GPIO pin Output Level */
|
|
311
|
+ HAL_GPIO_WritePin(GPIOG, DA_SYNC_Pin|DA_SCLK_Pin|DA_DIN_Pin|_T_SYNC_UL_Pin
|
|
312
|
+ |T_SYNC_UL_Pin|_T_SYNC_DL_Pin|T_SYNC_DL_Pin|PATH_EN_3_5G_DL_Pin
|
|
313
|
+ |PATH_EN_3_5G_UL_Pin|PLL_ON_OFF_3_5G_L_Pin|PLL_ON_OFF_3_5G_H_Pin, GPIO_PIN_RESET);
|
|
314
|
+
|
|
315
|
+ /*Configure GPIO pin Output Level */
|
|
316
|
+ HAL_GPIO_WritePin(GPIOB, PLL_EN_2_1G_DL_Pin|PLL_EN_2_1G_UL_Pin, GPIO_PIN_RESET);
|
|
317
|
+
|
|
318
|
+ /*Configure GPIO pins : ATT_EN_1_8G_DL1_Pin ATT_EN_1_8G_DL2_Pin ATT_EN_1_8G_UL1_Pin ATT_EN_1_8G_UL2_Pin
|
|
319
|
+ ATT_EN_1_8G_UL3_Pin PATH_EN_2_1G_DL_Pin PATH_EN_2_1G_UL_Pin */
|
|
320
|
+ GPIO_InitStruct.Pin = ATT_EN_1_8G_DL1_Pin|ATT_EN_1_8G_DL2_Pin|ATT_EN_1_8G_UL1_Pin|ATT_EN_1_8G_UL2_Pin
|
|
321
|
+ |ATT_EN_1_8G_UL3_Pin|PATH_EN_2_1G_DL_Pin|PATH_EN_2_1G_UL_Pin;
|
|
322
|
+ GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
323
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
324
|
+ GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
325
|
+ HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
|
326
|
+
|
|
327
|
+ /*Configure GPIO pins : ATT_EN_1_8G_UL4_Pin PATH_EN_1_8G_DL_Pin PATH_EN_1_8G_UL_Pin PLL_EN_3_5G_L_Pin
|
|
328
|
+ PLL_EN_3_5G_H_Pin */
|
|
329
|
+ GPIO_InitStruct.Pin = ATT_EN_1_8G_UL4_Pin|PATH_EN_1_8G_DL_Pin|PATH_EN_1_8G_UL_Pin|PLL_EN_3_5G_L_Pin
|
|
330
|
+ |PLL_EN_3_5G_H_Pin;
|
|
331
|
+ GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
332
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
333
|
+ GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
334
|
+ HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
335
|
+
|
|
336
|
+ /*Configure GPIO pins : PLL_EN_1_8G_DL_Pin PLL_EN_1_8G_UL_Pin ATT_EN_2_1G_DL1_Pin ATT_EN_2_1G_DL2_Pin
|
|
337
|
+ ATT_EN_2_1G_UL1_Pin ATT_EN_2_1G_UL2_Pin ATT_EN_2_1G_UL3_Pin ATT_EN_2_1G_UL4_Pin */
|
|
338
|
+ GPIO_InitStruct.Pin = PLL_EN_1_8G_DL_Pin|PLL_EN_1_8G_UL_Pin|ATT_EN_2_1G_DL1_Pin|ATT_EN_2_1G_DL2_Pin
|
|
339
|
+ |ATT_EN_2_1G_UL1_Pin|ATT_EN_2_1G_UL2_Pin|ATT_EN_2_1G_UL3_Pin|ATT_EN_2_1G_UL4_Pin;
|
|
340
|
+ GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
341
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
342
|
+ GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
343
|
+ HAL_GPIO_Init(GPIOF, &GPIO_InitStruct);
|
|
344
|
+
|
|
345
|
+ /*Configure GPIO pins : PLL_LD_1_8G_DL_Pin PLL_LD_1_8G_UL_Pin */
|
|
346
|
+ GPIO_InitStruct.Pin = PLL_LD_1_8G_DL_Pin|PLL_LD_1_8G_UL_Pin;
|
|
347
|
+ GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
348
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
349
|
+ HAL_GPIO_Init(GPIOF, &GPIO_InitStruct);
|
|
350
|
+
|
|
351
|
+ /*Configure GPIO pins : PLL_DATA_Pin PLL_CLK_Pin ATT_DATA_Pin ATT_CLK_Pin
|
|
352
|
+ DA_LDAC_Pin ATT_CLK_3_5G_Pin ATT_EN_3_5G_Pin ATT_DATA_3_5G_DL_Pin
|
|
353
|
+ ATT_DATA_3_5G_UL_Pin ATT_DATA_3_5G_COM1_Pin ATT_DATA_3_5G_COM2_Pin ATT_DATA_3_5G_COM3_Pin
|
|
354
|
+ PATH_EN_3_5G_L_Pin */
|
|
355
|
+ GPIO_InitStruct.Pin = PLL_DATA_Pin|PLL_CLK_Pin|ATT_DATA_Pin|ATT_CLK_Pin
|
|
356
|
+ |DA_LDAC_Pin|ATT_CLK_3_5G_Pin|ATT_EN_3_5G_Pin|ATT_DATA_3_5G_DL_Pin
|
|
357
|
+ |ATT_DATA_3_5G_UL_Pin|ATT_DATA_3_5G_COM1_Pin|ATT_DATA_3_5G_COM2_Pin|ATT_DATA_3_5G_COM3_Pin
|
|
358
|
+ |PATH_EN_3_5G_L_Pin;
|
|
359
|
+ GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
360
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
361
|
+ GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
362
|
+ HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
|
363
|
+
|
|
364
|
+ /*Configure GPIO pins : ALARM_DC_Pin ALARM_AC_Pin */
|
|
365
|
+ GPIO_InitStruct.Pin = ALARM_DC_Pin|ALARM_AC_Pin;
|
|
366
|
+ GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
367
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
368
|
+ HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
|
369
|
+
|
|
370
|
+ /*Configure GPIO pins : DA_SYNC_Pin DA_SCLK_Pin DA_DIN_Pin _T_SYNC_UL_Pin
|
|
371
|
+ T_SYNC_UL_Pin _T_SYNC_DL_Pin T_SYNC_DL_Pin PATH_EN_3_5G_DL_Pin
|
|
372
|
+ PATH_EN_3_5G_UL_Pin PLL_ON_OFF_3_5G_L_Pin PLL_ON_OFF_3_5G_H_Pin */
|
|
373
|
+ GPIO_InitStruct.Pin = DA_SYNC_Pin|DA_SCLK_Pin|DA_DIN_Pin|_T_SYNC_UL_Pin
|
|
374
|
+ |T_SYNC_UL_Pin|_T_SYNC_DL_Pin|T_SYNC_DL_Pin|PATH_EN_3_5G_DL_Pin
|
|
375
|
+ |PATH_EN_3_5G_UL_Pin|PLL_ON_OFF_3_5G_L_Pin|PLL_ON_OFF_3_5G_H_Pin;
|
|
376
|
+ GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
377
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
378
|
+ GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
379
|
+ HAL_GPIO_Init(GPIOG, &GPIO_InitStruct);
|
|
380
|
+
|
|
381
|
+ /*Configure GPIO pins : PLL_LD_3_5G_L_Pin PLL_LD_3_5G_H_Pin */
|
|
382
|
+ GPIO_InitStruct.Pin = PLL_LD_3_5G_L_Pin|PLL_LD_3_5G_H_Pin;
|
|
383
|
+ GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
384
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
385
|
+ HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
386
|
+
|
|
387
|
+ /*Configure GPIO pin : PATH_EN_3_5G_H_Pin */
|
|
388
|
+ GPIO_InitStruct.Pin = PATH_EN_3_5G_H_Pin;
|
|
389
|
+ GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
390
|
+ HAL_GPIO_Init(PATH_EN_3_5G_H_GPIO_Port, &GPIO_InitStruct);
|
|
391
|
+
|
|
392
|
+ /*Configure GPIO pins : PLL_EN_2_1G_DL_Pin PLL_EN_2_1G_UL_Pin */
|
|
393
|
+ GPIO_InitStruct.Pin = PLL_EN_2_1G_DL_Pin|PLL_EN_2_1G_UL_Pin;
|
|
394
|
+ GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
395
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
396
|
+ GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
397
|
+ HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
398
|
+
|
|
399
|
+ /*Configure GPIO pins : PLL_LD_2_1G_DL_Pin PLL_LD_2_1G_UL_Pin */
|
|
400
|
+ GPIO_InitStruct.Pin = PLL_LD_2_1G_DL_Pin|PLL_LD_2_1G_UL_Pin;
|
|
401
|
+ GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
402
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
403
|
+ HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
404
|
+
|
|
405
|
+}
|
|
406
|
+
|
|
407
|
+/* USER CODE BEGIN 4 */
|
|
408
|
+
|
|
409
|
+/* USER CODE END 4 */
|
|
410
|
+
|
|
411
|
+/**
|
|
412
|
+ * @brief This function is executed in case of error occurrence.
|
|
413
|
+ * @retval None
|
|
414
|
+ */
|
|
415
|
+void Error_Handler(void)
|
|
416
|
+{
|
|
417
|
+ /* USER CODE BEGIN Error_Handler_Debug */
|
|
418
|
+ /* User can add his own implementation to report the HAL error return state */
|
|
419
|
+
|
|
420
|
+ /* USER CODE END Error_Handler_Debug */
|
|
421
|
+}
|
|
422
|
+
|
|
423
|
+#ifdef USE_FULL_ASSERT
|
|
424
|
+/**
|
|
425
|
+ * @brief Reports the name of the source file and the source line number
|
|
426
|
+ * where the assert_param error has occurred.
|
|
427
|
+ * @param file: pointer to the source file name
|
|
428
|
+ * @param line: assert_param error line source number
|
|
429
|
+ * @retval None
|
|
430
|
+ */
|
|
431
|
+void assert_failed(uint8_t *file, uint32_t line)
|
|
432
|
+{
|
|
433
|
+ /* USER CODE BEGIN 6 */
|
|
434
|
+ /* User can add his own implementation to report the file name and line number,
|
|
435
|
+ tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
|
|
436
|
+ /* USER CODE END 6 */
|
|
437
|
+}
|
|
438
|
+#endif /* USE_FULL_ASSERT */
|
|
439
|
+
|
|
440
|
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|