forked from achamaikin/CCSModuleSW30Web
clean project
This commit is contained in:
@@ -1,5 +1,6 @@
|
|||||||
# macOS
|
# macOS
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
**/.DS_Store
|
||||||
|
|
||||||
# Temporary/editor files
|
# Temporary/editor files
|
||||||
*.swp
|
*.swp
|
||||||
@@ -57,3 +58,6 @@ Release/**/*.obj
|
|||||||
# Optional local launch configs
|
# Optional local launch configs
|
||||||
*.launch
|
*.launch
|
||||||
|
|
||||||
|
# VS Code local settings
|
||||||
|
.vscode/
|
||||||
|
|
||||||
|
|||||||
+47
-63
@@ -1,63 +1,47 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file adc.h
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* @brief This file contains all the function prototypes for
|
#ifndef __ADC_H__
|
||||||
* the adc.c file
|
#define __ADC_H__
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
#ifdef __cplusplus
|
||||||
*
|
extern "C" {
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
#endif
|
||||||
* All rights reserved.
|
|
||||||
*
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#include "main.h"
|
||||||
* in the root directory of this software component.
|
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN Includes */
|
||||||
*
|
#include <stdint.h>
|
||||||
******************************************************************************
|
|
||||||
*/
|
/* USER CODE END Includes */
|
||||||
/* USER CODE END Header */
|
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
extern ADC_HandleTypeDef hadc1;
|
||||||
#ifndef __ADC_H__
|
|
||||||
#define __ADC_H__
|
/* USER CODE BEGIN Private defines */
|
||||||
|
typedef struct {
|
||||||
#ifdef __cplusplus
|
uint16_t in3_raw; /* Rank1: ADC_CHANNEL_3 */
|
||||||
extern "C" {
|
uint16_t cp_raw; /* Rank2: ADC_CHANNEL_4 */
|
||||||
#endif
|
uint16_t ntc1_raw; /* Rank3: ADC_CHANNEL_8 */
|
||||||
|
uint16_t ntc2_raw; /* Rank4: ADC_CHANNEL_9 */
|
||||||
/* Includes ------------------------------------------------------------------*/
|
uint16_t temp_sensor_raw; /* Rank5: ADC_CHANNEL_TEMPSENSOR */
|
||||||
#include "main.h"
|
uint16_t vrefint_raw; /* Rank6: ADC_CHANNEL_VREFINT */
|
||||||
|
} ADC_ScanData_t;
|
||||||
/* USER CODE BEGIN Includes */
|
extern volatile ADC_ScanData_t adc_data;
|
||||||
#include <stdint.h>
|
|
||||||
|
/* USER CODE END Private defines */
|
||||||
/* USER CODE END Includes */
|
|
||||||
|
void MX_ADC1_Init(void);
|
||||||
extern ADC_HandleTypeDef hadc1;
|
|
||||||
|
/* USER CODE BEGIN Prototypes */
|
||||||
/* USER CODE BEGIN Private defines */
|
void ADC_ScanStart(void);
|
||||||
typedef struct {
|
|
||||||
uint16_t in3_raw; /* Rank1: ADC_CHANNEL_3 */
|
/* USER CODE END Prototypes */
|
||||||
uint16_t cp_raw; /* Rank2: ADC_CHANNEL_4 */
|
|
||||||
uint16_t ntc1_raw; /* Rank3: ADC_CHANNEL_8 */
|
#ifdef __cplusplus
|
||||||
uint16_t ntc2_raw; /* Rank4: ADC_CHANNEL_9 */
|
}
|
||||||
uint16_t temp_sensor_raw; /* Rank5: ADC_CHANNEL_TEMPSENSOR */
|
#endif
|
||||||
uint16_t vrefint_raw; /* Rank6: ADC_CHANNEL_VREFINT */
|
|
||||||
} ADC_ScanData_t;
|
#endif /* __ADC_H__ */
|
||||||
extern volatile ADC_ScanData_t adc_data;
|
|
||||||
|
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
void MX_ADC1_Init(void);
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Prototypes */
|
|
||||||
void ADC_ScanStart(void);
|
|
||||||
|
|
||||||
/* USER CODE END Prototypes */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __ADC_H__ */
|
|
||||||
|
|
||||||
|
|||||||
+3
-13
@@ -1,14 +1,6 @@
|
|||||||
/*
|
#pragma once
|
||||||
* board.h
|
|
||||||
*
|
|
||||||
* Created on: Apr 15, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef SRC_BOARD_H_
|
#include <stdint.h>
|
||||||
#define SRC_BOARD_H_
|
|
||||||
|
|
||||||
void GBT_Lock(uint8_t state);
|
|
||||||
|
|
||||||
typedef enum{
|
typedef enum{
|
||||||
RELAY_AUX0 = 0,
|
RELAY_AUX0 = 0,
|
||||||
@@ -24,6 +16,7 @@ typedef enum{
|
|||||||
} relay_t;
|
} relay_t;
|
||||||
|
|
||||||
void RELAY_Write(relay_t num, uint8_t state);
|
void RELAY_Write(relay_t num, uint8_t state);
|
||||||
|
uint8_t RELAY_Read(relay_t num);
|
||||||
void Init_Peripheral();
|
void Init_Peripheral();
|
||||||
uint8_t GBT_LockGetState();
|
uint8_t GBT_LockGetState();
|
||||||
void GBT_Lock(uint8_t state);
|
void GBT_Lock(uint8_t state);
|
||||||
@@ -60,6 +53,3 @@ typedef struct __attribute__((packed)) {
|
|||||||
} InfoBlock_t;
|
} InfoBlock_t;
|
||||||
|
|
||||||
extern InfoBlock_t *InfoBlock;
|
extern InfoBlock_t *InfoBlock;
|
||||||
|
|
||||||
|
|
||||||
#endif /* SRC_BOARD_H_ */
|
|
||||||
|
|||||||
+39
-55
@@ -1,55 +1,39 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file can.h
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* @brief This file contains all the function prototypes for
|
#ifndef __CAN_H__
|
||||||
* the can.c file
|
#define __CAN_H__
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
#ifdef __cplusplus
|
||||||
*
|
extern "C" {
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
#endif
|
||||||
* All rights reserved.
|
|
||||||
*
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#include "main.h"
|
||||||
* in the root directory of this software component.
|
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN Includes */
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE END Includes */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
extern CAN_HandleTypeDef hcan1;
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __CAN_H__
|
extern CAN_HandleTypeDef hcan2;
|
||||||
#define __CAN_H__
|
|
||||||
|
/* USER CODE BEGIN Private defines */
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
/* USER CODE END Private defines */
|
||||||
#endif
|
|
||||||
|
void MX_CAN1_Init(void);
|
||||||
/* Includes ------------------------------------------------------------------*/
|
void MX_CAN2_Init(void);
|
||||||
#include "main.h"
|
|
||||||
|
/* USER CODE BEGIN Prototypes */
|
||||||
/* USER CODE BEGIN Includes */
|
|
||||||
|
/* USER CODE END Prototypes */
|
||||||
/* USER CODE END Includes */
|
|
||||||
|
#ifdef __cplusplus
|
||||||
extern CAN_HandleTypeDef hcan1;
|
}
|
||||||
|
#endif
|
||||||
extern CAN_HandleTypeDef hcan2;
|
|
||||||
|
#endif /* __CAN_H__ */
|
||||||
/* USER CODE BEGIN Private defines */
|
|
||||||
|
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
void MX_CAN1_Init(void);
|
|
||||||
void MX_CAN2_Init(void);
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Prototypes */
|
|
||||||
|
|
||||||
/* USER CODE END Prototypes */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __CAN_H__ */
|
|
||||||
|
|
||||||
|
|||||||
@@ -5,9 +5,11 @@
|
|||||||
#define PSU_MIN_VOLTAGE 150 //1V/bit
|
#define PSU_MIN_VOLTAGE 150 //1V/bit
|
||||||
#define PSU_MAX_CURRENT 133 //1A/bit
|
#define PSU_MAX_CURRENT 133 //1A/bit
|
||||||
#define PSU_MIN_CURRENT 1 //1A/bit
|
#define PSU_MIN_CURRENT 1 //1A/bit
|
||||||
#define PSU_MAX_POWER 30000 //1W/bit
|
#define PSU_MAX_POWER 40000 //1W/bit
|
||||||
|
|
||||||
#define PSU_NUM 1
|
#define PSU_NUM 1
|
||||||
|
|
||||||
#define GBT_CH_VER_MAJOR 1
|
/* Everest / стенд: запрос «500 В» на шине — реально на PSU задаются U/I ниже; статус может оставаться 500 В (serial.c). */
|
||||||
#define GBT_CH_VER_MINOR 0
|
#define FAKE_EVREQ_VOLTAGE_V 500u
|
||||||
|
#define FAKE_PSU_VOLTAGE_V 300u
|
||||||
|
#define FAKE_PSU_CURRENT_0P1A 10u
|
||||||
|
|||||||
@@ -1,12 +1,4 @@
|
|||||||
/*
|
#pragma once
|
||||||
* charger_control.h
|
|
||||||
*
|
|
||||||
* Created on: Jul 29, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef INC_CHARGER_CONTROL_H_
|
|
||||||
#define INC_CHARGER_CONTROL_H_
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
|
||||||
@@ -83,16 +75,6 @@ typedef struct{
|
|||||||
|
|
||||||
extern ChargingConnector_t CONN;
|
extern ChargingConnector_t CONN;
|
||||||
|
|
||||||
//информация о зарядке
|
|
||||||
|
|
||||||
//база данных с хранением инфы
|
|
||||||
//главный блок хранит в себе инфу о конфиге возможно во флеше
|
|
||||||
//либо в charger_config.h
|
|
||||||
//OCPP - универсальный блок типа
|
|
||||||
|
|
||||||
void CONN_Init();
|
void CONN_Init();
|
||||||
void CONN_Loop();
|
void CONN_Loop();
|
||||||
|
|
||||||
void CONN_PrintChargingTotal();
|
|
||||||
|
|
||||||
#endif /* INC_CHARGER_CONTROL_H_ */
|
|
||||||
|
|||||||
+1
-12
@@ -1,12 +1,4 @@
|
|||||||
/*
|
#pragma once
|
||||||
* connector.h
|
|
||||||
*
|
|
||||||
* Created on: Jul 31, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef INC_CONNECTOR_H_
|
|
||||||
#define INC_CONNECTOR_H_
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "charger_control.h"
|
#include "charger_control.h"
|
||||||
@@ -15,7 +7,4 @@
|
|||||||
extern CONN_State_t connectorState;
|
extern CONN_State_t connectorState;
|
||||||
|
|
||||||
void CONN_Init();
|
void CONN_Init();
|
||||||
void CONN_Task();
|
|
||||||
void CONN_SetState(CONN_State_t state);
|
void CONN_SetState(CONN_State_t state);
|
||||||
|
|
||||||
#endif /* INC_CONNECTOR_H_ */
|
|
||||||
|
|||||||
+1
-4
@@ -1,5 +1,4 @@
|
|||||||
#ifndef __CP_H
|
#pragma once
|
||||||
#define __CP_H
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
@@ -27,5 +26,3 @@ CP_State_t CP_GetFilteredState(void);
|
|||||||
void CP_FilterState(void);
|
void CP_FilterState(void);
|
||||||
void CP_Loop(void);
|
void CP_Loop(void);
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|||||||
+36
-52
@@ -1,52 +1,36 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file crc.h
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* @brief This file contains all the function prototypes for
|
#ifndef __CRC_H__
|
||||||
* the crc.c file
|
#define __CRC_H__
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
#ifdef __cplusplus
|
||||||
*
|
extern "C" {
|
||||||
* Copyright (c) 2025 STMicroelectronics.
|
#endif
|
||||||
* All rights reserved.
|
|
||||||
*
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#include "main.h"
|
||||||
* in the root directory of this software component.
|
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN Includes */
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE END Includes */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
extern CRC_HandleTypeDef hcrc;
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __CRC_H__
|
/* USER CODE BEGIN Private defines */
|
||||||
#define __CRC_H__
|
|
||||||
|
/* USER CODE END Private defines */
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
void MX_CRC_Init(void);
|
||||||
#endif
|
|
||||||
|
/* USER CODE BEGIN Prototypes */
|
||||||
/* Includes ------------------------------------------------------------------*/
|
|
||||||
#include "main.h"
|
/* USER CODE END Prototypes */
|
||||||
|
|
||||||
/* USER CODE BEGIN Includes */
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
/* USER CODE END Includes */
|
#endif
|
||||||
|
|
||||||
extern CRC_HandleTypeDef hcrc;
|
#endif /* __CRC_H__ */
|
||||||
|
|
||||||
/* USER CODE BEGIN Private defines */
|
|
||||||
|
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
void MX_CRC_Init(void);
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Prototypes */
|
|
||||||
|
|
||||||
/* USER CODE END Prototypes */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __CRC_H__ */
|
|
||||||
|
|
||||||
|
|||||||
+1
-11
@@ -1,12 +1,4 @@
|
|||||||
/*
|
#pragma once
|
||||||
* debug.h
|
|
||||||
*
|
|
||||||
* Created on: Apr 16, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef SRC_DEBUG_H_
|
|
||||||
#define SRC_DEBUG_H_
|
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
@@ -30,5 +22,3 @@ void debug_buffer_send(void);
|
|||||||
|
|
||||||
// Кастомный printf с приоритетом лога
|
// Кастомный printf с приоритетом лога
|
||||||
int log_printf(LogLevel_t level, const char *format, ...);
|
int log_printf(LogLevel_t level, const char *format, ...);
|
||||||
|
|
||||||
#endif /* SRC_DEBUG_H_ */
|
|
||||||
|
|||||||
+36
-52
@@ -1,52 +1,36 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file dma.h
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* @brief This file contains all the function prototypes for
|
#ifndef __DMA_H__
|
||||||
* the dma.c file
|
#define __DMA_H__
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
#ifdef __cplusplus
|
||||||
*
|
extern "C" {
|
||||||
* Copyright (c) 2026 STMicroelectronics.
|
#endif
|
||||||
* All rights reserved.
|
|
||||||
*
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#include "main.h"
|
||||||
* in the root directory of this software component.
|
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* DMA memory to memory transfer handles -------------------------------------*/
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE BEGIN Includes */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
/* USER CODE END Includes */
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __DMA_H__
|
/* USER CODE BEGIN Private defines */
|
||||||
#define __DMA_H__
|
|
||||||
|
/* USER CODE END Private defines */
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
void MX_DMA_Init(void);
|
||||||
#endif
|
|
||||||
|
/* USER CODE BEGIN Prototypes */
|
||||||
/* Includes ------------------------------------------------------------------*/
|
|
||||||
#include "main.h"
|
/* USER CODE END Prototypes */
|
||||||
|
|
||||||
/* DMA memory to memory transfer handles -------------------------------------*/
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
/* USER CODE BEGIN Includes */
|
#endif
|
||||||
|
|
||||||
/* USER CODE END Includes */
|
#endif /* __DMA_H__ */
|
||||||
|
|
||||||
/* USER CODE BEGIN Private defines */
|
|
||||||
|
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
void MX_DMA_Init(void);
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Prototypes */
|
|
||||||
|
|
||||||
/* USER CODE END Prototypes */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __DMA_H__ */
|
|
||||||
|
|
||||||
|
|||||||
+33
-49
@@ -1,49 +1,33 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file gpio.h
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* @brief This file contains all the function prototypes for
|
#ifndef __GPIO_H__
|
||||||
* the gpio.c file
|
#define __GPIO_H__
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
#ifdef __cplusplus
|
||||||
*
|
extern "C" {
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
#endif
|
||||||
* All rights reserved.
|
|
||||||
*
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#include "main.h"
|
||||||
* in the root directory of this software component.
|
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN Includes */
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE END Includes */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
/* USER CODE BEGIN Private defines */
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __GPIO_H__
|
/* USER CODE END Private defines */
|
||||||
#define __GPIO_H__
|
|
||||||
|
void MX_GPIO_Init(void);
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
/* USER CODE BEGIN Prototypes */
|
||||||
#endif
|
|
||||||
|
/* USER CODE END Prototypes */
|
||||||
/* Includes ------------------------------------------------------------------*/
|
|
||||||
#include "main.h"
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
/* USER CODE BEGIN Includes */
|
#endif
|
||||||
|
#endif /*__ GPIO_H__ */
|
||||||
/* USER CODE END Includes */
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Private defines */
|
|
||||||
|
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
void MX_GPIO_Init(void);
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Prototypes */
|
|
||||||
|
|
||||||
/* USER CODE END Prototypes */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#endif /*__ GPIO_H__ */
|
|
||||||
|
|
||||||
|
|||||||
+1
-4
@@ -1,5 +1,4 @@
|
|||||||
#ifndef ISR_OPT_H
|
#pragma once
|
||||||
#define ISR_OPT_H
|
|
||||||
|
|
||||||
/* GCC: быстрые функции, вызываемые из IRQ / из HAL из IRQ-контекста */
|
/* GCC: быстрые функции, вызываемые из IRQ / из HAL из IRQ-контекста */
|
||||||
#if defined(__GNUC__)
|
#if defined(__GNUC__)
|
||||||
@@ -7,5 +6,3 @@
|
|||||||
#else
|
#else
|
||||||
#define ISR_FAST
|
#define ISR_FAST
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* ISR_OPT_H */
|
|
||||||
|
|||||||
+115
-129
@@ -1,129 +1,115 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file : main.h
|
|
||||||
* @brief : Header for main.c file.
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* This file contains the common defines of the application.
|
#ifndef __MAIN_H
|
||||||
******************************************************************************
|
#define __MAIN_H
|
||||||
* @attention
|
|
||||||
*
|
#ifdef __cplusplus
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
extern "C" {
|
||||||
* All rights reserved.
|
#endif
|
||||||
*
|
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* in the root directory of this software component.
|
#include "stm32f1xx_hal.h"
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
|
||||||
*
|
/* Private includes ----------------------------------------------------------*/
|
||||||
******************************************************************************
|
/* USER CODE BEGIN Includes */
|
||||||
*/
|
#include <stdio.h>
|
||||||
/* USER CODE END Header */
|
/* USER CODE END Includes */
|
||||||
|
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
/* Exported types ------------------------------------------------------------*/
|
||||||
#ifndef __MAIN_H
|
/* USER CODE BEGIN ET */
|
||||||
#define __MAIN_H
|
|
||||||
|
/* USER CODE END ET */
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
/* Exported constants --------------------------------------------------------*/
|
||||||
#endif
|
/* USER CODE BEGIN EC */
|
||||||
|
#define FW_VERSION_MAJOR 1
|
||||||
/* Includes ------------------------------------------------------------------*/
|
#define FW_VERSION_MINOR 0
|
||||||
#include "stm32f1xx_hal.h"
|
#define FW_VERSION_PATCH 17
|
||||||
|
/* USER CODE END EC */
|
||||||
/* Private includes ----------------------------------------------------------*/
|
|
||||||
/* USER CODE BEGIN Includes */
|
/* Exported macro ------------------------------------------------------------*/
|
||||||
#include <stdio.h>
|
/* USER CODE BEGIN EM */
|
||||||
/* USER CODE END Includes */
|
|
||||||
|
/* USER CODE END EM */
|
||||||
/* Exported types ------------------------------------------------------------*/
|
|
||||||
/* USER CODE BEGIN ET */
|
/* Exported functions prototypes ---------------------------------------------*/
|
||||||
|
void Error_Handler(void);
|
||||||
/* USER CODE END ET */
|
|
||||||
|
/* USER CODE BEGIN EFP */
|
||||||
/* Exported constants --------------------------------------------------------*/
|
uint8_t ED_TraceWarning(uint8_t flag, uint8_t id);
|
||||||
/* USER CODE BEGIN EC */
|
void ED_Delay(uint32_t Delay);
|
||||||
#define FW_VERSION_MAJOR 1
|
|
||||||
#define FW_VERSION_MINOR 0
|
/* USER CODE END EFP */
|
||||||
#define FW_VERSION_PATCH 17
|
|
||||||
/* USER CODE END EC */
|
/* Private defines -----------------------------------------------------------*/
|
||||||
|
#define DBG1_Pin GPIO_PIN_2
|
||||||
/* Exported macro ------------------------------------------------------------*/
|
#define DBG1_GPIO_Port GPIOC
|
||||||
/* USER CODE BEGIN EM */
|
#define RELAY_CP_Pin GPIO_PIN_3
|
||||||
|
#define RELAY_CP_GPIO_Port GPIOC
|
||||||
/* USER CODE END EM */
|
#define IN_SW0_Pin GPIO_PIN_1
|
||||||
|
#define IN_SW0_GPIO_Port GPIOA
|
||||||
/* Exported functions prototypes ---------------------------------------------*/
|
#define IN_SW1_Pin GPIO_PIN_2
|
||||||
void Error_Handler(void);
|
#define IN_SW1_GPIO_Port GPIOA
|
||||||
|
#define CP_ADC_Pin GPIO_PIN_4
|
||||||
/* USER CODE BEGIN EFP */
|
#define CP_ADC_GPIO_Port GPIOA
|
||||||
|
#define DBG2_Pin GPIO_PIN_5
|
||||||
/* USER CODE END EFP */
|
#define DBG2_GPIO_Port GPIOA
|
||||||
|
#define DBG3_Pin GPIO_PIN_6
|
||||||
/* Private defines -----------------------------------------------------------*/
|
#define DBG3_GPIO_Port GPIOA
|
||||||
#define DBG1_Pin GPIO_PIN_2
|
#define CP_PWM_Pin GPIO_PIN_7
|
||||||
#define DBG1_GPIO_Port GPIOC
|
#define CP_PWM_GPIO_Port GPIOA
|
||||||
#define RELAY_CP_Pin GPIO_PIN_3
|
#define LOCK_A_Pin GPIO_PIN_4
|
||||||
#define RELAY_CP_GPIO_Port GPIOC
|
#define LOCK_A_GPIO_Port GPIOC
|
||||||
#define IN_SW0_Pin GPIO_PIN_1
|
#define LOCK_B_Pin GPIO_PIN_5
|
||||||
#define IN_SW0_GPIO_Port GPIOA
|
#define LOCK_B_GPIO_Port GPIOC
|
||||||
#define IN_SW1_Pin GPIO_PIN_2
|
#define ADC_NTC1_Pin GPIO_PIN_0
|
||||||
#define IN_SW1_GPIO_Port GPIOA
|
#define ADC_NTC1_GPIO_Port GPIOB
|
||||||
#define CP_ADC_Pin GPIO_PIN_4
|
#define ADC_NTC2_Pin GPIO_PIN_1
|
||||||
#define CP_ADC_GPIO_Port GPIOA
|
#define ADC_NTC2_GPIO_Port GPIOB
|
||||||
#define DBG2_Pin GPIO_PIN_5
|
#define IN0_Pin GPIO_PIN_7
|
||||||
#define DBG2_GPIO_Port GPIOA
|
#define IN0_GPIO_Port GPIOE
|
||||||
#define DBG3_Pin GPIO_PIN_6
|
#define RELAY1_Pin GPIO_PIN_8
|
||||||
#define DBG3_GPIO_Port GPIOA
|
#define RELAY1_GPIO_Port GPIOE
|
||||||
#define CP_PWM_Pin GPIO_PIN_7
|
#define RELAY2_Pin GPIO_PIN_9
|
||||||
#define CP_PWM_GPIO_Port GPIOA
|
#define RELAY2_GPIO_Port GPIOE
|
||||||
#define LOCK_A_Pin GPIO_PIN_4
|
#define RELAY3_Pin GPIO_PIN_10
|
||||||
#define LOCK_A_GPIO_Port GPIOC
|
#define RELAY3_GPIO_Port GPIOE
|
||||||
#define LOCK_B_Pin GPIO_PIN_5
|
#define RELAY4_Pin GPIO_PIN_11
|
||||||
#define LOCK_B_GPIO_Port GPIOC
|
#define RELAY4_GPIO_Port GPIOE
|
||||||
#define ADC_NTC1_Pin GPIO_PIN_0
|
#define RELAY5_Pin GPIO_PIN_12
|
||||||
#define ADC_NTC1_GPIO_Port GPIOB
|
#define RELAY5_GPIO_Port GPIOE
|
||||||
#define ADC_NTC2_Pin GPIO_PIN_1
|
#define AC_OK_Pin GPIO_PIN_14
|
||||||
#define ADC_NTC2_GPIO_Port GPIOB
|
#define AC_OK_GPIO_Port GPIOE
|
||||||
#define IN0_Pin GPIO_PIN_7
|
#define DBG5_Pin GPIO_PIN_10
|
||||||
#define IN0_GPIO_Port GPIOE
|
#define DBG5_GPIO_Port GPIOB
|
||||||
#define RELAY1_Pin GPIO_PIN_8
|
#define DBG4_Pin GPIO_PIN_11
|
||||||
#define RELAY1_GPIO_Port GPIOE
|
#define DBG4_GPIO_Port GPIOB
|
||||||
#define RELAY2_Pin GPIO_PIN_9
|
#define RELAY_CC_Pin GPIO_PIN_15
|
||||||
#define RELAY2_GPIO_Port GPIOE
|
#define RELAY_CC_GPIO_Port GPIOA
|
||||||
#define RELAY3_Pin GPIO_PIN_10
|
#define RELAY_DC_Pin GPIO_PIN_3
|
||||||
#define RELAY3_GPIO_Port GPIOE
|
#define RELAY_DC_GPIO_Port GPIOD
|
||||||
#define RELAY4_Pin GPIO_PIN_11
|
#define USART2_DIR_Pin GPIO_PIN_4
|
||||||
#define RELAY4_GPIO_Port GPIOE
|
#define USART2_DIR_GPIO_Port GPIOD
|
||||||
#define RELAY5_Pin GPIO_PIN_12
|
#define IN_ESTOP_Pin GPIO_PIN_7
|
||||||
#define RELAY5_GPIO_Port GPIOE
|
#define IN_ESTOP_GPIO_Port GPIOD
|
||||||
#define AC_OK_Pin GPIO_PIN_14
|
#define IN_FB2_Pin GPIO_PIN_3
|
||||||
#define AC_OK_GPIO_Port GPIOE
|
#define IN_FB2_GPIO_Port GPIOB
|
||||||
#define DBG5_Pin GPIO_PIN_10
|
#define IN_FB1_Pin GPIO_PIN_4
|
||||||
#define DBG5_GPIO_Port GPIOB
|
#define IN_FB1_GPIO_Port GPIOB
|
||||||
#define DBG4_Pin GPIO_PIN_11
|
#define EE_WP_Pin GPIO_PIN_7
|
||||||
#define DBG4_GPIO_Port GPIOB
|
#define EE_WP_GPIO_Port GPIOB
|
||||||
#define RELAY_CC_Pin GPIO_PIN_15
|
#define ISO_IN_Pin GPIO_PIN_1
|
||||||
#define RELAY_CC_GPIO_Port GPIOA
|
#define ISO_IN_GPIO_Port GPIOE
|
||||||
#define RELAY_DC_Pin GPIO_PIN_3
|
|
||||||
#define RELAY_DC_GPIO_Port GPIOD
|
/* USER CODE BEGIN Private defines */
|
||||||
#define USART2_DIR_Pin GPIO_PIN_4
|
|
||||||
#define USART2_DIR_GPIO_Port GPIOD
|
/* USER CODE END Private defines */
|
||||||
#define IN_ESTOP_Pin GPIO_PIN_7
|
|
||||||
#define IN_ESTOP_GPIO_Port GPIOD
|
#ifdef __cplusplus
|
||||||
#define IN_FB2_Pin GPIO_PIN_3
|
}
|
||||||
#define IN_FB2_GPIO_Port GPIOB
|
#endif
|
||||||
#define IN_FB1_Pin GPIO_PIN_4
|
|
||||||
#define IN_FB1_GPIO_Port GPIOB
|
#endif /* __MAIN_H */
|
||||||
#define EE_WP_Pin GPIO_PIN_7
|
|
||||||
#define EE_WP_GPIO_Port GPIOB
|
|
||||||
#define ISO_IN_Pin GPIO_PIN_1
|
|
||||||
#define ISO_IN_GPIO_Port GPIOE
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Private defines */
|
|
||||||
|
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __MAIN_H */
|
|
||||||
|
|||||||
+1
-13
@@ -1,25 +1,15 @@
|
|||||||
/*
|
#pragma once
|
||||||
* psu_struct.h
|
|
||||||
*
|
|
||||||
* Created on: Jul 24, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef INC_METER_H_
|
|
||||||
#define INC_METER_H_
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "charger_config.h"
|
#include "charger_config.h"
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint32_t meterLastTick; // Время последнего пакета Alive
|
|
||||||
uint8_t online;
|
uint8_t online;
|
||||||
uint32_t lastTick; // Время последнего вызова для каждого коннектора
|
uint32_t lastTick; // Время последнего вызова для каждого коннектора
|
||||||
uint64_t EnergyPSU_Ws; // Энергия для каждого коннектора (расчет по силовым модулям)
|
uint64_t EnergyPSU_Ws; // Энергия для каждого коннектора (расчет по силовым модулям)
|
||||||
uint32_t AbsoluteEnergy; // Абсолютная энергия каждого счетчика (ватт*час)
|
uint32_t AbsoluteEnergy; // Абсолютная энергия каждого счетчика (ватт*час)
|
||||||
uint32_t EnergyOffset; // смещение энергии по счетчикам (если 0, значит не успели захватить Offset) (ватт*час)
|
uint32_t EnergyOffset; // смещение энергии по счетчикам (если 0, значит не успели захватить Offset) (ватт*час)
|
||||||
uint32_t EnergyOffset1; // смещение энергии по счетчикам относительно PSU
|
|
||||||
|
|
||||||
uint8_t enable; //если 0, то счетчик обнуляется
|
uint8_t enable; //если 0, то счетчик обнуляется
|
||||||
}METER_t;
|
}METER_t;
|
||||||
@@ -27,5 +17,3 @@ typedef struct {
|
|||||||
extern METER_t METER;
|
extern METER_t METER;
|
||||||
|
|
||||||
void METER_CalculateEnergy();
|
void METER_CalculateEnergy();
|
||||||
|
|
||||||
#endif /* INC_METER_H_ */
|
|
||||||
|
|||||||
+2
-15
@@ -1,20 +1,11 @@
|
|||||||
/*
|
#pragma once
|
||||||
* ccs_control.h
|
|
||||||
*
|
|
||||||
* Created on: 19 авг. 2024 г.
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef INC_PSU_CONTROL_H_
|
|
||||||
#define INC_PSU_CONTROL_H_
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "charger_config.h"
|
#include "charger_config.h"
|
||||||
|
|
||||||
void PSU_Init();
|
void PSU_Init();
|
||||||
void PSU_Enable(uint8_t addr, uint8_t enable);
|
void PSU_Enable(uint8_t addr, uint8_t enable);
|
||||||
void PSU_Loop();
|
void PSU_ReadWrite(void);
|
||||||
void CONT_Loop();
|
|
||||||
|
|
||||||
// --- Состояние силового модуля (DC30, один PSU) ---
|
// --- Состояние силового модуля (DC30, один PSU) ---
|
||||||
|
|
||||||
@@ -191,7 +182,3 @@ extern PSU_1B_t PSU_1B;
|
|||||||
extern PSU_1C_t PSU_1C;
|
extern PSU_1C_t PSU_1C;
|
||||||
|
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* INC_PSU_CONTROL_H_ */
|
|
||||||
|
|||||||
@@ -1,12 +1,4 @@
|
|||||||
/*
|
#pragma once
|
||||||
* rgb_handler.h
|
|
||||||
*
|
|
||||||
* Created on: Jul 25, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef INC_RGB_CONTROLLER_H_
|
|
||||||
#define INC_RGB_CONTROLLER_H_
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
|
||||||
@@ -48,6 +40,4 @@ typedef struct{
|
|||||||
void LED_Task();
|
void LED_Task();
|
||||||
void LED_Write();
|
void LED_Write();
|
||||||
void LED_Init();
|
void LED_Init();
|
||||||
|
void LED_SetColor(RGB_Cycle_t *color);
|
||||||
|
|
||||||
#endif /* INC_RGB_CONTROLLER_H_ */
|
|
||||||
|
|||||||
+36
-52
@@ -1,52 +1,36 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file rtc.h
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* @brief This file contains all the function prototypes for
|
#ifndef __RTC_H__
|
||||||
* the rtc.c file
|
#define __RTC_H__
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
#ifdef __cplusplus
|
||||||
*
|
extern "C" {
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
#endif
|
||||||
* All rights reserved.
|
|
||||||
*
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#include "main.h"
|
||||||
* in the root directory of this software component.
|
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN Includes */
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE END Includes */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
extern RTC_HandleTypeDef hrtc;
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __RTC_H__
|
/* USER CODE BEGIN Private defines */
|
||||||
#define __RTC_H__
|
|
||||||
|
/* USER CODE END Private defines */
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
void MX_RTC_Init(void);
|
||||||
#endif
|
|
||||||
|
/* USER CODE BEGIN Prototypes */
|
||||||
/* Includes ------------------------------------------------------------------*/
|
|
||||||
#include "main.h"
|
/* USER CODE END Prototypes */
|
||||||
|
|
||||||
/* USER CODE BEGIN Includes */
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
/* USER CODE END Includes */
|
#endif
|
||||||
|
|
||||||
extern RTC_HandleTypeDef hrtc;
|
#endif /* __RTC_H__ */
|
||||||
|
|
||||||
/* USER CODE BEGIN Private defines */
|
|
||||||
|
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
void MX_RTC_Init(void);
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Prototypes */
|
|
||||||
|
|
||||||
/* USER CODE END Prototypes */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __RTC_H__ */
|
|
||||||
|
|
||||||
|
|||||||
+1
-5
@@ -1,5 +1,4 @@
|
|||||||
#ifndef __SERIAL_H
|
#pragma once
|
||||||
#define __SERIAL_H
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "charger_control.h"
|
#include "charger_control.h"
|
||||||
@@ -125,6 +124,3 @@ extern CCS_MaxLoad_t CCS_MaxLoad;
|
|||||||
extern CCS_EvInfo_t CCS_EvInfo;
|
extern CCS_EvInfo_t CCS_EvInfo;
|
||||||
extern CONN_State_t CCS_EvseState;
|
extern CONN_State_t CCS_EvseState;
|
||||||
extern uint8_t REPLUG;
|
extern uint8_t REPLUG;
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,13 +1,10 @@
|
|||||||
#ifndef SERIALCONTROL_H
|
#pragma once
|
||||||
#define SERIALCONTROL_H
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "charger_control.h"
|
#include "charger_control.h"
|
||||||
#include "isr_opt.h"
|
#include "isr_opt.h"
|
||||||
|
|
||||||
#define USE_WEB_INTERFACE
|
|
||||||
|
|
||||||
// Команды от ПК к устройству
|
// Команды от ПК к устройству
|
||||||
// Пакет статуса изоляции от отдельного блока по одностороннему UART
|
// Пакет статуса изоляции от отдельного блока по одностороннему UART
|
||||||
#define CMD_ISOLATION_STATUS 0x01
|
#define CMD_ISOLATION_STATUS 0x01
|
||||||
@@ -180,5 +177,3 @@ extern StatusPacket_t statusPacket;
|
|||||||
extern InfoPacket_t infoPacket;
|
extern InfoPacket_t infoPacket;
|
||||||
extern IsolationStatusPacket_t ISO;
|
extern IsolationStatusPacket_t ISO;
|
||||||
extern volatile SC_Source_t g_sc_command_source;
|
extern volatile SC_Source_t g_sc_command_source;
|
||||||
|
|
||||||
#endif // SERIALCONTROL_H
|
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
#ifndef SMA_FILTER_H
|
#pragma once
|
||||||
#define SMA_FILTER_H
|
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
@@ -18,6 +17,3 @@ typedef struct {
|
|||||||
|
|
||||||
void SMAFilter_Init(SMAFilter_t* f);
|
void SMAFilter_Init(SMAFilter_t* f);
|
||||||
int32_t SMAFilter_Update(SMAFilter_t* f, int32_t x);
|
int32_t SMAFilter_Update(SMAFilter_t* f, int32_t x);
|
||||||
|
|
||||||
#endif // SMA_FILTER_H
|
|
||||||
|
|
||||||
|
|||||||
+1
-11
@@ -1,12 +1,4 @@
|
|||||||
/*
|
#pragma once
|
||||||
* soft_rtc.h
|
|
||||||
*
|
|
||||||
* Created on: Jul 22, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef INC_SOFT_RTC_H_
|
|
||||||
#define INC_SOFT_RTC_H_
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
|
||||||
@@ -15,5 +7,3 @@ void set_Time(uint32_t unix_time);
|
|||||||
void unix_to_bcd(uint32_t unix_time, uint8_t *time);
|
void unix_to_bcd(uint32_t unix_time, uint8_t *time);
|
||||||
void writeTimeReg(uint8_t reg_number, uint8_t value);
|
void writeTimeReg(uint8_t reg_number, uint8_t value);
|
||||||
uint8_t getTimeReg(uint8_t reg_number);
|
uint8_t getTimeReg(uint8_t reg_number);
|
||||||
|
|
||||||
#endif /* INC_SOFT_RTC_H_ */
|
|
||||||
|
|||||||
+376
-391
@@ -1,391 +1,376 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file stm32f1xx_hal_conf.h
|
|
||||||
* @brief HAL configuration file.
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
******************************************************************************
|
#ifndef __STM32F1xx_HAL_CONF_H
|
||||||
* @attention
|
#define __STM32F1xx_HAL_CONF_H
|
||||||
*
|
|
||||||
* Copyright (c) 2017 STMicroelectronics.
|
#ifdef __cplusplus
|
||||||
* All rights reserved.
|
extern "C" {
|
||||||
*
|
#endif
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
|
||||||
* in the root directory of this software component.
|
/* Exported types ------------------------------------------------------------*/
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* Exported constants --------------------------------------------------------*/
|
||||||
*
|
|
||||||
******************************************************************************
|
/* ########################## Module Selection ############################## */
|
||||||
*/
|
/**
|
||||||
/* USER CODE END Header */
|
* @brief This is the list of modules to be used in the HAL driver
|
||||||
|
*/
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __STM32F1xx_HAL_CONF_H
|
#define HAL_MODULE_ENABLED
|
||||||
#define __STM32F1xx_HAL_CONF_H
|
#define HAL_ADC_MODULE_ENABLED
|
||||||
|
/*#define HAL_CRYP_MODULE_ENABLED */
|
||||||
#ifdef __cplusplus
|
#define HAL_CAN_MODULE_ENABLED
|
||||||
extern "C" {
|
/*#define HAL_CAN_LEGACY_MODULE_ENABLED */
|
||||||
#endif
|
/*#define HAL_CEC_MODULE_ENABLED */
|
||||||
|
/*#define HAL_CORTEX_MODULE_ENABLED */
|
||||||
/* Exported types ------------------------------------------------------------*/
|
#define HAL_CRC_MODULE_ENABLED
|
||||||
/* Exported constants --------------------------------------------------------*/
|
/*#define HAL_DAC_MODULE_ENABLED */
|
||||||
|
#define HAL_DMA_MODULE_ENABLED
|
||||||
/* ########################## Module Selection ############################## */
|
/*#define HAL_ETH_MODULE_ENABLED */
|
||||||
/**
|
/*#define HAL_FLASH_MODULE_ENABLED */
|
||||||
* @brief This is the list of modules to be used in the HAL driver
|
#define HAL_GPIO_MODULE_ENABLED
|
||||||
*/
|
/*#define HAL_I2C_MODULE_ENABLED */
|
||||||
|
/*#define HAL_I2S_MODULE_ENABLED */
|
||||||
#define HAL_MODULE_ENABLED
|
/*#define HAL_IRDA_MODULE_ENABLED */
|
||||||
#define HAL_ADC_MODULE_ENABLED
|
/*#define HAL_IWDG_MODULE_ENABLED */
|
||||||
/*#define HAL_CRYP_MODULE_ENABLED */
|
/*#define HAL_NOR_MODULE_ENABLED */
|
||||||
#define HAL_CAN_MODULE_ENABLED
|
/*#define HAL_NAND_MODULE_ENABLED */
|
||||||
/*#define HAL_CAN_LEGACY_MODULE_ENABLED */
|
/*#define HAL_PCCARD_MODULE_ENABLED */
|
||||||
/*#define HAL_CEC_MODULE_ENABLED */
|
/*#define HAL_PCD_MODULE_ENABLED */
|
||||||
/*#define HAL_CORTEX_MODULE_ENABLED */
|
/*#define HAL_HCD_MODULE_ENABLED */
|
||||||
#define HAL_CRC_MODULE_ENABLED
|
/*#define HAL_PWR_MODULE_ENABLED */
|
||||||
/*#define HAL_DAC_MODULE_ENABLED */
|
/*#define HAL_RCC_MODULE_ENABLED */
|
||||||
#define HAL_DMA_MODULE_ENABLED
|
#define HAL_RTC_MODULE_ENABLED
|
||||||
/*#define HAL_ETH_MODULE_ENABLED */
|
/*#define HAL_SD_MODULE_ENABLED */
|
||||||
/*#define HAL_FLASH_MODULE_ENABLED */
|
/*#define HAL_MMC_MODULE_ENABLED */
|
||||||
#define HAL_GPIO_MODULE_ENABLED
|
/*#define HAL_SDRAM_MODULE_ENABLED */
|
||||||
/*#define HAL_I2C_MODULE_ENABLED */
|
/*#define HAL_SMARTCARD_MODULE_ENABLED */
|
||||||
/*#define HAL_I2S_MODULE_ENABLED */
|
/*#define HAL_SPI_MODULE_ENABLED */
|
||||||
/*#define HAL_IRDA_MODULE_ENABLED */
|
/*#define HAL_SRAM_MODULE_ENABLED */
|
||||||
/*#define HAL_IWDG_MODULE_ENABLED */
|
#define HAL_TIM_MODULE_ENABLED
|
||||||
/*#define HAL_NOR_MODULE_ENABLED */
|
#define HAL_UART_MODULE_ENABLED
|
||||||
/*#define HAL_NAND_MODULE_ENABLED */
|
/*#define HAL_USART_MODULE_ENABLED */
|
||||||
/*#define HAL_PCCARD_MODULE_ENABLED */
|
/*#define HAL_WWDG_MODULE_ENABLED */
|
||||||
/*#define HAL_PCD_MODULE_ENABLED */
|
|
||||||
/*#define HAL_HCD_MODULE_ENABLED */
|
#define HAL_CORTEX_MODULE_ENABLED
|
||||||
/*#define HAL_PWR_MODULE_ENABLED */
|
#define HAL_DMA_MODULE_ENABLED
|
||||||
/*#define HAL_RCC_MODULE_ENABLED */
|
#define HAL_FLASH_MODULE_ENABLED
|
||||||
#define HAL_RTC_MODULE_ENABLED
|
#define HAL_EXTI_MODULE_ENABLED
|
||||||
/*#define HAL_SD_MODULE_ENABLED */
|
#define HAL_GPIO_MODULE_ENABLED
|
||||||
/*#define HAL_MMC_MODULE_ENABLED */
|
#define HAL_PWR_MODULE_ENABLED
|
||||||
/*#define HAL_SDRAM_MODULE_ENABLED */
|
#define HAL_RCC_MODULE_ENABLED
|
||||||
/*#define HAL_SMARTCARD_MODULE_ENABLED */
|
|
||||||
/*#define HAL_SPI_MODULE_ENABLED */
|
/* ########################## Oscillator Values adaptation ####################*/
|
||||||
/*#define HAL_SRAM_MODULE_ENABLED */
|
/**
|
||||||
#define HAL_TIM_MODULE_ENABLED
|
* @brief Adjust the value of External High Speed oscillator (HSE) used in your application.
|
||||||
#define HAL_UART_MODULE_ENABLED
|
* This value is used by the RCC HAL module to compute the system frequency
|
||||||
/*#define HAL_USART_MODULE_ENABLED */
|
* (when HSE is used as system clock source, directly or through the PLL).
|
||||||
/*#define HAL_WWDG_MODULE_ENABLED */
|
*/
|
||||||
|
#if !defined (HSE_VALUE)
|
||||||
#define HAL_CORTEX_MODULE_ENABLED
|
#define HSE_VALUE 25000000U /*!< Value of the External oscillator in Hz */
|
||||||
#define HAL_DMA_MODULE_ENABLED
|
#endif /* HSE_VALUE */
|
||||||
#define HAL_FLASH_MODULE_ENABLED
|
|
||||||
#define HAL_EXTI_MODULE_ENABLED
|
#if !defined (HSE_STARTUP_TIMEOUT)
|
||||||
#define HAL_GPIO_MODULE_ENABLED
|
#define HSE_STARTUP_TIMEOUT 100U /*!< Time out for HSE start up, in ms */
|
||||||
#define HAL_PWR_MODULE_ENABLED
|
#endif /* HSE_STARTUP_TIMEOUT */
|
||||||
#define HAL_RCC_MODULE_ENABLED
|
|
||||||
|
/**
|
||||||
/* ########################## Oscillator Values adaptation ####################*/
|
* @brief Internal High Speed oscillator (HSI) value.
|
||||||
/**
|
* This value is used by the RCC HAL module to compute the system frequency
|
||||||
* @brief Adjust the value of External High Speed oscillator (HSE) used in your application.
|
* (when HSI is used as system clock source, directly or through the PLL).
|
||||||
* This value is used by the RCC HAL module to compute the system frequency
|
*/
|
||||||
* (when HSE is used as system clock source, directly or through the PLL).
|
#if !defined (HSI_VALUE)
|
||||||
*/
|
#define HSI_VALUE 8000000U /*!< Value of the Internal oscillator in Hz*/
|
||||||
#if !defined (HSE_VALUE)
|
#endif /* HSI_VALUE */
|
||||||
#define HSE_VALUE 25000000U /*!< Value of the External oscillator in Hz */
|
|
||||||
#endif /* HSE_VALUE */
|
/**
|
||||||
|
* @brief Internal Low Speed oscillator (LSI) value.
|
||||||
#if !defined (HSE_STARTUP_TIMEOUT)
|
*/
|
||||||
#define HSE_STARTUP_TIMEOUT 100U /*!< Time out for HSE start up, in ms */
|
#if !defined (LSI_VALUE)
|
||||||
#endif /* HSE_STARTUP_TIMEOUT */
|
#define LSI_VALUE 40000U /*!< LSI Typical Value in Hz */
|
||||||
|
#endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz
|
||||||
/**
|
The real value may vary depending on the variations
|
||||||
* @brief Internal High Speed oscillator (HSI) value.
|
in voltage and temperature. */
|
||||||
* This value is used by the RCC HAL module to compute the system frequency
|
|
||||||
* (when HSI is used as system clock source, directly or through the PLL).
|
/**
|
||||||
*/
|
* @brief External Low Speed oscillator (LSE) value.
|
||||||
#if !defined (HSI_VALUE)
|
* This value is used by the UART, RTC HAL module to compute the system frequency
|
||||||
#define HSI_VALUE 8000000U /*!< Value of the Internal oscillator in Hz*/
|
*/
|
||||||
#endif /* HSI_VALUE */
|
#if !defined (LSE_VALUE)
|
||||||
|
#define LSE_VALUE 32768U /*!< Value of the External oscillator in Hz*/
|
||||||
/**
|
#endif /* LSE_VALUE */
|
||||||
* @brief Internal Low Speed oscillator (LSI) value.
|
|
||||||
*/
|
#if !defined (LSE_STARTUP_TIMEOUT)
|
||||||
#if !defined (LSI_VALUE)
|
#define LSE_STARTUP_TIMEOUT 5000U /*!< Time out for LSE start up, in ms */
|
||||||
#define LSI_VALUE 40000U /*!< LSI Typical Value in Hz */
|
#endif /* LSE_STARTUP_TIMEOUT */
|
||||||
#endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz
|
|
||||||
The real value may vary depending on the variations
|
/* Tip: To avoid modifying this file each time you need to use different HSE,
|
||||||
in voltage and temperature. */
|
=== you can define the HSE value in your toolchain compiler preprocessor. */
|
||||||
|
|
||||||
/**
|
/* ########################### System Configuration ######################### */
|
||||||
* @brief External Low Speed oscillator (LSE) value.
|
/**
|
||||||
* This value is used by the UART, RTC HAL module to compute the system frequency
|
* @brief This is the HAL system configuration section
|
||||||
*/
|
*/
|
||||||
#if !defined (LSE_VALUE)
|
#define VDD_VALUE 3300U /*!< Value of VDD in mv */
|
||||||
#define LSE_VALUE 32768U /*!< Value of the External oscillator in Hz*/
|
#define TICK_INT_PRIORITY 15U /*!< tick interrupt priority (lowest by default) */
|
||||||
#endif /* LSE_VALUE */
|
#define USE_RTOS 0U
|
||||||
|
#define PREFETCH_ENABLE 1U
|
||||||
#if !defined (LSE_STARTUP_TIMEOUT)
|
|
||||||
#define LSE_STARTUP_TIMEOUT 5000U /*!< Time out for LSE start up, in ms */
|
#define USE_HAL_ADC_REGISTER_CALLBACKS 0U /* ADC register callback disabled */
|
||||||
#endif /* LSE_STARTUP_TIMEOUT */
|
#define USE_HAL_CAN_REGISTER_CALLBACKS 0U /* CAN register callback disabled */
|
||||||
|
#define USE_HAL_CEC_REGISTER_CALLBACKS 0U /* CEC register callback disabled */
|
||||||
/* Tip: To avoid modifying this file each time you need to use different HSE,
|
#define USE_HAL_DAC_REGISTER_CALLBACKS 0U /* DAC register callback disabled */
|
||||||
=== you can define the HSE value in your toolchain compiler preprocessor. */
|
#define USE_HAL_ETH_REGISTER_CALLBACKS 0U /* ETH register callback disabled */
|
||||||
|
#define USE_HAL_HCD_REGISTER_CALLBACKS 0U /* HCD register callback disabled */
|
||||||
/* ########################### System Configuration ######################### */
|
#define USE_HAL_I2C_REGISTER_CALLBACKS 0U /* I2C register callback disabled */
|
||||||
/**
|
#define USE_HAL_I2S_REGISTER_CALLBACKS 0U /* I2S register callback disabled */
|
||||||
* @brief This is the HAL system configuration section
|
#define USE_HAL_MMC_REGISTER_CALLBACKS 0U /* MMC register callback disabled */
|
||||||
*/
|
#define USE_HAL_NAND_REGISTER_CALLBACKS 0U /* NAND register callback disabled */
|
||||||
#define VDD_VALUE 3300U /*!< Value of VDD in mv */
|
#define USE_HAL_NOR_REGISTER_CALLBACKS 0U /* NOR register callback disabled */
|
||||||
#define TICK_INT_PRIORITY 15U /*!< tick interrupt priority (lowest by default) */
|
#define USE_HAL_PCCARD_REGISTER_CALLBACKS 0U /* PCCARD register callback disabled */
|
||||||
#define USE_RTOS 0U
|
#define USE_HAL_PCD_REGISTER_CALLBACKS 0U /* PCD register callback disabled */
|
||||||
#define PREFETCH_ENABLE 1U
|
#define USE_HAL_RTC_REGISTER_CALLBACKS 0U /* RTC register callback disabled */
|
||||||
|
#define USE_HAL_SD_REGISTER_CALLBACKS 0U /* SD register callback disabled */
|
||||||
#define USE_HAL_ADC_REGISTER_CALLBACKS 0U /* ADC register callback disabled */
|
#define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U /* SMARTCARD register callback disabled */
|
||||||
#define USE_HAL_CAN_REGISTER_CALLBACKS 0U /* CAN register callback disabled */
|
#define USE_HAL_IRDA_REGISTER_CALLBACKS 0U /* IRDA register callback disabled */
|
||||||
#define USE_HAL_CEC_REGISTER_CALLBACKS 0U /* CEC register callback disabled */
|
#define USE_HAL_SRAM_REGISTER_CALLBACKS 0U /* SRAM register callback disabled */
|
||||||
#define USE_HAL_DAC_REGISTER_CALLBACKS 0U /* DAC register callback disabled */
|
#define USE_HAL_SPI_REGISTER_CALLBACKS 0U /* SPI register callback disabled */
|
||||||
#define USE_HAL_ETH_REGISTER_CALLBACKS 0U /* ETH register callback disabled */
|
#define USE_HAL_TIM_REGISTER_CALLBACKS 0U /* TIM register callback disabled */
|
||||||
#define USE_HAL_HCD_REGISTER_CALLBACKS 0U /* HCD register callback disabled */
|
#define USE_HAL_UART_REGISTER_CALLBACKS 0U /* UART register callback disabled */
|
||||||
#define USE_HAL_I2C_REGISTER_CALLBACKS 0U /* I2C register callback disabled */
|
#define USE_HAL_USART_REGISTER_CALLBACKS 0U /* USART register callback disabled */
|
||||||
#define USE_HAL_I2S_REGISTER_CALLBACKS 0U /* I2S register callback disabled */
|
#define USE_HAL_WWDG_REGISTER_CALLBACKS 0U /* WWDG register callback disabled */
|
||||||
#define USE_HAL_MMC_REGISTER_CALLBACKS 0U /* MMC register callback disabled */
|
|
||||||
#define USE_HAL_NAND_REGISTER_CALLBACKS 0U /* NAND register callback disabled */
|
/* ########################## Assert Selection ############################## */
|
||||||
#define USE_HAL_NOR_REGISTER_CALLBACKS 0U /* NOR register callback disabled */
|
/**
|
||||||
#define USE_HAL_PCCARD_REGISTER_CALLBACKS 0U /* PCCARD register callback disabled */
|
* @brief Uncomment the line below to expanse the "assert_param" macro in the
|
||||||
#define USE_HAL_PCD_REGISTER_CALLBACKS 0U /* PCD register callback disabled */
|
* HAL drivers code
|
||||||
#define USE_HAL_RTC_REGISTER_CALLBACKS 0U /* RTC register callback disabled */
|
*/
|
||||||
#define USE_HAL_SD_REGISTER_CALLBACKS 0U /* SD register callback disabled */
|
/* #define USE_FULL_ASSERT 1U */
|
||||||
#define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U /* SMARTCARD register callback disabled */
|
|
||||||
#define USE_HAL_IRDA_REGISTER_CALLBACKS 0U /* IRDA register callback disabled */
|
/* ################## Ethernet peripheral configuration ##################### */
|
||||||
#define USE_HAL_SRAM_REGISTER_CALLBACKS 0U /* SRAM register callback disabled */
|
|
||||||
#define USE_HAL_SPI_REGISTER_CALLBACKS 0U /* SPI register callback disabled */
|
/* Section 1 : Ethernet peripheral configuration */
|
||||||
#define USE_HAL_TIM_REGISTER_CALLBACKS 0U /* TIM register callback disabled */
|
|
||||||
#define USE_HAL_UART_REGISTER_CALLBACKS 0U /* UART register callback disabled */
|
/* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */
|
||||||
#define USE_HAL_USART_REGISTER_CALLBACKS 0U /* USART register callback disabled */
|
#define MAC_ADDR0 2U
|
||||||
#define USE_HAL_WWDG_REGISTER_CALLBACKS 0U /* WWDG register callback disabled */
|
#define MAC_ADDR1 0U
|
||||||
|
#define MAC_ADDR2 0U
|
||||||
/* ########################## Assert Selection ############################## */
|
#define MAC_ADDR3 0U
|
||||||
/**
|
#define MAC_ADDR4 0U
|
||||||
* @brief Uncomment the line below to expanse the "assert_param" macro in the
|
#define MAC_ADDR5 0U
|
||||||
* HAL drivers code
|
|
||||||
*/
|
/* Definition of the Ethernet driver buffers size and count */
|
||||||
/* #define USE_FULL_ASSERT 1U */
|
#define ETH_RX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for receive */
|
||||||
|
#define ETH_TX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for transmit */
|
||||||
/* ################## Ethernet peripheral configuration ##################### */
|
#define ETH_RXBUFNB 8U /* 4 Rx buffers of size ETH_RX_BUF_SIZE */
|
||||||
|
#define ETH_TXBUFNB 4U /* 4 Tx buffers of size ETH_TX_BUF_SIZE */
|
||||||
/* Section 1 : Ethernet peripheral configuration */
|
|
||||||
|
/* Section 2: PHY configuration section */
|
||||||
/* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */
|
|
||||||
#define MAC_ADDR0 2U
|
/* DP83848_PHY_ADDRESS Address*/
|
||||||
#define MAC_ADDR1 0U
|
#define DP83848_PHY_ADDRESS 0x01U
|
||||||
#define MAC_ADDR2 0U
|
/* PHY Reset delay these values are based on a 1 ms Systick interrupt*/
|
||||||
#define MAC_ADDR3 0U
|
#define PHY_RESET_DELAY 0x000000FFU
|
||||||
#define MAC_ADDR4 0U
|
/* PHY Configuration delay */
|
||||||
#define MAC_ADDR5 0U
|
#define PHY_CONFIG_DELAY 0x00000FFFU
|
||||||
|
|
||||||
/* Definition of the Ethernet driver buffers size and count */
|
#define PHY_READ_TO 0x0000FFFFU
|
||||||
#define ETH_RX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for receive */
|
#define PHY_WRITE_TO 0x0000FFFFU
|
||||||
#define ETH_TX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for transmit */
|
|
||||||
#define ETH_RXBUFNB 8U /* 4 Rx buffers of size ETH_RX_BUF_SIZE */
|
/* Section 3: Common PHY Registers */
|
||||||
#define ETH_TXBUFNB 4U /* 4 Tx buffers of size ETH_TX_BUF_SIZE */
|
|
||||||
|
#define PHY_BCR ((uint16_t)0x00) /*!< Transceiver Basic Control Register */
|
||||||
/* Section 2: PHY configuration section */
|
#define PHY_BSR ((uint16_t)0x01) /*!< Transceiver Basic Status Register */
|
||||||
|
|
||||||
/* DP83848_PHY_ADDRESS Address*/
|
#define PHY_RESET ((uint16_t)0x8000) /*!< PHY Reset */
|
||||||
#define DP83848_PHY_ADDRESS 0x01U
|
#define PHY_LOOPBACK ((uint16_t)0x4000) /*!< Select loop-back mode */
|
||||||
/* PHY Reset delay these values are based on a 1 ms Systick interrupt*/
|
#define PHY_FULLDUPLEX_100M ((uint16_t)0x2100) /*!< Set the full-duplex mode at 100 Mb/s */
|
||||||
#define PHY_RESET_DELAY 0x000000FFU
|
#define PHY_HALFDUPLEX_100M ((uint16_t)0x2000) /*!< Set the half-duplex mode at 100 Mb/s */
|
||||||
/* PHY Configuration delay */
|
#define PHY_FULLDUPLEX_10M ((uint16_t)0x0100) /*!< Set the full-duplex mode at 10 Mb/s */
|
||||||
#define PHY_CONFIG_DELAY 0x00000FFFU
|
#define PHY_HALFDUPLEX_10M ((uint16_t)0x0000) /*!< Set the half-duplex mode at 10 Mb/s */
|
||||||
|
#define PHY_AUTONEGOTIATION ((uint16_t)0x1000) /*!< Enable auto-negotiation function */
|
||||||
#define PHY_READ_TO 0x0000FFFFU
|
#define PHY_RESTART_AUTONEGOTIATION ((uint16_t)0x0200) /*!< Restart auto-negotiation function */
|
||||||
#define PHY_WRITE_TO 0x0000FFFFU
|
#define PHY_POWERDOWN ((uint16_t)0x0800) /*!< Select the power down mode */
|
||||||
|
#define PHY_ISOLATE ((uint16_t)0x0400) /*!< Isolate PHY from MII */
|
||||||
/* Section 3: Common PHY Registers */
|
|
||||||
|
#define PHY_AUTONEGO_COMPLETE ((uint16_t)0x0020) /*!< Auto-Negotiation process completed */
|
||||||
#define PHY_BCR ((uint16_t)0x00) /*!< Transceiver Basic Control Register */
|
#define PHY_LINKED_STATUS ((uint16_t)0x0004) /*!< Valid link established */
|
||||||
#define PHY_BSR ((uint16_t)0x01) /*!< Transceiver Basic Status Register */
|
#define PHY_JABBER_DETECTION ((uint16_t)0x0002) /*!< Jabber condition detected */
|
||||||
|
|
||||||
#define PHY_RESET ((uint16_t)0x8000) /*!< PHY Reset */
|
/* Section 4: Extended PHY Registers */
|
||||||
#define PHY_LOOPBACK ((uint16_t)0x4000) /*!< Select loop-back mode */
|
#define PHY_SR ((uint16_t)0x10U) /*!< PHY status register Offset */
|
||||||
#define PHY_FULLDUPLEX_100M ((uint16_t)0x2100) /*!< Set the full-duplex mode at 100 Mb/s */
|
|
||||||
#define PHY_HALFDUPLEX_100M ((uint16_t)0x2000) /*!< Set the half-duplex mode at 100 Mb/s */
|
#define PHY_SPEED_STATUS ((uint16_t)0x0002U) /*!< PHY Speed mask */
|
||||||
#define PHY_FULLDUPLEX_10M ((uint16_t)0x0100) /*!< Set the full-duplex mode at 10 Mb/s */
|
#define PHY_DUPLEX_STATUS ((uint16_t)0x0004U) /*!< PHY Duplex mask */
|
||||||
#define PHY_HALFDUPLEX_10M ((uint16_t)0x0000) /*!< Set the half-duplex mode at 10 Mb/s */
|
|
||||||
#define PHY_AUTONEGOTIATION ((uint16_t)0x1000) /*!< Enable auto-negotiation function */
|
/* ################## SPI peripheral configuration ########################## */
|
||||||
#define PHY_RESTART_AUTONEGOTIATION ((uint16_t)0x0200) /*!< Restart auto-negotiation function */
|
|
||||||
#define PHY_POWERDOWN ((uint16_t)0x0800) /*!< Select the power down mode */
|
/* CRC FEATURE: Use to activate CRC feature inside HAL SPI Driver
|
||||||
#define PHY_ISOLATE ((uint16_t)0x0400) /*!< Isolate PHY from MII */
|
* Activated: CRC code is present inside driver
|
||||||
|
* Deactivated: CRC code cleaned from driver
|
||||||
#define PHY_AUTONEGO_COMPLETE ((uint16_t)0x0020) /*!< Auto-Negotiation process completed */
|
*/
|
||||||
#define PHY_LINKED_STATUS ((uint16_t)0x0004) /*!< Valid link established */
|
|
||||||
#define PHY_JABBER_DETECTION ((uint16_t)0x0002) /*!< Jabber condition detected */
|
#define USE_SPI_CRC 0U
|
||||||
|
|
||||||
/* Section 4: Extended PHY Registers */
|
/* Includes ------------------------------------------------------------------*/
|
||||||
#define PHY_SR ((uint16_t)0x10U) /*!< PHY status register Offset */
|
/**
|
||||||
|
* @brief Include module's header file
|
||||||
#define PHY_SPEED_STATUS ((uint16_t)0x0002U) /*!< PHY Speed mask */
|
*/
|
||||||
#define PHY_DUPLEX_STATUS ((uint16_t)0x0004U) /*!< PHY Duplex mask */
|
|
||||||
|
#ifdef HAL_RCC_MODULE_ENABLED
|
||||||
/* ################## SPI peripheral configuration ########################## */
|
#include "stm32f1xx_hal_rcc.h"
|
||||||
|
#endif /* HAL_RCC_MODULE_ENABLED */
|
||||||
/* CRC FEATURE: Use to activate CRC feature inside HAL SPI Driver
|
|
||||||
* Activated: CRC code is present inside driver
|
#ifdef HAL_GPIO_MODULE_ENABLED
|
||||||
* Deactivated: CRC code cleaned from driver
|
#include "stm32f1xx_hal_gpio.h"
|
||||||
*/
|
#endif /* HAL_GPIO_MODULE_ENABLED */
|
||||||
|
|
||||||
#define USE_SPI_CRC 0U
|
#ifdef HAL_EXTI_MODULE_ENABLED
|
||||||
|
#include "stm32f1xx_hal_exti.h"
|
||||||
/* Includes ------------------------------------------------------------------*/
|
#endif /* HAL_EXTI_MODULE_ENABLED */
|
||||||
/**
|
|
||||||
* @brief Include module's header file
|
#ifdef HAL_DMA_MODULE_ENABLED
|
||||||
*/
|
#include "stm32f1xx_hal_dma.h"
|
||||||
|
#endif /* HAL_DMA_MODULE_ENABLED */
|
||||||
#ifdef HAL_RCC_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_rcc.h"
|
#ifdef HAL_ETH_MODULE_ENABLED
|
||||||
#endif /* HAL_RCC_MODULE_ENABLED */
|
#include "stm32f1xx_hal_eth.h"
|
||||||
|
#endif /* HAL_ETH_MODULE_ENABLED */
|
||||||
#ifdef HAL_GPIO_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_gpio.h"
|
#ifdef HAL_CAN_MODULE_ENABLED
|
||||||
#endif /* HAL_GPIO_MODULE_ENABLED */
|
#include "stm32f1xx_hal_can.h"
|
||||||
|
#endif /* HAL_CAN_MODULE_ENABLED */
|
||||||
#ifdef HAL_EXTI_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_exti.h"
|
#ifdef HAL_CAN_LEGACY_MODULE_ENABLED
|
||||||
#endif /* HAL_EXTI_MODULE_ENABLED */
|
#include "Legacy/stm32f1xx_hal_can_legacy.h"
|
||||||
|
#endif /* HAL_CAN_LEGACY_MODULE_ENABLED */
|
||||||
#ifdef HAL_DMA_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_dma.h"
|
#ifdef HAL_CEC_MODULE_ENABLED
|
||||||
#endif /* HAL_DMA_MODULE_ENABLED */
|
#include "stm32f1xx_hal_cec.h"
|
||||||
|
#endif /* HAL_CEC_MODULE_ENABLED */
|
||||||
#ifdef HAL_ETH_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_eth.h"
|
#ifdef HAL_CORTEX_MODULE_ENABLED
|
||||||
#endif /* HAL_ETH_MODULE_ENABLED */
|
#include "stm32f1xx_hal_cortex.h"
|
||||||
|
#endif /* HAL_CORTEX_MODULE_ENABLED */
|
||||||
#ifdef HAL_CAN_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_can.h"
|
#ifdef HAL_ADC_MODULE_ENABLED
|
||||||
#endif /* HAL_CAN_MODULE_ENABLED */
|
#include "stm32f1xx_hal_adc.h"
|
||||||
|
#endif /* HAL_ADC_MODULE_ENABLED */
|
||||||
#ifdef HAL_CAN_LEGACY_MODULE_ENABLED
|
|
||||||
#include "Legacy/stm32f1xx_hal_can_legacy.h"
|
#ifdef HAL_CRC_MODULE_ENABLED
|
||||||
#endif /* HAL_CAN_LEGACY_MODULE_ENABLED */
|
#include "stm32f1xx_hal_crc.h"
|
||||||
|
#endif /* HAL_CRC_MODULE_ENABLED */
|
||||||
#ifdef HAL_CEC_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_cec.h"
|
#ifdef HAL_DAC_MODULE_ENABLED
|
||||||
#endif /* HAL_CEC_MODULE_ENABLED */
|
#include "stm32f1xx_hal_dac.h"
|
||||||
|
#endif /* HAL_DAC_MODULE_ENABLED */
|
||||||
#ifdef HAL_CORTEX_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_cortex.h"
|
#ifdef HAL_FLASH_MODULE_ENABLED
|
||||||
#endif /* HAL_CORTEX_MODULE_ENABLED */
|
#include "stm32f1xx_hal_flash.h"
|
||||||
|
#endif /* HAL_FLASH_MODULE_ENABLED */
|
||||||
#ifdef HAL_ADC_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_adc.h"
|
#ifdef HAL_SRAM_MODULE_ENABLED
|
||||||
#endif /* HAL_ADC_MODULE_ENABLED */
|
#include "stm32f1xx_hal_sram.h"
|
||||||
|
#endif /* HAL_SRAM_MODULE_ENABLED */
|
||||||
#ifdef HAL_CRC_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_crc.h"
|
#ifdef HAL_NOR_MODULE_ENABLED
|
||||||
#endif /* HAL_CRC_MODULE_ENABLED */
|
#include "stm32f1xx_hal_nor.h"
|
||||||
|
#endif /* HAL_NOR_MODULE_ENABLED */
|
||||||
#ifdef HAL_DAC_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_dac.h"
|
#ifdef HAL_I2C_MODULE_ENABLED
|
||||||
#endif /* HAL_DAC_MODULE_ENABLED */
|
#include "stm32f1xx_hal_i2c.h"
|
||||||
|
#endif /* HAL_I2C_MODULE_ENABLED */
|
||||||
#ifdef HAL_FLASH_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_flash.h"
|
#ifdef HAL_I2S_MODULE_ENABLED
|
||||||
#endif /* HAL_FLASH_MODULE_ENABLED */
|
#include "stm32f1xx_hal_i2s.h"
|
||||||
|
#endif /* HAL_I2S_MODULE_ENABLED */
|
||||||
#ifdef HAL_SRAM_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_sram.h"
|
#ifdef HAL_IWDG_MODULE_ENABLED
|
||||||
#endif /* HAL_SRAM_MODULE_ENABLED */
|
#include "stm32f1xx_hal_iwdg.h"
|
||||||
|
#endif /* HAL_IWDG_MODULE_ENABLED */
|
||||||
#ifdef HAL_NOR_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_nor.h"
|
#ifdef HAL_PWR_MODULE_ENABLED
|
||||||
#endif /* HAL_NOR_MODULE_ENABLED */
|
#include "stm32f1xx_hal_pwr.h"
|
||||||
|
#endif /* HAL_PWR_MODULE_ENABLED */
|
||||||
#ifdef HAL_I2C_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_i2c.h"
|
#ifdef HAL_RTC_MODULE_ENABLED
|
||||||
#endif /* HAL_I2C_MODULE_ENABLED */
|
#include "stm32f1xx_hal_rtc.h"
|
||||||
|
#endif /* HAL_RTC_MODULE_ENABLED */
|
||||||
#ifdef HAL_I2S_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_i2s.h"
|
#ifdef HAL_PCCARD_MODULE_ENABLED
|
||||||
#endif /* HAL_I2S_MODULE_ENABLED */
|
#include "stm32f1xx_hal_pccard.h"
|
||||||
|
#endif /* HAL_PCCARD_MODULE_ENABLED */
|
||||||
#ifdef HAL_IWDG_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_iwdg.h"
|
#ifdef HAL_SD_MODULE_ENABLED
|
||||||
#endif /* HAL_IWDG_MODULE_ENABLED */
|
#include "stm32f1xx_hal_sd.h"
|
||||||
|
#endif /* HAL_SD_MODULE_ENABLED */
|
||||||
#ifdef HAL_PWR_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_pwr.h"
|
#ifdef HAL_NAND_MODULE_ENABLED
|
||||||
#endif /* HAL_PWR_MODULE_ENABLED */
|
#include "stm32f1xx_hal_nand.h"
|
||||||
|
#endif /* HAL_NAND_MODULE_ENABLED */
|
||||||
#ifdef HAL_RTC_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_rtc.h"
|
#ifdef HAL_SPI_MODULE_ENABLED
|
||||||
#endif /* HAL_RTC_MODULE_ENABLED */
|
#include "stm32f1xx_hal_spi.h"
|
||||||
|
#endif /* HAL_SPI_MODULE_ENABLED */
|
||||||
#ifdef HAL_PCCARD_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_pccard.h"
|
#ifdef HAL_TIM_MODULE_ENABLED
|
||||||
#endif /* HAL_PCCARD_MODULE_ENABLED */
|
#include "stm32f1xx_hal_tim.h"
|
||||||
|
#endif /* HAL_TIM_MODULE_ENABLED */
|
||||||
#ifdef HAL_SD_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_sd.h"
|
#ifdef HAL_UART_MODULE_ENABLED
|
||||||
#endif /* HAL_SD_MODULE_ENABLED */
|
#include "stm32f1xx_hal_uart.h"
|
||||||
|
#endif /* HAL_UART_MODULE_ENABLED */
|
||||||
#ifdef HAL_NAND_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_nand.h"
|
#ifdef HAL_USART_MODULE_ENABLED
|
||||||
#endif /* HAL_NAND_MODULE_ENABLED */
|
#include "stm32f1xx_hal_usart.h"
|
||||||
|
#endif /* HAL_USART_MODULE_ENABLED */
|
||||||
#ifdef HAL_SPI_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_spi.h"
|
#ifdef HAL_IRDA_MODULE_ENABLED
|
||||||
#endif /* HAL_SPI_MODULE_ENABLED */
|
#include "stm32f1xx_hal_irda.h"
|
||||||
|
#endif /* HAL_IRDA_MODULE_ENABLED */
|
||||||
#ifdef HAL_TIM_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_tim.h"
|
#ifdef HAL_SMARTCARD_MODULE_ENABLED
|
||||||
#endif /* HAL_TIM_MODULE_ENABLED */
|
#include "stm32f1xx_hal_smartcard.h"
|
||||||
|
#endif /* HAL_SMARTCARD_MODULE_ENABLED */
|
||||||
#ifdef HAL_UART_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_uart.h"
|
#ifdef HAL_WWDG_MODULE_ENABLED
|
||||||
#endif /* HAL_UART_MODULE_ENABLED */
|
#include "stm32f1xx_hal_wwdg.h"
|
||||||
|
#endif /* HAL_WWDG_MODULE_ENABLED */
|
||||||
#ifdef HAL_USART_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_usart.h"
|
#ifdef HAL_PCD_MODULE_ENABLED
|
||||||
#endif /* HAL_USART_MODULE_ENABLED */
|
#include "stm32f1xx_hal_pcd.h"
|
||||||
|
#endif /* HAL_PCD_MODULE_ENABLED */
|
||||||
#ifdef HAL_IRDA_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_irda.h"
|
#ifdef HAL_HCD_MODULE_ENABLED
|
||||||
#endif /* HAL_IRDA_MODULE_ENABLED */
|
#include "stm32f1xx_hal_hcd.h"
|
||||||
|
#endif /* HAL_HCD_MODULE_ENABLED */
|
||||||
#ifdef HAL_SMARTCARD_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_smartcard.h"
|
#ifdef HAL_MMC_MODULE_ENABLED
|
||||||
#endif /* HAL_SMARTCARD_MODULE_ENABLED */
|
#include "stm32f1xx_hal_mmc.h"
|
||||||
|
#endif /* HAL_MMC_MODULE_ENABLED */
|
||||||
#ifdef HAL_WWDG_MODULE_ENABLED
|
|
||||||
#include "stm32f1xx_hal_wwdg.h"
|
/* Exported macro ------------------------------------------------------------*/
|
||||||
#endif /* HAL_WWDG_MODULE_ENABLED */
|
#ifdef USE_FULL_ASSERT
|
||||||
|
/**
|
||||||
#ifdef HAL_PCD_MODULE_ENABLED
|
* @brief The assert_param macro is used for function's parameters check.
|
||||||
#include "stm32f1xx_hal_pcd.h"
|
* @param expr If expr is false, it calls assert_failed function
|
||||||
#endif /* HAL_PCD_MODULE_ENABLED */
|
* which reports the name of the source file and the source
|
||||||
|
* line number of the call that failed.
|
||||||
#ifdef HAL_HCD_MODULE_ENABLED
|
* If expr is true, it returns no value.
|
||||||
#include "stm32f1xx_hal_hcd.h"
|
* @retval None
|
||||||
#endif /* HAL_HCD_MODULE_ENABLED */
|
*/
|
||||||
|
#define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__))
|
||||||
#ifdef HAL_MMC_MODULE_ENABLED
|
/* Exported functions ------------------------------------------------------- */
|
||||||
#include "stm32f1xx_hal_mmc.h"
|
void assert_failed(uint8_t* file, uint32_t line);
|
||||||
#endif /* HAL_MMC_MODULE_ENABLED */
|
#else
|
||||||
|
#define assert_param(expr) ((void)0U)
|
||||||
/* Exported macro ------------------------------------------------------------*/
|
#endif /* USE_FULL_ASSERT */
|
||||||
#ifdef USE_FULL_ASSERT
|
|
||||||
/**
|
#ifdef __cplusplus
|
||||||
* @brief The assert_param macro is used for function's parameters check.
|
}
|
||||||
* @param expr If expr is false, it calls assert_failed function
|
#endif
|
||||||
* which reports the name of the source file and the source
|
|
||||||
* line number of the call that failed.
|
#endif /* __STM32F1xx_HAL_CONF_H */
|
||||||
* If expr is true, it returns no value.
|
|
||||||
* @retval None
|
|
||||||
*/
|
|
||||||
#define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__))
|
|
||||||
/* Exported functions ------------------------------------------------------- */
|
|
||||||
void assert_failed(uint8_t* file, uint32_t line);
|
|
||||||
#else
|
|
||||||
#define assert_param(expr) ((void)0U)
|
|
||||||
#endif /* USE_FULL_ASSERT */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __STM32F1xx_HAL_CONF_H */
|
|
||||||
|
|
||||||
|
|||||||
+65
-80
@@ -1,80 +1,65 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file stm32f1xx_it.h
|
|
||||||
* @brief This file contains the headers of the interrupt handlers.
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
******************************************************************************
|
#ifndef __STM32F1xx_IT_H
|
||||||
* @attention
|
#define __STM32F1xx_IT_H
|
||||||
*
|
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
#ifdef __cplusplus
|
||||||
* All rights reserved.
|
extern "C" {
|
||||||
*
|
#endif
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
|
||||||
* in the root directory of this software component.
|
/* Private includes ----------------------------------------------------------*/
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN Includes */
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE END Includes */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
/* Exported types ------------------------------------------------------------*/
|
||||||
|
/* USER CODE BEGIN ET */
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __STM32F1xx_IT_H
|
/* USER CODE END ET */
|
||||||
#define __STM32F1xx_IT_H
|
|
||||||
|
/* Exported constants --------------------------------------------------------*/
|
||||||
#ifdef __cplusplus
|
/* USER CODE BEGIN EC */
|
||||||
extern "C" {
|
|
||||||
#endif
|
/* USER CODE END EC */
|
||||||
|
|
||||||
/* Private includes ----------------------------------------------------------*/
|
/* Exported macro ------------------------------------------------------------*/
|
||||||
/* USER CODE BEGIN Includes */
|
/* USER CODE BEGIN EM */
|
||||||
|
|
||||||
/* USER CODE END Includes */
|
/* USER CODE END EM */
|
||||||
|
|
||||||
/* Exported types ------------------------------------------------------------*/
|
/* Exported functions prototypes ---------------------------------------------*/
|
||||||
/* USER CODE BEGIN ET */
|
void NMI_Handler(void);
|
||||||
|
void HardFault_Handler(void);
|
||||||
/* USER CODE END ET */
|
void MemManage_Handler(void);
|
||||||
|
void BusFault_Handler(void);
|
||||||
/* Exported constants --------------------------------------------------------*/
|
void UsageFault_Handler(void);
|
||||||
/* USER CODE BEGIN EC */
|
void SVC_Handler(void);
|
||||||
|
void DebugMon_Handler(void);
|
||||||
/* USER CODE END EC */
|
void PendSV_Handler(void);
|
||||||
|
void SysTick_Handler(void);
|
||||||
/* Exported macro ------------------------------------------------------------*/
|
void DMA1_Channel1_IRQHandler(void);
|
||||||
/* USER CODE BEGIN EM */
|
void DMA1_Channel2_IRQHandler(void);
|
||||||
|
void DMA1_Channel3_IRQHandler(void);
|
||||||
/* USER CODE END EM */
|
void DMA1_Channel6_IRQHandler(void);
|
||||||
|
void DMA1_Channel7_IRQHandler(void);
|
||||||
/* Exported functions prototypes ---------------------------------------------*/
|
void ADC1_2_IRQHandler(void);
|
||||||
void NMI_Handler(void);
|
void CAN1_RX0_IRQHandler(void);
|
||||||
void HardFault_Handler(void);
|
void TIM3_IRQHandler(void);
|
||||||
void MemManage_Handler(void);
|
void USART1_IRQHandler(void);
|
||||||
void BusFault_Handler(void);
|
void USART2_IRQHandler(void);
|
||||||
void UsageFault_Handler(void);
|
void USART3_IRQHandler(void);
|
||||||
void SVC_Handler(void);
|
void UART5_IRQHandler(void);
|
||||||
void DebugMon_Handler(void);
|
void CAN2_TX_IRQHandler(void);
|
||||||
void PendSV_Handler(void);
|
void CAN2_RX1_IRQHandler(void);
|
||||||
void SysTick_Handler(void);
|
/* USER CODE BEGIN EFP */
|
||||||
void DMA1_Channel1_IRQHandler(void);
|
|
||||||
void DMA1_Channel2_IRQHandler(void);
|
/* USER CODE END EFP */
|
||||||
void DMA1_Channel3_IRQHandler(void);
|
|
||||||
void DMA1_Channel6_IRQHandler(void);
|
#ifdef __cplusplus
|
||||||
void DMA1_Channel7_IRQHandler(void);
|
}
|
||||||
void ADC1_2_IRQHandler(void);
|
#endif
|
||||||
void CAN1_RX0_IRQHandler(void);
|
|
||||||
void TIM3_IRQHandler(void);
|
#endif /* __STM32F1xx_IT_H */
|
||||||
void USART1_IRQHandler(void);
|
|
||||||
void USART2_IRQHandler(void);
|
|
||||||
void USART3_IRQHandler(void);
|
|
||||||
void UART5_IRQHandler(void);
|
|
||||||
void CAN2_TX_IRQHandler(void);
|
|
||||||
void CAN2_RX1_IRQHandler(void);
|
|
||||||
/* USER CODE BEGIN EFP */
|
|
||||||
|
|
||||||
/* USER CODE END EFP */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __STM32F1xx_IT_H */
|
|
||||||
|
|||||||
+41
-57
@@ -1,57 +1,41 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file tim.h
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* @brief This file contains all the function prototypes for
|
#ifndef __TIM_H__
|
||||||
* the tim.c file
|
#define __TIM_H__
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
#ifdef __cplusplus
|
||||||
*
|
extern "C" {
|
||||||
* Copyright (c) 2025 STMicroelectronics.
|
#endif
|
||||||
* All rights reserved.
|
|
||||||
*
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#include "main.h"
|
||||||
* in the root directory of this software component.
|
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN Includes */
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE END Includes */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
extern TIM_HandleTypeDef htim3;
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __TIM_H__
|
extern TIM_HandleTypeDef htim4;
|
||||||
#define __TIM_H__
|
|
||||||
|
/* USER CODE BEGIN Private defines */
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
/* USER CODE END Private defines */
|
||||||
#endif
|
|
||||||
|
void MX_TIM3_Init(void);
|
||||||
/* Includes ------------------------------------------------------------------*/
|
void MX_TIM4_Init(void);
|
||||||
#include "main.h"
|
|
||||||
|
void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);
|
||||||
/* USER CODE BEGIN Includes */
|
|
||||||
|
/* USER CODE BEGIN Prototypes */
|
||||||
/* USER CODE END Includes */
|
|
||||||
|
/* USER CODE END Prototypes */
|
||||||
extern TIM_HandleTypeDef htim3;
|
|
||||||
|
#ifdef __cplusplus
|
||||||
extern TIM_HandleTypeDef htim4;
|
}
|
||||||
|
#endif
|
||||||
/* USER CODE BEGIN Private defines */
|
|
||||||
|
#endif /* __TIM_H__ */
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
void MX_TIM3_Init(void);
|
|
||||||
void MX_TIM4_Init(void);
|
|
||||||
|
|
||||||
void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Prototypes */
|
|
||||||
|
|
||||||
/* USER CODE END Prototypes */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __TIM_H__ */
|
|
||||||
|
|
||||||
|
|||||||
+45
-61
@@ -1,61 +1,45 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file usart.h
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
* @brief This file contains all the function prototypes for
|
#ifndef __USART_H__
|
||||||
* the usart.c file
|
#define __USART_H__
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
#ifdef __cplusplus
|
||||||
*
|
extern "C" {
|
||||||
* Copyright (c) 2025 STMicroelectronics.
|
#endif
|
||||||
* All rights reserved.
|
|
||||||
*
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#include "main.h"
|
||||||
* in the root directory of this software component.
|
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN Includes */
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE END Includes */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
extern UART_HandleTypeDef huart5;
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
||||||
#ifndef __USART_H__
|
extern UART_HandleTypeDef huart1;
|
||||||
#define __USART_H__
|
|
||||||
|
extern UART_HandleTypeDef huart2;
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
extern UART_HandleTypeDef huart3;
|
||||||
#endif
|
|
||||||
|
/* USER CODE BEGIN Private defines */
|
||||||
/* Includes ------------------------------------------------------------------*/
|
|
||||||
#include "main.h"
|
/* USER CODE END Private defines */
|
||||||
|
|
||||||
/* USER CODE BEGIN Includes */
|
void MX_UART5_Init(void);
|
||||||
|
void MX_USART1_UART_Init(void);
|
||||||
/* USER CODE END Includes */
|
void MX_USART2_UART_Init(void);
|
||||||
|
void MX_USART3_UART_Init(void);
|
||||||
extern UART_HandleTypeDef huart5;
|
|
||||||
|
/* USER CODE BEGIN Prototypes */
|
||||||
extern UART_HandleTypeDef huart1;
|
|
||||||
|
/* USER CODE END Prototypes */
|
||||||
extern UART_HandleTypeDef huart2;
|
|
||||||
|
#ifdef __cplusplus
|
||||||
extern UART_HandleTypeDef huart3;
|
}
|
||||||
|
#endif
|
||||||
/* USER CODE BEGIN Private defines */
|
|
||||||
|
#endif /* __USART_H__ */
|
||||||
/* USER CODE END Private defines */
|
|
||||||
|
|
||||||
void MX_UART5_Init(void);
|
|
||||||
void MX_USART1_UART_Init(void);
|
|
||||||
void MX_USART2_UART_Init(void);
|
|
||||||
void MX_USART3_UART_Init(void);
|
|
||||||
|
|
||||||
/* USER CODE BEGIN Prototypes */
|
|
||||||
|
|
||||||
/* USER CODE END Prototypes */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __USART_H__ */
|
|
||||||
|
|
||||||
|
|||||||
+218
-234
@@ -1,234 +1,218 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file adc.c
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* @brief This file provides code for the configuration
|
#include "adc.h"
|
||||||
* of the ADC instances.
|
|
||||||
******************************************************************************
|
/* USER CODE BEGIN 0 */
|
||||||
* @attention
|
#include "isr_opt.h"
|
||||||
*
|
static volatile uint16_t adc_dma_raw[6];
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
volatile ADC_ScanData_t adc_data = {0};
|
||||||
* All rights reserved.
|
static volatile uint8_t adc_scan_data_ready = 0u;
|
||||||
*
|
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
void ADC_ScanStart(void)
|
||||||
* in the root directory of this software component.
|
{
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
if (HAL_ADC_Start_DMA(&hadc1, (uint32_t *)adc_dma_raw, 6u) != HAL_OK)
|
||||||
*
|
{
|
||||||
******************************************************************************
|
Error_Handler();
|
||||||
*/
|
}
|
||||||
/* USER CODE END Header */
|
}
|
||||||
/* Includes ------------------------------------------------------------------*/
|
|
||||||
#include "adc.h"
|
ISR_FAST void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef *hadc)
|
||||||
|
{
|
||||||
/* USER CODE BEGIN 0 */
|
if (hadc->Instance != ADC1)
|
||||||
#include "isr_opt.h"
|
{
|
||||||
static volatile uint16_t adc_dma_raw[6];
|
return;
|
||||||
volatile ADC_ScanData_t adc_data = {0};
|
}
|
||||||
static volatile uint8_t adc_scan_data_ready = 0u;
|
|
||||||
|
adc_data.in3_raw = adc_dma_raw[0];
|
||||||
void ADC_ScanStart(void)
|
adc_data.cp_raw = adc_dma_raw[1];
|
||||||
{
|
adc_data.ntc1_raw = adc_dma_raw[2];
|
||||||
if (HAL_ADC_Start_DMA(&hadc1, (uint32_t *)adc_dma_raw, 6u) != HAL_OK)
|
adc_data.ntc2_raw = adc_dma_raw[3];
|
||||||
{
|
adc_data.temp_sensor_raw = adc_dma_raw[4];
|
||||||
Error_Handler();
|
adc_data.vrefint_raw = adc_dma_raw[5];
|
||||||
}
|
adc_scan_data_ready = 1u;
|
||||||
}
|
}
|
||||||
|
|
||||||
ISR_FAST void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef *hadc)
|
/* USER CODE END 0 */
|
||||||
{
|
|
||||||
if (hadc->Instance != ADC1)
|
ADC_HandleTypeDef hadc1;
|
||||||
{
|
DMA_HandleTypeDef hdma_adc1;
|
||||||
return;
|
|
||||||
}
|
/* ADC1 init function */
|
||||||
|
void MX_ADC1_Init(void)
|
||||||
adc_data.in3_raw = adc_dma_raw[0];
|
{
|
||||||
adc_data.cp_raw = adc_dma_raw[1];
|
|
||||||
adc_data.ntc1_raw = adc_dma_raw[2];
|
/* USER CODE BEGIN ADC1_Init 0 */
|
||||||
adc_data.ntc2_raw = adc_dma_raw[3];
|
|
||||||
adc_data.temp_sensor_raw = adc_dma_raw[4];
|
/* USER CODE END ADC1_Init 0 */
|
||||||
adc_data.vrefint_raw = adc_dma_raw[5];
|
|
||||||
adc_scan_data_ready = 1u;
|
ADC_ChannelConfTypeDef sConfig = {0};
|
||||||
}
|
|
||||||
|
/* USER CODE BEGIN ADC1_Init 1 */
|
||||||
/* USER CODE END 0 */
|
|
||||||
|
/* USER CODE END ADC1_Init 1 */
|
||||||
ADC_HandleTypeDef hadc1;
|
|
||||||
DMA_HandleTypeDef hdma_adc1;
|
/** Common config
|
||||||
|
*/
|
||||||
/* ADC1 init function */
|
hadc1.Instance = ADC1;
|
||||||
void MX_ADC1_Init(void)
|
hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
|
||||||
{
|
hadc1.Init.ContinuousConvMode = DISABLE;
|
||||||
|
hadc1.Init.DiscontinuousConvMode = DISABLE;
|
||||||
/* USER CODE BEGIN ADC1_Init 0 */
|
hadc1.Init.ExternalTrigConv = ADC_EXTERNALTRIGCONV_T3_TRGO;
|
||||||
|
hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
|
||||||
/* USER CODE END ADC1_Init 0 */
|
hadc1.Init.NbrOfConversion = 6;
|
||||||
|
if (HAL_ADC_Init(&hadc1) != HAL_OK)
|
||||||
ADC_ChannelConfTypeDef sConfig = {0};
|
{
|
||||||
|
Error_Handler();
|
||||||
/* USER CODE BEGIN ADC1_Init 1 */
|
}
|
||||||
|
|
||||||
/* USER CODE END ADC1_Init 1 */
|
/** Configure Regular Channel
|
||||||
|
*/
|
||||||
/** Common config
|
sConfig.Channel = ADC_CHANNEL_3;
|
||||||
*/
|
sConfig.Rank = ADC_REGULAR_RANK_1;
|
||||||
hadc1.Instance = ADC1;
|
sConfig.SamplingTime = ADC_SAMPLETIME_41CYCLES_5;
|
||||||
hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
|
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
||||||
hadc1.Init.ContinuousConvMode = DISABLE;
|
{
|
||||||
hadc1.Init.DiscontinuousConvMode = DISABLE;
|
Error_Handler();
|
||||||
hadc1.Init.ExternalTrigConv = ADC_EXTERNALTRIGCONV_T3_TRGO;
|
}
|
||||||
hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
|
|
||||||
hadc1.Init.NbrOfConversion = 6;
|
/** Configure Regular Channel
|
||||||
if (HAL_ADC_Init(&hadc1) != HAL_OK)
|
*/
|
||||||
{
|
sConfig.Channel = ADC_CHANNEL_4;
|
||||||
Error_Handler();
|
sConfig.Rank = ADC_REGULAR_RANK_2;
|
||||||
}
|
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
||||||
|
{
|
||||||
/** Configure Regular Channel
|
Error_Handler();
|
||||||
*/
|
}
|
||||||
sConfig.Channel = ADC_CHANNEL_3;
|
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_1;
|
/** Configure Regular Channel
|
||||||
sConfig.SamplingTime = ADC_SAMPLETIME_41CYCLES_5;
|
*/
|
||||||
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
sConfig.Channel = ADC_CHANNEL_8;
|
||||||
{
|
sConfig.Rank = ADC_REGULAR_RANK_3;
|
||||||
Error_Handler();
|
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
||||||
}
|
{
|
||||||
|
Error_Handler();
|
||||||
/** Configure Regular Channel
|
}
|
||||||
*/
|
|
||||||
sConfig.Channel = ADC_CHANNEL_4;
|
/** Configure Regular Channel
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_2;
|
*/
|
||||||
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
sConfig.Channel = ADC_CHANNEL_9;
|
||||||
{
|
sConfig.Rank = ADC_REGULAR_RANK_4;
|
||||||
Error_Handler();
|
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
||||||
}
|
{
|
||||||
|
Error_Handler();
|
||||||
/** Configure Regular Channel
|
}
|
||||||
*/
|
|
||||||
sConfig.Channel = ADC_CHANNEL_8;
|
/** Configure Regular Channel
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_3;
|
*/
|
||||||
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
sConfig.Channel = ADC_CHANNEL_TEMPSENSOR;
|
||||||
{
|
sConfig.Rank = ADC_REGULAR_RANK_5;
|
||||||
Error_Handler();
|
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
||||||
}
|
{
|
||||||
|
Error_Handler();
|
||||||
/** Configure Regular Channel
|
}
|
||||||
*/
|
|
||||||
sConfig.Channel = ADC_CHANNEL_9;
|
/** Configure Regular Channel
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_4;
|
*/
|
||||||
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
sConfig.Channel = ADC_CHANNEL_VREFINT;
|
||||||
{
|
sConfig.Rank = ADC_REGULAR_RANK_6;
|
||||||
Error_Handler();
|
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
||||||
}
|
{
|
||||||
|
Error_Handler();
|
||||||
/** Configure Regular Channel
|
}
|
||||||
*/
|
/* USER CODE BEGIN ADC1_Init 2 */
|
||||||
sConfig.Channel = ADC_CHANNEL_TEMPSENSOR;
|
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_5;
|
/* USER CODE END ADC1_Init 2 */
|
||||||
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
|
||||||
{
|
}
|
||||||
Error_Handler();
|
|
||||||
}
|
void HAL_ADC_MspInit(ADC_HandleTypeDef* adcHandle)
|
||||||
|
{
|
||||||
/** Configure Regular Channel
|
|
||||||
*/
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
||||||
sConfig.Channel = ADC_CHANNEL_VREFINT;
|
if(adcHandle->Instance==ADC1)
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_6;
|
{
|
||||||
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
|
/* USER CODE BEGIN ADC1_MspInit 0 */
|
||||||
{
|
|
||||||
Error_Handler();
|
/* USER CODE END ADC1_MspInit 0 */
|
||||||
}
|
/* ADC1 clock enable */
|
||||||
/* USER CODE BEGIN ADC1_Init 2 */
|
__HAL_RCC_ADC1_CLK_ENABLE();
|
||||||
|
|
||||||
/* USER CODE END ADC1_Init 2 */
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
||||||
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
||||||
}
|
/**ADC1 GPIO Configuration
|
||||||
|
PA3 ------> ADC1_IN3
|
||||||
void HAL_ADC_MspInit(ADC_HandleTypeDef* adcHandle)
|
PA4 ------> ADC1_IN4
|
||||||
{
|
PB0 ------> ADC1_IN8
|
||||||
|
PB1 ------> ADC1_IN9
|
||||||
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
*/
|
||||||
if(adcHandle->Instance==ADC1)
|
GPIO_InitStruct.Pin = GPIO_PIN_3|CP_ADC_Pin;
|
||||||
{
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
||||||
/* USER CODE BEGIN ADC1_MspInit 0 */
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
||||||
|
|
||||||
/* USER CODE END ADC1_MspInit 0 */
|
GPIO_InitStruct.Pin = ADC_NTC1_Pin|ADC_NTC2_Pin;
|
||||||
/* ADC1 clock enable */
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
||||||
__HAL_RCC_ADC1_CLK_ENABLE();
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
||||||
|
|
||||||
__HAL_RCC_GPIOA_CLK_ENABLE();
|
/* ADC1 DMA Init */
|
||||||
__HAL_RCC_GPIOB_CLK_ENABLE();
|
/* ADC1 Init */
|
||||||
/**ADC1 GPIO Configuration
|
hdma_adc1.Instance = DMA1_Channel1;
|
||||||
PA3 ------> ADC1_IN3
|
hdma_adc1.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
||||||
PA4 ------> ADC1_IN4
|
hdma_adc1.Init.PeriphInc = DMA_PINC_DISABLE;
|
||||||
PB0 ------> ADC1_IN8
|
hdma_adc1.Init.MemInc = DMA_MINC_ENABLE;
|
||||||
PB1 ------> ADC1_IN9
|
hdma_adc1.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
||||||
*/
|
hdma_adc1.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_3|CP_ADC_Pin;
|
hdma_adc1.Init.Mode = DMA_CIRCULAR;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
hdma_adc1.Init.Priority = DMA_PRIORITY_MEDIUM;
|
||||||
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
if (HAL_DMA_Init(&hdma_adc1) != HAL_OK)
|
||||||
|
{
|
||||||
GPIO_InitStruct.Pin = ADC_NTC1_Pin|ADC_NTC2_Pin;
|
Error_Handler();
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
}
|
||||||
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
||||||
|
__HAL_LINKDMA(adcHandle,DMA_Handle,hdma_adc1);
|
||||||
/* ADC1 DMA Init */
|
|
||||||
/* ADC1 Init */
|
/* ADC1 interrupt Init */
|
||||||
hdma_adc1.Instance = DMA1_Channel1;
|
HAL_NVIC_SetPriority(ADC1_2_IRQn, 7, 0);
|
||||||
hdma_adc1.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
HAL_NVIC_EnableIRQ(ADC1_2_IRQn);
|
||||||
hdma_adc1.Init.PeriphInc = DMA_PINC_DISABLE;
|
/* USER CODE BEGIN ADC1_MspInit 1 */
|
||||||
hdma_adc1.Init.MemInc = DMA_MINC_ENABLE;
|
|
||||||
hdma_adc1.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
/* USER CODE END ADC1_MspInit 1 */
|
||||||
hdma_adc1.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
}
|
||||||
hdma_adc1.Init.Mode = DMA_CIRCULAR;
|
}
|
||||||
hdma_adc1.Init.Priority = DMA_PRIORITY_MEDIUM;
|
|
||||||
if (HAL_DMA_Init(&hdma_adc1) != HAL_OK)
|
void HAL_ADC_MspDeInit(ADC_HandleTypeDef* adcHandle)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
|
||||||
}
|
if(adcHandle->Instance==ADC1)
|
||||||
|
{
|
||||||
__HAL_LINKDMA(adcHandle,DMA_Handle,hdma_adc1);
|
/* USER CODE BEGIN ADC1_MspDeInit 0 */
|
||||||
|
|
||||||
/* ADC1 interrupt Init */
|
/* USER CODE END ADC1_MspDeInit 0 */
|
||||||
HAL_NVIC_SetPriority(ADC1_2_IRQn, 7, 0);
|
/* Peripheral clock disable */
|
||||||
HAL_NVIC_EnableIRQ(ADC1_2_IRQn);
|
__HAL_RCC_ADC1_CLK_DISABLE();
|
||||||
/* USER CODE BEGIN ADC1_MspInit 1 */
|
|
||||||
|
/**ADC1 GPIO Configuration
|
||||||
/* USER CODE END ADC1_MspInit 1 */
|
PA3 ------> ADC1_IN3
|
||||||
}
|
PA4 ------> ADC1_IN4
|
||||||
}
|
PB0 ------> ADC1_IN8
|
||||||
|
PB1 ------> ADC1_IN9
|
||||||
void HAL_ADC_MspDeInit(ADC_HandleTypeDef* adcHandle)
|
*/
|
||||||
{
|
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_3|CP_ADC_Pin);
|
||||||
|
|
||||||
if(adcHandle->Instance==ADC1)
|
HAL_GPIO_DeInit(GPIOB, ADC_NTC1_Pin|ADC_NTC2_Pin);
|
||||||
{
|
|
||||||
/* USER CODE BEGIN ADC1_MspDeInit 0 */
|
/* ADC1 DMA DeInit */
|
||||||
|
HAL_DMA_DeInit(adcHandle->DMA_Handle);
|
||||||
/* USER CODE END ADC1_MspDeInit 0 */
|
|
||||||
/* Peripheral clock disable */
|
/* ADC1 interrupt Deinit */
|
||||||
__HAL_RCC_ADC1_CLK_DISABLE();
|
HAL_NVIC_DisableIRQ(ADC1_2_IRQn);
|
||||||
|
/* USER CODE BEGIN ADC1_MspDeInit 1 */
|
||||||
/**ADC1 GPIO Configuration
|
|
||||||
PA3 ------> ADC1_IN3
|
/* USER CODE END ADC1_MspDeInit 1 */
|
||||||
PA4 ------> ADC1_IN4
|
}
|
||||||
PB0 ------> ADC1_IN8
|
}
|
||||||
PB1 ------> ADC1_IN9
|
|
||||||
*/
|
/* USER CODE BEGIN 1 */
|
||||||
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_3|CP_ADC_Pin);
|
|
||||||
|
/* USER CODE END 1 */
|
||||||
HAL_GPIO_DeInit(GPIOB, ADC_NTC1_Pin|ADC_NTC2_Pin);
|
|
||||||
|
|
||||||
/* ADC1 DMA DeInit */
|
|
||||||
HAL_DMA_DeInit(adcHandle->DMA_Handle);
|
|
||||||
|
|
||||||
/* ADC1 interrupt Deinit */
|
|
||||||
HAL_NVIC_DisableIRQ(ADC1_2_IRQn);
|
|
||||||
/* USER CODE BEGIN ADC1_MspDeInit 1 */
|
|
||||||
|
|
||||||
/* USER CODE END ADC1_MspDeInit 1 */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
|
||||||
|
|||||||
+6
-18
@@ -1,13 +1,9 @@
|
|||||||
|
|
||||||
#include "main.h"
|
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "adc.h"
|
|
||||||
#include "tim.h"
|
|
||||||
#include "sma_filter.h"
|
|
||||||
|
|
||||||
//TODO:
|
#include "adc.h"
|
||||||
//TEMP READ
|
#include "main.h"
|
||||||
// Connector temperature sensors
|
#include "sma_filter.h"
|
||||||
|
#include "tim.h"
|
||||||
|
|
||||||
InfoBlock_t *InfoBlock = (InfoBlock_t *)(VERSION_OFFSET);
|
InfoBlock_t *InfoBlock = (InfoBlock_t *)(VERSION_OFFSET);
|
||||||
|
|
||||||
@@ -74,15 +70,8 @@ uint8_t IN_ReadInput(inputNum_t input_n){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t GetBoardTemp(){
|
/* Заглушка: температура платы не измеряется (нет реализации АЦП для канала). */
|
||||||
//TODO
|
uint8_t GetBoardTemp(void){
|
||||||
// HAL_ADC_Start(&hadc1); // start the adc
|
|
||||||
//
|
|
||||||
// HAL_ADC_PollForConversion(&hadc1, 100); // poll for conversion
|
|
||||||
//
|
|
||||||
// adc_val = HAL_ADC_GetValue(&hadc1); // get the adc value
|
|
||||||
//
|
|
||||||
// HAL_ADC_Stop(&hadc1); // stop adc
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -138,7 +127,6 @@ int16_t CONN_ReadTemp(uint8_t ch){
|
|||||||
return 20; //Термодатчик не подключен
|
return 20; //Термодатчик не подключен
|
||||||
}
|
}
|
||||||
|
|
||||||
// int adc_value = 2048; // Пример значения АЦП
|
|
||||||
float Vref = 3.3; // Напряжение опорное
|
float Vref = 3.3; // Напряжение опорное
|
||||||
float Vin = 5.0; // Входное напряжение
|
float Vin = 5.0; // Входное напряжение
|
||||||
float R = 1000; // Сопротивление резистора в Омах
|
float R = 1000; // Сопротивление резистора в Омах
|
||||||
|
|||||||
+215
-231
@@ -1,231 +1,215 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file can.c
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* @brief This file provides code for the configuration
|
#include "can.h"
|
||||||
* of the CAN instances.
|
|
||||||
******************************************************************************
|
/* USER CODE BEGIN 0 */
|
||||||
* @attention
|
|
||||||
*
|
/* USER CODE END 0 */
|
||||||
* Copyright (c) 2025 STMicroelectronics.
|
|
||||||
* All rights reserved.
|
CAN_HandleTypeDef hcan1;
|
||||||
*
|
CAN_HandleTypeDef hcan2;
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
|
||||||
* in the root directory of this software component.
|
/* CAN1 init function */
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
void MX_CAN1_Init(void)
|
||||||
*
|
{
|
||||||
******************************************************************************
|
|
||||||
*/
|
/* USER CODE BEGIN CAN1_Init 0 */
|
||||||
/* USER CODE END Header */
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* USER CODE END CAN1_Init 0 */
|
||||||
#include "can.h"
|
|
||||||
|
/* USER CODE BEGIN CAN1_Init 1 */
|
||||||
/* USER CODE BEGIN 0 */
|
|
||||||
|
/* USER CODE END CAN1_Init 1 */
|
||||||
/* USER CODE END 0 */
|
hcan1.Instance = CAN1;
|
||||||
|
hcan1.Init.Prescaler = 8;
|
||||||
CAN_HandleTypeDef hcan1;
|
hcan1.Init.Mode = CAN_MODE_NORMAL;
|
||||||
CAN_HandleTypeDef hcan2;
|
hcan1.Init.SyncJumpWidth = CAN_SJW_1TQ;
|
||||||
|
hcan1.Init.TimeSeg1 = CAN_BS1_15TQ;
|
||||||
/* CAN1 init function */
|
hcan1.Init.TimeSeg2 = CAN_BS2_2TQ;
|
||||||
void MX_CAN1_Init(void)
|
hcan1.Init.TimeTriggeredMode = DISABLE;
|
||||||
{
|
hcan1.Init.AutoBusOff = ENABLE;
|
||||||
|
hcan1.Init.AutoWakeUp = ENABLE;
|
||||||
/* USER CODE BEGIN CAN1_Init 0 */
|
hcan1.Init.AutoRetransmission = ENABLE;
|
||||||
|
hcan1.Init.ReceiveFifoLocked = DISABLE;
|
||||||
/* USER CODE END CAN1_Init 0 */
|
hcan1.Init.TransmitFifoPriority = ENABLE;
|
||||||
|
if (HAL_CAN_Init(&hcan1) != HAL_OK)
|
||||||
/* USER CODE BEGIN CAN1_Init 1 */
|
{
|
||||||
|
Error_Handler();
|
||||||
/* USER CODE END CAN1_Init 1 */
|
}
|
||||||
hcan1.Instance = CAN1;
|
/* USER CODE BEGIN CAN1_Init 2 */
|
||||||
hcan1.Init.Prescaler = 8;
|
|
||||||
hcan1.Init.Mode = CAN_MODE_NORMAL;
|
/* USER CODE END CAN1_Init 2 */
|
||||||
hcan1.Init.SyncJumpWidth = CAN_SJW_1TQ;
|
|
||||||
hcan1.Init.TimeSeg1 = CAN_BS1_15TQ;
|
}
|
||||||
hcan1.Init.TimeSeg2 = CAN_BS2_2TQ;
|
/* CAN2 init function */
|
||||||
hcan1.Init.TimeTriggeredMode = DISABLE;
|
void MX_CAN2_Init(void)
|
||||||
hcan1.Init.AutoBusOff = ENABLE;
|
{
|
||||||
hcan1.Init.AutoWakeUp = ENABLE;
|
|
||||||
hcan1.Init.AutoRetransmission = ENABLE;
|
/* USER CODE BEGIN CAN2_Init 0 */
|
||||||
hcan1.Init.ReceiveFifoLocked = DISABLE;
|
|
||||||
hcan1.Init.TransmitFifoPriority = ENABLE;
|
/* USER CODE END CAN2_Init 0 */
|
||||||
if (HAL_CAN_Init(&hcan1) != HAL_OK)
|
|
||||||
{
|
/* USER CODE BEGIN CAN2_Init 1 */
|
||||||
Error_Handler();
|
|
||||||
}
|
/* USER CODE END CAN2_Init 1 */
|
||||||
/* USER CODE BEGIN CAN1_Init 2 */
|
hcan2.Instance = CAN2;
|
||||||
|
hcan2.Init.Prescaler = 16;
|
||||||
/* USER CODE END CAN1_Init 2 */
|
hcan2.Init.Mode = CAN_MODE_NORMAL;
|
||||||
|
hcan2.Init.SyncJumpWidth = CAN_SJW_1TQ;
|
||||||
}
|
hcan2.Init.TimeSeg1 = CAN_BS1_15TQ;
|
||||||
/* CAN2 init function */
|
hcan2.Init.TimeSeg2 = CAN_BS2_2TQ;
|
||||||
void MX_CAN2_Init(void)
|
hcan2.Init.TimeTriggeredMode = DISABLE;
|
||||||
{
|
hcan2.Init.AutoBusOff = ENABLE;
|
||||||
|
hcan2.Init.AutoWakeUp = ENABLE;
|
||||||
/* USER CODE BEGIN CAN2_Init 0 */
|
hcan2.Init.AutoRetransmission = ENABLE;
|
||||||
|
hcan2.Init.ReceiveFifoLocked = DISABLE;
|
||||||
/* USER CODE END CAN2_Init 0 */
|
hcan2.Init.TransmitFifoPriority = ENABLE;
|
||||||
|
if (HAL_CAN_Init(&hcan2) != HAL_OK)
|
||||||
/* USER CODE BEGIN CAN2_Init 1 */
|
{
|
||||||
|
Error_Handler();
|
||||||
/* USER CODE END CAN2_Init 1 */
|
}
|
||||||
hcan2.Instance = CAN2;
|
/* USER CODE BEGIN CAN2_Init 2 */
|
||||||
hcan2.Init.Prescaler = 16;
|
|
||||||
hcan2.Init.Mode = CAN_MODE_NORMAL;
|
/* USER CODE END CAN2_Init 2 */
|
||||||
hcan2.Init.SyncJumpWidth = CAN_SJW_1TQ;
|
|
||||||
hcan2.Init.TimeSeg1 = CAN_BS1_15TQ;
|
}
|
||||||
hcan2.Init.TimeSeg2 = CAN_BS2_2TQ;
|
|
||||||
hcan2.Init.TimeTriggeredMode = DISABLE;
|
static uint32_t HAL_RCC_CAN1_CLK_ENABLED=0;
|
||||||
hcan2.Init.AutoBusOff = ENABLE;
|
|
||||||
hcan2.Init.AutoWakeUp = ENABLE;
|
void HAL_CAN_MspInit(CAN_HandleTypeDef* canHandle)
|
||||||
hcan2.Init.AutoRetransmission = ENABLE;
|
{
|
||||||
hcan2.Init.ReceiveFifoLocked = DISABLE;
|
|
||||||
hcan2.Init.TransmitFifoPriority = ENABLE;
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
||||||
if (HAL_CAN_Init(&hcan2) != HAL_OK)
|
if(canHandle->Instance==CAN1)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
/* USER CODE BEGIN CAN1_MspInit 0 */
|
||||||
}
|
|
||||||
/* USER CODE BEGIN CAN2_Init 2 */
|
/* USER CODE END CAN1_MspInit 0 */
|
||||||
|
/* CAN1 clock enable */
|
||||||
/* USER CODE END CAN2_Init 2 */
|
HAL_RCC_CAN1_CLK_ENABLED++;
|
||||||
|
if(HAL_RCC_CAN1_CLK_ENABLED==1){
|
||||||
}
|
__HAL_RCC_CAN1_CLK_ENABLE();
|
||||||
|
}
|
||||||
static uint32_t HAL_RCC_CAN1_CLK_ENABLED=0;
|
|
||||||
|
__HAL_RCC_GPIOD_CLK_ENABLE();
|
||||||
void HAL_CAN_MspInit(CAN_HandleTypeDef* canHandle)
|
/**CAN1 GPIO Configuration
|
||||||
{
|
PD0 ------> CAN1_RX
|
||||||
|
PD1 ------> CAN1_TX
|
||||||
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
*/
|
||||||
if(canHandle->Instance==CAN1)
|
GPIO_InitStruct.Pin = GPIO_PIN_0;
|
||||||
{
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
/* USER CODE BEGIN CAN1_MspInit 0 */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
||||||
/* USER CODE END CAN1_MspInit 0 */
|
|
||||||
/* CAN1 clock enable */
|
GPIO_InitStruct.Pin = GPIO_PIN_1;
|
||||||
HAL_RCC_CAN1_CLK_ENABLED++;
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
if(HAL_RCC_CAN1_CLK_ENABLED==1){
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
__HAL_RCC_CAN1_CLK_ENABLE();
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
||||||
}
|
|
||||||
|
__HAL_AFIO_REMAP_CAN1_3();
|
||||||
__HAL_RCC_GPIOD_CLK_ENABLE();
|
|
||||||
/**CAN1 GPIO Configuration
|
/* CAN1 interrupt Init */
|
||||||
PD0 ------> CAN1_RX
|
HAL_NVIC_SetPriority(CAN1_RX0_IRQn, 3, 0);
|
||||||
PD1 ------> CAN1_TX
|
HAL_NVIC_EnableIRQ(CAN1_RX0_IRQn);
|
||||||
*/
|
/* USER CODE BEGIN CAN1_MspInit 1 */
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_0;
|
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
/* USER CODE END CAN1_MspInit 1 */
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
}
|
||||||
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
else if(canHandle->Instance==CAN2)
|
||||||
|
{
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_1;
|
/* USER CODE BEGIN CAN2_MspInit 0 */
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
/* USER CODE END CAN2_MspInit 0 */
|
||||||
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
/* CAN2 clock enable */
|
||||||
|
__HAL_RCC_CAN2_CLK_ENABLE();
|
||||||
__HAL_AFIO_REMAP_CAN1_3();
|
HAL_RCC_CAN1_CLK_ENABLED++;
|
||||||
|
if(HAL_RCC_CAN1_CLK_ENABLED==1){
|
||||||
/* CAN1 interrupt Init */
|
__HAL_RCC_CAN1_CLK_ENABLE();
|
||||||
HAL_NVIC_SetPriority(CAN1_RX0_IRQn, 3, 0);
|
}
|
||||||
HAL_NVIC_EnableIRQ(CAN1_RX0_IRQn);
|
|
||||||
/* USER CODE BEGIN CAN1_MspInit 1 */
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
||||||
|
/**CAN2 GPIO Configuration
|
||||||
/* USER CODE END CAN1_MspInit 1 */
|
PB5 ------> CAN2_RX
|
||||||
}
|
PB6 ------> CAN2_TX
|
||||||
else if(canHandle->Instance==CAN2)
|
*/
|
||||||
{
|
GPIO_InitStruct.Pin = GPIO_PIN_5;
|
||||||
/* USER CODE BEGIN CAN2_MspInit 0 */
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
/* USER CODE END CAN2_MspInit 0 */
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
||||||
/* CAN2 clock enable */
|
|
||||||
__HAL_RCC_CAN2_CLK_ENABLE();
|
GPIO_InitStruct.Pin = GPIO_PIN_6;
|
||||||
HAL_RCC_CAN1_CLK_ENABLED++;
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
if(HAL_RCC_CAN1_CLK_ENABLED==1){
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
__HAL_RCC_CAN1_CLK_ENABLE();
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
||||||
}
|
|
||||||
|
__HAL_AFIO_REMAP_CAN2_ENABLE();
|
||||||
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
||||||
/**CAN2 GPIO Configuration
|
/* CAN2 interrupt Init */
|
||||||
PB5 ------> CAN2_RX
|
HAL_NVIC_SetPriority(CAN2_TX_IRQn, 0, 0);
|
||||||
PB6 ------> CAN2_TX
|
HAL_NVIC_EnableIRQ(CAN2_TX_IRQn);
|
||||||
*/
|
HAL_NVIC_SetPriority(CAN2_RX1_IRQn, 3, 0);
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_5;
|
HAL_NVIC_EnableIRQ(CAN2_RX1_IRQn);
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
/* USER CODE BEGIN CAN2_MspInit 1 */
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
||||||
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
/* USER CODE END CAN2_MspInit 1 */
|
||||||
|
}
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_6;
|
}
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
void HAL_CAN_MspDeInit(CAN_HandleTypeDef* canHandle)
|
||||||
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
{
|
||||||
|
|
||||||
__HAL_AFIO_REMAP_CAN2_ENABLE();
|
if(canHandle->Instance==CAN1)
|
||||||
|
{
|
||||||
/* CAN2 interrupt Init */
|
/* USER CODE BEGIN CAN1_MspDeInit 0 */
|
||||||
HAL_NVIC_SetPriority(CAN2_TX_IRQn, 0, 0);
|
|
||||||
HAL_NVIC_EnableIRQ(CAN2_TX_IRQn);
|
/* USER CODE END CAN1_MspDeInit 0 */
|
||||||
HAL_NVIC_SetPriority(CAN2_RX1_IRQn, 3, 0);
|
/* Peripheral clock disable */
|
||||||
HAL_NVIC_EnableIRQ(CAN2_RX1_IRQn);
|
HAL_RCC_CAN1_CLK_ENABLED--;
|
||||||
/* USER CODE BEGIN CAN2_MspInit 1 */
|
if(HAL_RCC_CAN1_CLK_ENABLED==0){
|
||||||
|
__HAL_RCC_CAN1_CLK_DISABLE();
|
||||||
/* USER CODE END CAN2_MspInit 1 */
|
}
|
||||||
}
|
|
||||||
}
|
/**CAN1 GPIO Configuration
|
||||||
|
PD0 ------> CAN1_RX
|
||||||
void HAL_CAN_MspDeInit(CAN_HandleTypeDef* canHandle)
|
PD1 ------> CAN1_TX
|
||||||
{
|
*/
|
||||||
|
HAL_GPIO_DeInit(GPIOD, GPIO_PIN_0|GPIO_PIN_1);
|
||||||
if(canHandle->Instance==CAN1)
|
|
||||||
{
|
/* CAN1 interrupt Deinit */
|
||||||
/* USER CODE BEGIN CAN1_MspDeInit 0 */
|
HAL_NVIC_DisableIRQ(CAN1_RX0_IRQn);
|
||||||
|
/* USER CODE BEGIN CAN1_MspDeInit 1 */
|
||||||
/* USER CODE END CAN1_MspDeInit 0 */
|
|
||||||
/* Peripheral clock disable */
|
/* USER CODE END CAN1_MspDeInit 1 */
|
||||||
HAL_RCC_CAN1_CLK_ENABLED--;
|
}
|
||||||
if(HAL_RCC_CAN1_CLK_ENABLED==0){
|
else if(canHandle->Instance==CAN2)
|
||||||
__HAL_RCC_CAN1_CLK_DISABLE();
|
{
|
||||||
}
|
/* USER CODE BEGIN CAN2_MspDeInit 0 */
|
||||||
|
|
||||||
/**CAN1 GPIO Configuration
|
/* USER CODE END CAN2_MspDeInit 0 */
|
||||||
PD0 ------> CAN1_RX
|
/* Peripheral clock disable */
|
||||||
PD1 ------> CAN1_TX
|
__HAL_RCC_CAN2_CLK_DISABLE();
|
||||||
*/
|
HAL_RCC_CAN1_CLK_ENABLED--;
|
||||||
HAL_GPIO_DeInit(GPIOD, GPIO_PIN_0|GPIO_PIN_1);
|
if(HAL_RCC_CAN1_CLK_ENABLED==0){
|
||||||
|
__HAL_RCC_CAN1_CLK_DISABLE();
|
||||||
/* CAN1 interrupt Deinit */
|
}
|
||||||
HAL_NVIC_DisableIRQ(CAN1_RX0_IRQn);
|
|
||||||
/* USER CODE BEGIN CAN1_MspDeInit 1 */
|
/**CAN2 GPIO Configuration
|
||||||
|
PB5 ------> CAN2_RX
|
||||||
/* USER CODE END CAN1_MspDeInit 1 */
|
PB6 ------> CAN2_TX
|
||||||
}
|
*/
|
||||||
else if(canHandle->Instance==CAN2)
|
HAL_GPIO_DeInit(GPIOB, GPIO_PIN_5|GPIO_PIN_6);
|
||||||
{
|
|
||||||
/* USER CODE BEGIN CAN2_MspDeInit 0 */
|
/* CAN2 interrupt Deinit */
|
||||||
|
HAL_NVIC_DisableIRQ(CAN2_TX_IRQn);
|
||||||
/* USER CODE END CAN2_MspDeInit 0 */
|
HAL_NVIC_DisableIRQ(CAN2_RX1_IRQn);
|
||||||
/* Peripheral clock disable */
|
/* USER CODE BEGIN CAN2_MspDeInit 1 */
|
||||||
__HAL_RCC_CAN2_CLK_DISABLE();
|
|
||||||
HAL_RCC_CAN1_CLK_ENABLED--;
|
/* USER CODE END CAN2_MspDeInit 1 */
|
||||||
if(HAL_RCC_CAN1_CLK_ENABLED==0){
|
}
|
||||||
__HAL_RCC_CAN1_CLK_DISABLE();
|
}
|
||||||
}
|
|
||||||
|
/* USER CODE BEGIN 1 */
|
||||||
/**CAN2 GPIO Configuration
|
|
||||||
PB5 ------> CAN2_RX
|
/* USER CODE END 1 */
|
||||||
PB6 ------> CAN2_TX
|
|
||||||
*/
|
|
||||||
HAL_GPIO_DeInit(GPIOB, GPIO_PIN_5|GPIO_PIN_6);
|
|
||||||
|
|
||||||
/* CAN2 interrupt Deinit */
|
|
||||||
HAL_NVIC_DisableIRQ(CAN2_TX_IRQn);
|
|
||||||
HAL_NVIC_DisableIRQ(CAN2_RX1_IRQn);
|
|
||||||
/* USER CODE BEGIN CAN2_MspDeInit 1 */
|
|
||||||
|
|
||||||
/* USER CODE END CAN2_MspDeInit 1 */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
|
||||||
|
|||||||
@@ -1,13 +1,11 @@
|
|||||||
|
|
||||||
#include "charger_control.h"
|
#include "charger_control.h"
|
||||||
|
|
||||||
#include "charger_config.h"
|
#include "charger_config.h"
|
||||||
#include "psu_control.h"
|
|
||||||
#include "connector.h"
|
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
#include "psu_control.h"
|
||||||
|
|
||||||
ChargingConnector_t CONN;
|
ChargingConnector_t CONN;
|
||||||
CONN_State_t connectorState;
|
CONN_State_t connectorState;
|
||||||
extern uint8_t config_initialized;
|
|
||||||
|
|
||||||
void CONN_Init(){
|
void CONN_Init(){
|
||||||
|
|
||||||
@@ -28,24 +26,16 @@ void CONN_Loop(){
|
|||||||
CONN.chargingError = CONN_ERR_CONTACTOR;
|
CONN.chargingError = CONN_ERR_CONTACTOR;
|
||||||
} else if(PSU0.psu_fault){
|
} else if(PSU0.psu_fault){
|
||||||
CONN.chargingError = CONN_ERR_PSU_FAULT;
|
CONN.chargingError = CONN_ERR_PSU_FAULT;
|
||||||
// } else if(!CTRL.ac_ok) {
|
|
||||||
// CONN.chargingError = CONN_ERR_AC_FAULT;
|
|
||||||
// } else
|
|
||||||
}else if (CONN.EvConnected == 0){
|
}else if (CONN.EvConnected == 0){
|
||||||
CONN.chargingError = CONN_NO_ERROR;
|
CONN.chargingError = CONN_NO_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(ED_TraceWarning(CONN.chargingError, 0)) printf("CONN%d Error: %d\n", 0, CONN.chargingError);
|
if(ED_TraceWarning(CONN.chargingError, 0)) {
|
||||||
|
log_printf(LOG_WARN, "CONN0 Error: %d\n", (int)CONN.chargingError);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CONN_Task(){
|
|
||||||
/* CCS state machine is handled in serial.c.
|
|
||||||
* Keep this task lightweight for scheduler compatibility.
|
|
||||||
*/
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CONN_SetState(CONN_State_t state){
|
void CONN_SetState(CONN_State_t state){
|
||||||
if (connectorState == state) {
|
if (connectorState == state) {
|
||||||
CONN.connState = state;
|
CONN.connState = state;
|
||||||
@@ -71,10 +61,3 @@ void CONN_SetState(CONN_State_t state){
|
|||||||
|
|
||||||
CONN.connState = state;
|
CONN.connState = state;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CONN_PrintChargingTotal(){
|
|
||||||
printf("CONN%d Charging Finished:\n", 0);
|
|
||||||
// printf("Charging Time: %d\n", CONN.chargingTime);
|
|
||||||
printf("Charging Energy: %d\n", CONN.Energy);
|
|
||||||
// printf("Charging Power: %d\n", CONN.chargingPower);
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
#include "cp.h"
|
#include "cp.h"
|
||||||
|
|
||||||
#include "adc.h"
|
#include "adc.h"
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|||||||
+69
-85
@@ -1,85 +1,69 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file crc.c
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* @brief This file provides code for the configuration
|
#include "crc.h"
|
||||||
* of the CRC instances.
|
|
||||||
******************************************************************************
|
/* USER CODE BEGIN 0 */
|
||||||
* @attention
|
|
||||||
*
|
/* USER CODE END 0 */
|
||||||
* Copyright (c) 2025 STMicroelectronics.
|
|
||||||
* All rights reserved.
|
CRC_HandleTypeDef hcrc;
|
||||||
*
|
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
/* CRC init function */
|
||||||
* in the root directory of this software component.
|
void MX_CRC_Init(void)
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
{
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE BEGIN CRC_Init 0 */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
/* USER CODE END CRC_Init 0 */
|
||||||
/* Includes ------------------------------------------------------------------*/
|
|
||||||
#include "crc.h"
|
/* USER CODE BEGIN CRC_Init 1 */
|
||||||
|
|
||||||
/* USER CODE BEGIN 0 */
|
/* USER CODE END CRC_Init 1 */
|
||||||
|
hcrc.Instance = CRC;
|
||||||
/* USER CODE END 0 */
|
if (HAL_CRC_Init(&hcrc) != HAL_OK)
|
||||||
|
{
|
||||||
CRC_HandleTypeDef hcrc;
|
Error_Handler();
|
||||||
|
}
|
||||||
/* CRC init function */
|
/* USER CODE BEGIN CRC_Init 2 */
|
||||||
void MX_CRC_Init(void)
|
|
||||||
{
|
/* USER CODE END CRC_Init 2 */
|
||||||
|
|
||||||
/* USER CODE BEGIN CRC_Init 0 */
|
}
|
||||||
|
|
||||||
/* USER CODE END CRC_Init 0 */
|
void HAL_CRC_MspInit(CRC_HandleTypeDef* crcHandle)
|
||||||
|
{
|
||||||
/* USER CODE BEGIN CRC_Init 1 */
|
|
||||||
|
if(crcHandle->Instance==CRC)
|
||||||
/* USER CODE END CRC_Init 1 */
|
{
|
||||||
hcrc.Instance = CRC;
|
/* USER CODE BEGIN CRC_MspInit 0 */
|
||||||
if (HAL_CRC_Init(&hcrc) != HAL_OK)
|
|
||||||
{
|
/* USER CODE END CRC_MspInit 0 */
|
||||||
Error_Handler();
|
/* CRC clock enable */
|
||||||
}
|
__HAL_RCC_CRC_CLK_ENABLE();
|
||||||
/* USER CODE BEGIN CRC_Init 2 */
|
/* USER CODE BEGIN CRC_MspInit 1 */
|
||||||
|
|
||||||
/* USER CODE END CRC_Init 2 */
|
/* USER CODE END CRC_MspInit 1 */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void HAL_CRC_MspInit(CRC_HandleTypeDef* crcHandle)
|
void HAL_CRC_MspDeInit(CRC_HandleTypeDef* crcHandle)
|
||||||
{
|
{
|
||||||
|
|
||||||
if(crcHandle->Instance==CRC)
|
if(crcHandle->Instance==CRC)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN CRC_MspInit 0 */
|
/* USER CODE BEGIN CRC_MspDeInit 0 */
|
||||||
|
|
||||||
/* USER CODE END CRC_MspInit 0 */
|
/* USER CODE END CRC_MspDeInit 0 */
|
||||||
/* CRC clock enable */
|
/* Peripheral clock disable */
|
||||||
__HAL_RCC_CRC_CLK_ENABLE();
|
__HAL_RCC_CRC_CLK_DISABLE();
|
||||||
/* USER CODE BEGIN CRC_MspInit 1 */
|
/* USER CODE BEGIN CRC_MspDeInit 1 */
|
||||||
|
|
||||||
/* USER CODE END CRC_MspInit 1 */
|
/* USER CODE END CRC_MspDeInit 1 */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void HAL_CRC_MspDeInit(CRC_HandleTypeDef* crcHandle)
|
/* USER CODE BEGIN 1 */
|
||||||
{
|
|
||||||
|
/* USER CODE END 1 */
|
||||||
if(crcHandle->Instance==CRC)
|
|
||||||
{
|
|
||||||
/* USER CODE BEGIN CRC_MspDeInit 0 */
|
|
||||||
|
|
||||||
/* USER CODE END CRC_MspDeInit 0 */
|
|
||||||
/* Peripheral clock disable */
|
|
||||||
__HAL_RCC_CRC_CLK_DISABLE();
|
|
||||||
/* USER CODE BEGIN CRC_MspDeInit 1 */
|
|
||||||
|
|
||||||
/* USER CODE END CRC_MspDeInit 1 */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
|
||||||
|
|||||||
+7
-14
@@ -1,21 +1,14 @@
|
|||||||
/*
|
|
||||||
* debug.c
|
|
||||||
*
|
|
||||||
* Created on: Apr 16, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
#include "board.h"
|
||||||
|
#include "connector.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "serial_control.h"
|
||||||
|
#include "usart.h"
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <stdint.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdint.h>
|
|
||||||
#include <stdarg.h>
|
|
||||||
#include "debug.h"
|
|
||||||
#include "board.h"
|
|
||||||
#include "usart.h"
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <connector.h>
|
|
||||||
#include "serial_control.h"
|
|
||||||
|
|
||||||
// Кольцевой буфер для отладочных сообщений
|
// Кольцевой буфер для отладочных сообщений
|
||||||
#define DEBUG_BUFFER_SIZE 1024
|
#define DEBUG_BUFFER_SIZE 1024
|
||||||
|
|||||||
+51
-67
@@ -1,67 +1,51 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file dma.c
|
|
||||||
* @brief This file provides code for the configuration
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* of all the requested memory to memory DMA transfers.
|
#include "dma.h"
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
/* USER CODE BEGIN 0 */
|
||||||
*
|
|
||||||
* Copyright (c) 2026 STMicroelectronics.
|
/* USER CODE END 0 */
|
||||||
* All rights reserved.
|
|
||||||
*
|
/*----------------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
/* Configure DMA */
|
||||||
* in the root directory of this software component.
|
/*----------------------------------------------------------------------------*/
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
|
||||||
*
|
/* USER CODE BEGIN 1 */
|
||||||
******************************************************************************
|
|
||||||
*/
|
/* USER CODE END 1 */
|
||||||
/* USER CODE END Header */
|
|
||||||
|
/**
|
||||||
/* Includes ------------------------------------------------------------------*/
|
* Enable DMA controller clock
|
||||||
#include "dma.h"
|
*/
|
||||||
|
void MX_DMA_Init(void)
|
||||||
/* USER CODE BEGIN 0 */
|
{
|
||||||
|
|
||||||
/* USER CODE END 0 */
|
/* DMA controller clock enable */
|
||||||
|
__HAL_RCC_DMA1_CLK_ENABLE();
|
||||||
/*----------------------------------------------------------------------------*/
|
|
||||||
/* Configure DMA */
|
/* DMA interrupt init */
|
||||||
/*----------------------------------------------------------------------------*/
|
/* DMA1_Channel1_IRQn interrupt configuration */
|
||||||
|
HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 1, 0);
|
||||||
/* USER CODE BEGIN 1 */
|
HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
|
||||||
|
/* DMA1_Channel2_IRQn interrupt configuration */
|
||||||
/* USER CODE END 1 */
|
HAL_NVIC_SetPriority(DMA1_Channel2_IRQn, 4, 0);
|
||||||
|
HAL_NVIC_EnableIRQ(DMA1_Channel2_IRQn);
|
||||||
/**
|
/* DMA1_Channel3_IRQn interrupt configuration */
|
||||||
* Enable DMA controller clock
|
HAL_NVIC_SetPriority(DMA1_Channel3_IRQn, 1, 0);
|
||||||
*/
|
HAL_NVIC_EnableIRQ(DMA1_Channel3_IRQn);
|
||||||
void MX_DMA_Init(void)
|
/* DMA1_Channel6_IRQn interrupt configuration */
|
||||||
{
|
HAL_NVIC_SetPriority(DMA1_Channel6_IRQn, 1, 0);
|
||||||
|
HAL_NVIC_EnableIRQ(DMA1_Channel6_IRQn);
|
||||||
/* DMA controller clock enable */
|
/* DMA1_Channel7_IRQn interrupt configuration */
|
||||||
__HAL_RCC_DMA1_CLK_ENABLE();
|
HAL_NVIC_SetPriority(DMA1_Channel7_IRQn, 4, 0);
|
||||||
|
HAL_NVIC_EnableIRQ(DMA1_Channel7_IRQn);
|
||||||
/* DMA interrupt init */
|
|
||||||
/* DMA1_Channel1_IRQn interrupt configuration */
|
}
|
||||||
HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 1, 0);
|
|
||||||
HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
|
/* USER CODE BEGIN 2 */
|
||||||
/* DMA1_Channel2_IRQn interrupt configuration */
|
|
||||||
HAL_NVIC_SetPriority(DMA1_Channel2_IRQn, 4, 0);
|
/* USER CODE END 2 */
|
||||||
HAL_NVIC_EnableIRQ(DMA1_Channel2_IRQn);
|
|
||||||
/* DMA1_Channel3_IRQn interrupt configuration */
|
|
||||||
HAL_NVIC_SetPriority(DMA1_Channel3_IRQn, 1, 0);
|
|
||||||
HAL_NVIC_EnableIRQ(DMA1_Channel3_IRQn);
|
|
||||||
/* DMA1_Channel6_IRQn interrupt configuration */
|
|
||||||
HAL_NVIC_SetPriority(DMA1_Channel6_IRQn, 1, 0);
|
|
||||||
HAL_NVIC_EnableIRQ(DMA1_Channel6_IRQn);
|
|
||||||
/* DMA1_Channel7_IRQn interrupt configuration */
|
|
||||||
HAL_NVIC_SetPriority(DMA1_Channel7_IRQn, 4, 0);
|
|
||||||
HAL_NVIC_EnableIRQ(DMA1_Channel7_IRQn);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 2 */
|
|
||||||
|
|
||||||
/* USER CODE END 2 */
|
|
||||||
|
|
||||||
|
|||||||
+157
-173
@@ -1,173 +1,157 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file gpio.c
|
|
||||||
* @brief This file provides code for the configuration
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* of all used GPIO pins.
|
#include "gpio.h"
|
||||||
******************************************************************************
|
|
||||||
* @attention
|
/* USER CODE BEGIN 0 */
|
||||||
*
|
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
/* USER CODE END 0 */
|
||||||
* All rights reserved.
|
|
||||||
*
|
/*----------------------------------------------------------------------------*/
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
/* Configure GPIO */
|
||||||
* in the root directory of this software component.
|
/*----------------------------------------------------------------------------*/
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
/* USER CODE BEGIN 1 */
|
||||||
*
|
|
||||||
******************************************************************************
|
/* USER CODE END 1 */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
/** Configure pins as
|
||||||
|
* Analog
|
||||||
/* Includes ------------------------------------------------------------------*/
|
* Input
|
||||||
#include "gpio.h"
|
* Output
|
||||||
|
* EVENT_OUT
|
||||||
/* USER CODE BEGIN 0 */
|
* EXTI
|
||||||
|
PB8 ------> I2C1_SCL
|
||||||
/* USER CODE END 0 */
|
PB9 ------> I2C1_SDA
|
||||||
|
*/
|
||||||
/*----------------------------------------------------------------------------*/
|
void MX_GPIO_Init(void)
|
||||||
/* Configure GPIO */
|
{
|
||||||
/*----------------------------------------------------------------------------*/
|
|
||||||
/* USER CODE BEGIN 1 */
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
/* GPIO Ports Clock Enable */
|
||||||
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
||||||
/** Configure pins as
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
||||||
* Analog
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
||||||
* Input
|
__HAL_RCC_GPIOE_CLK_ENABLE();
|
||||||
* Output
|
__HAL_RCC_GPIOD_CLK_ENABLE();
|
||||||
* EVENT_OUT
|
|
||||||
* EXTI
|
/*Configure GPIO pin Output Level */
|
||||||
PB8 ------> I2C1_SCL
|
HAL_GPIO_WritePin(GPIOC, DBG1_Pin|RELAY_CP_Pin|LOCK_A_Pin|LOCK_B_Pin, GPIO_PIN_RESET);
|
||||||
PB9 ------> I2C1_SDA
|
|
||||||
*/
|
/*Configure GPIO pin Output Level */
|
||||||
void MX_GPIO_Init(void)
|
HAL_GPIO_WritePin(GPIOA, DBG2_Pin|DBG3_Pin|RELAY_CC_Pin, GPIO_PIN_RESET);
|
||||||
{
|
|
||||||
|
/*Configure GPIO pin Output Level */
|
||||||
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
HAL_GPIO_WritePin(GPIOE, RELAY1_Pin|RELAY2_Pin|RELAY3_Pin|RELAY4_Pin
|
||||||
|
|RELAY5_Pin, GPIO_PIN_RESET);
|
||||||
/* GPIO Ports Clock Enable */
|
|
||||||
__HAL_RCC_GPIOC_CLK_ENABLE();
|
/*Configure GPIO pin Output Level */
|
||||||
__HAL_RCC_GPIOA_CLK_ENABLE();
|
HAL_GPIO_WritePin(GPIOB, DBG5_Pin|DBG4_Pin|EE_WP_Pin, GPIO_PIN_RESET);
|
||||||
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
||||||
__HAL_RCC_GPIOE_CLK_ENABLE();
|
/*Configure GPIO pin Output Level */
|
||||||
__HAL_RCC_GPIOD_CLK_ENABLE();
|
HAL_GPIO_WritePin(GPIOD, RELAY_DC_Pin|USART2_DIR_Pin, GPIO_PIN_RESET);
|
||||||
|
|
||||||
/*Configure GPIO pin Output Level */
|
/*Configure GPIO pin : DBG1_Pin */
|
||||||
HAL_GPIO_WritePin(GPIOC, DBG1_Pin|RELAY_CP_Pin|LOCK_A_Pin|LOCK_B_Pin, GPIO_PIN_RESET);
|
GPIO_InitStruct.Pin = DBG1_Pin;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
||||||
/*Configure GPIO pin Output Level */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
HAL_GPIO_WritePin(GPIOA, DBG2_Pin|DBG3_Pin|RELAY_CC_Pin, GPIO_PIN_RESET);
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
|
HAL_GPIO_Init(DBG1_GPIO_Port, &GPIO_InitStruct);
|
||||||
/*Configure GPIO pin Output Level */
|
|
||||||
HAL_GPIO_WritePin(GPIOE, RELAY1_Pin|RELAY2_Pin|RELAY3_Pin|RELAY4_Pin
|
/*Configure GPIO pins : RELAY_CP_Pin LOCK_A_Pin LOCK_B_Pin */
|
||||||
|RELAY5_Pin, GPIO_PIN_RESET);
|
GPIO_InitStruct.Pin = RELAY_CP_Pin|LOCK_A_Pin|LOCK_B_Pin;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
||||||
/*Configure GPIO pin Output Level */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
HAL_GPIO_WritePin(GPIOB, DBG5_Pin|DBG4_Pin|EE_WP_Pin, GPIO_PIN_RESET);
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
||||||
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
||||||
/*Configure GPIO pin Output Level */
|
|
||||||
HAL_GPIO_WritePin(GPIOD, RELAY_DC_Pin|USART2_DIR_Pin, GPIO_PIN_RESET);
|
/*Configure GPIO pin : IN_SW0_Pin */
|
||||||
|
GPIO_InitStruct.Pin = IN_SW0_Pin;
|
||||||
/*Configure GPIO pin : DBG1_Pin */
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
GPIO_InitStruct.Pin = DBG1_Pin;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
HAL_GPIO_Init(IN_SW0_GPIO_Port, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
/*Configure GPIO pin : IN_SW1_Pin */
|
||||||
HAL_GPIO_Init(DBG1_GPIO_Port, &GPIO_InitStruct);
|
GPIO_InitStruct.Pin = IN_SW1_Pin;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
/*Configure GPIO pins : RELAY_CP_Pin LOCK_A_Pin LOCK_B_Pin */
|
GPIO_InitStruct.Pull = GPIO_PULLDOWN;
|
||||||
GPIO_InitStruct.Pin = RELAY_CP_Pin|LOCK_A_Pin|LOCK_B_Pin;
|
HAL_GPIO_Init(IN_SW1_GPIO_Port, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
/*Configure GPIO pins : DBG2_Pin DBG3_Pin */
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
GPIO_InitStruct.Pin = DBG2_Pin|DBG3_Pin;
|
||||||
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
||||||
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
/*Configure GPIO pin : IN_SW0_Pin */
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
GPIO_InitStruct.Pin = IN_SW0_Pin;
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
/*Configure GPIO pins : IN0_Pin AC_OK_Pin ISO_IN_Pin */
|
||||||
HAL_GPIO_Init(IN_SW0_GPIO_Port, &GPIO_InitStruct);
|
GPIO_InitStruct.Pin = IN0_Pin|AC_OK_Pin|ISO_IN_Pin;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
/*Configure GPIO pin : IN_SW1_Pin */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Pin = IN_SW1_Pin;
|
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
||||||
GPIO_InitStruct.Pull = GPIO_PULLDOWN;
|
/*Configure GPIO pins : RELAY1_Pin RELAY2_Pin RELAY3_Pin RELAY4_Pin
|
||||||
HAL_GPIO_Init(IN_SW1_GPIO_Port, &GPIO_InitStruct);
|
RELAY5_Pin */
|
||||||
|
GPIO_InitStruct.Pin = RELAY1_Pin|RELAY2_Pin|RELAY3_Pin|RELAY4_Pin
|
||||||
/*Configure GPIO pins : DBG2_Pin DBG3_Pin */
|
|RELAY5_Pin;
|
||||||
GPIO_InitStruct.Pin = DBG2_Pin|DBG3_Pin;
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
||||||
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
||||||
|
/*Configure GPIO pins : DBG5_Pin DBG4_Pin */
|
||||||
/*Configure GPIO pins : IN0_Pin AC_OK_Pin ISO_IN_Pin */
|
GPIO_InitStruct.Pin = DBG5_Pin|DBG4_Pin;
|
||||||
GPIO_InitStruct.Pin = IN0_Pin|AC_OK_Pin|ISO_IN_Pin;
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
||||||
|
|
||||||
/*Configure GPIO pins : RELAY1_Pin RELAY2_Pin RELAY3_Pin RELAY4_Pin
|
/*Configure GPIO pin : RELAY_CC_Pin */
|
||||||
RELAY5_Pin */
|
GPIO_InitStruct.Pin = RELAY_CC_Pin;
|
||||||
GPIO_InitStruct.Pin = RELAY1_Pin|RELAY2_Pin|RELAY3_Pin|RELAY4_Pin
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
||||||
|RELAY5_Pin;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
HAL_GPIO_Init(RELAY_CC_GPIO_Port, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
||||||
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
/*Configure GPIO pins : RELAY_DC_Pin USART2_DIR_Pin */
|
||||||
|
GPIO_InitStruct.Pin = RELAY_DC_Pin|USART2_DIR_Pin;
|
||||||
/*Configure GPIO pins : DBG5_Pin DBG4_Pin */
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
||||||
GPIO_InitStruct.Pin = DBG5_Pin|DBG4_Pin;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
|
||||||
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
/*Configure GPIO pin : IN_ESTOP_Pin */
|
||||||
|
GPIO_InitStruct.Pin = IN_ESTOP_Pin;
|
||||||
/*Configure GPIO pin : RELAY_CC_Pin */
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
GPIO_InitStruct.Pin = RELAY_CC_Pin;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
HAL_GPIO_Init(IN_ESTOP_GPIO_Port, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
/*Configure GPIO pins : IN_FB2_Pin IN_FB1_Pin */
|
||||||
HAL_GPIO_Init(RELAY_CC_GPIO_Port, &GPIO_InitStruct);
|
GPIO_InitStruct.Pin = IN_FB2_Pin|IN_FB1_Pin;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
/*Configure GPIO pins : RELAY_DC_Pin USART2_DIR_Pin */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Pin = RELAY_DC_Pin|USART2_DIR_Pin;
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
/*Configure GPIO pin : EE_WP_Pin */
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
GPIO_InitStruct.Pin = EE_WP_Pin;
|
||||||
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
||||||
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
/*Configure GPIO pin : IN_ESTOP_Pin */
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
||||||
GPIO_InitStruct.Pin = IN_ESTOP_Pin;
|
HAL_GPIO_Init(EE_WP_GPIO_Port, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
/*Configure GPIO pins : PB8 PB9 */
|
||||||
HAL_GPIO_Init(IN_ESTOP_GPIO_Port, &GPIO_InitStruct);
|
GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
|
||||||
/*Configure GPIO pins : IN_FB2_Pin IN_FB1_Pin */
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
GPIO_InitStruct.Pin = IN_FB2_Pin|IN_FB1_Pin;
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
/*Configure peripheral I/O remapping */
|
||||||
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
__HAL_AFIO_REMAP_I2C1_ENABLE();
|
||||||
|
|
||||||
/*Configure GPIO pin : EE_WP_Pin */
|
}
|
||||||
GPIO_InitStruct.Pin = EE_WP_Pin;
|
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
/* USER CODE BEGIN 2 */
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
/* USER CODE END 2 */
|
||||||
HAL_GPIO_Init(EE_WP_GPIO_Port, &GPIO_InitStruct);
|
|
||||||
|
|
||||||
/*Configure GPIO pins : PB8 PB9 */
|
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9;
|
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
|
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
|
||||||
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
||||||
|
|
||||||
/*Configure peripheral I/O remapping */
|
|
||||||
__HAL_AFIO_REMAP_I2C1_ENABLE();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 2 */
|
|
||||||
|
|
||||||
/* USER CODE END 2 */
|
|
||||||
|
|||||||
+336
-335
@@ -1,335 +1,336 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/* USER CODE END Header */
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* USER CODE END Header */
|
||||||
#include "main.h"
|
/* Includes ------------------------------------------------------------------*/
|
||||||
#include "adc.h"
|
#include "main.h"
|
||||||
#include "can.h"
|
#include "adc.h"
|
||||||
#include "crc.h"
|
#include "can.h"
|
||||||
#include "dma.h"
|
#include "crc.h"
|
||||||
#include "rtc.h"
|
#include "dma.h"
|
||||||
#include "tim.h"
|
#include "rtc.h"
|
||||||
#include "usart.h"
|
#include "tim.h"
|
||||||
#include "gpio.h"
|
#include "usart.h"
|
||||||
|
#include "gpio.h"
|
||||||
/* Private includes ----------------------------------------------------------*/
|
|
||||||
/* USER CODE BEGIN Includes */
|
/* Private includes ----------------------------------------------------------*/
|
||||||
#include "can.h"
|
/* USER CODE BEGIN Includes */
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include <stdio.h>
|
#include "charger_config.h"
|
||||||
#include "debug.h"
|
#include "connector.h"
|
||||||
#include "soft_rtc.h"
|
#include "debug.h"
|
||||||
#include "connector.h"
|
#include "meter.h"
|
||||||
#include "serial_control.h"
|
#include "psu_control.h"
|
||||||
#include "charger_config.h"
|
#include "rgb_controller.h"
|
||||||
#include "serial.h"
|
#include "serial.h"
|
||||||
/* USER CODE END Includes */
|
#include "serial_control.h"
|
||||||
|
#include "soft_rtc.h"
|
||||||
/* Private typedef -----------------------------------------------------------*/
|
#include <stdio.h>
|
||||||
/* USER CODE BEGIN PTD */
|
/* USER CODE END Includes */
|
||||||
|
|
||||||
/* USER CODE END PTD */
|
/* Private typedef -----------------------------------------------------------*/
|
||||||
|
/* USER CODE BEGIN PTD */
|
||||||
/* Private define ------------------------------------------------------------*/
|
|
||||||
/* USER CODE BEGIN PD */
|
/* USER CODE END PTD */
|
||||||
|
|
||||||
/* USER CODE END PD */
|
/* Private define ------------------------------------------------------------*/
|
||||||
|
/* USER CODE BEGIN PD */
|
||||||
/* Private macro -------------------------------------------------------------*/
|
|
||||||
/* USER CODE BEGIN PM */
|
/* USER CODE END PD */
|
||||||
|
|
||||||
/* USER CODE END PM */
|
/* Private macro -------------------------------------------------------------*/
|
||||||
|
/* USER CODE BEGIN PM */
|
||||||
/* Private variables ---------------------------------------------------------*/
|
|
||||||
|
/* USER CODE END PM */
|
||||||
/* USER CODE BEGIN PV */
|
|
||||||
|
/* Private variables ---------------------------------------------------------*/
|
||||||
/* USER CODE END PV */
|
|
||||||
|
/* USER CODE BEGIN PV */
|
||||||
/* Private function prototypes -----------------------------------------------*/
|
|
||||||
void SystemClock_Config(void);
|
/* USER CODE END PV */
|
||||||
/* USER CODE BEGIN PFP */
|
|
||||||
|
/* Private function prototypes -----------------------------------------------*/
|
||||||
/* USER CODE END PFP */
|
void SystemClock_Config(void);
|
||||||
|
/* USER CODE BEGIN PFP */
|
||||||
/* Private user code ---------------------------------------------------------*/
|
|
||||||
/* USER CODE BEGIN 0 */
|
/* USER CODE END PFP */
|
||||||
|
|
||||||
/**
|
/* Private user code ---------------------------------------------------------*/
|
||||||
* @brief Vector base address configuration. It should no longer be at the start of
|
/* USER CODE BEGIN 0 */
|
||||||
* flash memory but moved forward because the first part of flash is
|
static void StopButtonControl(void);
|
||||||
* reserved for the bootloader. Note that this is already done by the
|
|
||||||
* bootloader before starting this program. Unfortunately, function
|
/**
|
||||||
* SystemInit() overwrites this change again.
|
* @brief Vector base address configuration. It should no longer be at the start of
|
||||||
* @return none.
|
* flash memory but moved forward because the first part of flash is
|
||||||
*/
|
* reserved for the bootloader. Note that this is already done by the
|
||||||
static void VectorBase_Config(void)
|
* bootloader before starting this program. Unfortunately, function
|
||||||
{
|
* SystemInit() overwrites this change again.
|
||||||
/* The constant array with vectors of the vector table is declared externally in the
|
* @return none.
|
||||||
* c-startup code.
|
*/
|
||||||
*/
|
static void VectorBase_Config(void)
|
||||||
extern const unsigned long g_pfnVectors[];
|
{
|
||||||
|
/* The constant array with vectors of the vector table is declared externally in the
|
||||||
/* Remap the vector table to where the vector table is located for this program. */
|
* c-startup code.
|
||||||
SCB->VTOR = (unsigned long)&g_pfnVectors[0];
|
*/
|
||||||
}
|
extern const unsigned long g_pfnVectors[];
|
||||||
|
|
||||||
uint8_t ED_TraceWarning(uint8_t flag, uint8_t id){
|
/* Remap the vector table to where the vector table is located for this program. */
|
||||||
static uint8_t memory[32];
|
SCB->VTOR = (unsigned long)&g_pfnVectors[0];
|
||||||
if(id > 31) return 0;
|
}
|
||||||
uint8_t result = 0;
|
|
||||||
if(memory[id] != flag){
|
uint8_t ED_TraceWarning(uint8_t flag, uint8_t id){
|
||||||
result = 1;
|
static uint8_t memory[32];
|
||||||
}
|
if(id > 31) return 0;
|
||||||
memory[id] = flag;
|
uint8_t result = 0;
|
||||||
return result;
|
if(memory[id] != flag){
|
||||||
}
|
result = 1;
|
||||||
|
}
|
||||||
|
memory[id] = flag;
|
||||||
void ED_Delay(uint32_t Delay)
|
return result;
|
||||||
{
|
}
|
||||||
uint32_t tickstart = HAL_GetTick();
|
|
||||||
uint32_t wait = Delay;
|
|
||||||
|
void ED_Delay(uint32_t Delay)
|
||||||
if (wait < HAL_MAX_DELAY)
|
{
|
||||||
{
|
uint32_t tickstart = HAL_GetTick();
|
||||||
wait += (uint32_t)(uwTickFreq);
|
uint32_t wait = Delay;
|
||||||
}
|
|
||||||
|
if (wait < HAL_MAX_DELAY)
|
||||||
while ((HAL_GetTick() - tickstart) < wait){
|
{
|
||||||
CCS_SerialLoop();
|
wait += (uint32_t)(uwTickFreq);
|
||||||
StopButtonControl();
|
}
|
||||||
CP_Loop();
|
|
||||||
CONN_Task();
|
while ((HAL_GetTick() - tickstart) < wait){
|
||||||
LED_Task();
|
CCS_SerialLoop();
|
||||||
SC_Task();
|
StopButtonControl();
|
||||||
}
|
CP_Loop();
|
||||||
}
|
LED_Task();
|
||||||
|
SC_Task();
|
||||||
void StopButtonControl(){
|
}
|
||||||
static uint32_t tick;
|
}
|
||||||
static uint32_t hold_time;
|
|
||||||
static uint8_t stop_btn_fault = 1;
|
static void StopButtonControl(void){
|
||||||
uint32_t now = HAL_GetTick();
|
static uint32_t tick;
|
||||||
|
static uint32_t hold_time;
|
||||||
/* Run no faster than once per 10 ms. */
|
static uint8_t stop_btn_fault = 1;
|
||||||
if((now - tick) < 10){
|
uint32_t now = HAL_GetTick();
|
||||||
return;
|
|
||||||
}
|
/* Run no faster than once per 10 ms. */
|
||||||
tick = now;
|
if((now - tick) < 10){
|
||||||
|
return;
|
||||||
uint8_t pressed = !IN_ReadInput(IN_ESTOP);
|
}
|
||||||
if(!pressed){
|
tick = now;
|
||||||
stop_btn_fault = 0;
|
|
||||||
}
|
uint8_t pressed = !IN_ReadInput(IN_ESTOP);
|
||||||
|
if(!pressed){
|
||||||
if(stop_btn_fault){
|
stop_btn_fault = 0;
|
||||||
return;
|
}
|
||||||
}
|
|
||||||
|
if(stop_btn_fault){
|
||||||
if(pressed){
|
return;
|
||||||
if(hold_time == 0){
|
}
|
||||||
CONN.connControl = CMD_STOP;
|
|
||||||
}
|
if(pressed){
|
||||||
hold_time += 10;
|
if(hold_time == 0){
|
||||||
if(hold_time == 5000){
|
CONN.connControl = CMD_STOP;
|
||||||
CONN.connControl = CMD_FORCE_UNLOCK;
|
}
|
||||||
}
|
hold_time += 10;
|
||||||
if(hold_time > 40000){
|
if(hold_time == 5000){
|
||||||
SC_SendPacket(NULL, 0, RESP_SUCCESS);
|
CONN.connControl = CMD_FORCE_UNLOCK;
|
||||||
while(huart2.gState == HAL_UART_STATE_BUSY_TX);
|
}
|
||||||
HAL_Delay(10);
|
if(hold_time > 40000){
|
||||||
NVIC_SystemReset();
|
SC_SendPacket(NULL, 0, RESP_SUCCESS);
|
||||||
}
|
while(huart2.gState == HAL_UART_STATE_BUSY_TX);
|
||||||
}
|
HAL_Delay(10);
|
||||||
else{
|
NVIC_SystemReset();
|
||||||
hold_time = 0;
|
}
|
||||||
}
|
}
|
||||||
}
|
else{
|
||||||
|
hold_time = 0;
|
||||||
uint8_t temp0, temp1;
|
}
|
||||||
|
}
|
||||||
static void CAN1_MinimalReInit(void)
|
|
||||||
{
|
static void CAN1_MinimalReInit(void)
|
||||||
HAL_CAN_Stop(&hcan1);
|
{
|
||||||
MX_CAN1_Init();
|
HAL_CAN_Stop(&hcan1);
|
||||||
if (HAL_CAN_Start(&hcan1) != HAL_OK) {
|
MX_CAN1_Init();
|
||||||
Error_Handler();
|
if (HAL_CAN_Start(&hcan1) != HAL_OK) {
|
||||||
}
|
Error_Handler();
|
||||||
if (HAL_CAN_ActivateNotification(&hcan1, CAN_IT_RX_FIFO0_MSG_PENDING) != HAL_OK) {
|
}
|
||||||
Error_Handler();
|
if (HAL_CAN_ActivateNotification(&hcan1, CAN_IT_RX_FIFO0_MSG_PENDING) != HAL_OK) {
|
||||||
}
|
Error_Handler();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
/* USER CODE END 0 */
|
|
||||||
|
/* USER CODE END 0 */
|
||||||
/**
|
|
||||||
* @brief The application entry point.
|
/**
|
||||||
* @retval int
|
* @brief The application entry point.
|
||||||
*/
|
* @retval int
|
||||||
int main(void)
|
*/
|
||||||
{
|
int main(void)
|
||||||
|
{
|
||||||
/* USER CODE BEGIN 1 */
|
|
||||||
|
/* USER CODE BEGIN 1 */
|
||||||
VectorBase_Config();
|
|
||||||
/* USER CODE END 1 */
|
VectorBase_Config();
|
||||||
|
/* USER CODE END 1 */
|
||||||
/* MCU Configuration--------------------------------------------------------*/
|
|
||||||
|
/* MCU Configuration--------------------------------------------------------*/
|
||||||
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */
|
|
||||||
HAL_Init();
|
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */
|
||||||
|
HAL_Init();
|
||||||
/* USER CODE BEGIN Init */
|
|
||||||
HAL_RCC_DeInit();
|
/* USER CODE BEGIN Init */
|
||||||
/* USER CODE END Init */
|
HAL_RCC_DeInit();
|
||||||
|
/* USER CODE END Init */
|
||||||
/* Configure the system clock */
|
|
||||||
SystemClock_Config();
|
/* Configure the system clock */
|
||||||
|
SystemClock_Config();
|
||||||
/* USER CODE BEGIN SysInit */
|
|
||||||
|
/* USER CODE BEGIN SysInit */
|
||||||
/* USER CODE END SysInit */
|
|
||||||
|
/* USER CODE END SysInit */
|
||||||
/* Initialize all configured peripherals */
|
|
||||||
MX_GPIO_Init();
|
/* Initialize all configured peripherals */
|
||||||
MX_DMA_Init();
|
MX_GPIO_Init();
|
||||||
MX_ADC1_Init();
|
MX_DMA_Init();
|
||||||
MX_CAN1_Init();
|
MX_ADC1_Init();
|
||||||
MX_CAN2_Init();
|
MX_CAN1_Init();
|
||||||
MX_RTC_Init();
|
MX_CAN2_Init();
|
||||||
MX_TIM4_Init();
|
MX_RTC_Init();
|
||||||
MX_USART2_UART_Init();
|
MX_TIM4_Init();
|
||||||
MX_CRC_Init();
|
MX_USART2_UART_Init();
|
||||||
MX_UART5_Init();
|
MX_CRC_Init();
|
||||||
MX_USART1_UART_Init();
|
MX_UART5_Init();
|
||||||
MX_USART3_UART_Init();
|
MX_USART1_UART_Init();
|
||||||
MX_TIM3_Init();
|
MX_USART3_UART_Init();
|
||||||
/* USER CODE BEGIN 2 */
|
MX_TIM3_Init();
|
||||||
Init_Peripheral();
|
/* USER CODE BEGIN 2 */
|
||||||
LED_Init();
|
Init_Peripheral();
|
||||||
|
LED_Init();
|
||||||
HAL_Delay(300);
|
|
||||||
CCS_Init();
|
HAL_Delay(300);
|
||||||
SC_Init();
|
CCS_Init();
|
||||||
log_printf(LOG_INFO, "CCS module start\n");
|
SC_Init();
|
||||||
ReadVersion();
|
log_printf(LOG_INFO, "CCS module start\n");
|
||||||
log_printf(LOG_INFO, "Serial number: %d\n", infoPacket.serialNumber);
|
ReadVersion();
|
||||||
log_printf(LOG_INFO, "Board revision: %d\n", infoPacket.boardVersion);
|
log_printf(LOG_INFO, "Serial number: %d\n", infoPacket.serialNumber);
|
||||||
log_printf(LOG_INFO, "FW version: %d.%d.%d\n", infoPacket.fw_version_major, infoPacket.fw_version_minor, infoPacket.fw_version_patch);
|
log_printf(LOG_INFO, "Board revision: %d\n", infoPacket.boardVersion);
|
||||||
CAN1_MinimalReInit();
|
log_printf(LOG_INFO, "FW version: %d.%d.%d\n", infoPacket.fw_version_major, infoPacket.fw_version_minor, infoPacket.fw_version_patch);
|
||||||
PSU_Init();
|
CAN1_MinimalReInit();
|
||||||
CONN_Init();
|
PSU_Init();
|
||||||
|
CONN_Init();
|
||||||
/* USER CODE END 2 */
|
|
||||||
|
/* USER CODE END 2 */
|
||||||
/* Infinite loop */
|
|
||||||
/* USER CODE BEGIN WHILE */
|
/* Infinite loop */
|
||||||
while (1)
|
/* USER CODE BEGIN WHILE */
|
||||||
{
|
while (1)
|
||||||
/* USER CODE END WHILE */
|
{
|
||||||
|
/* USER CODE END WHILE */
|
||||||
/* USER CODE BEGIN 3 */
|
|
||||||
|
/* USER CODE BEGIN 3 */
|
||||||
|
|
||||||
PSU_ReadWrite();
|
|
||||||
PSU_Task();
|
PSU_ReadWrite();
|
||||||
ED_Delay(10);
|
PSU_Task();
|
||||||
METER_CalculateEnergy();
|
ED_Delay(10);
|
||||||
CONN_Loop();
|
METER_CalculateEnergy();
|
||||||
LED_Write();
|
CONN_Loop();
|
||||||
ED_Delay(10);
|
LED_Write();
|
||||||
|
ED_Delay(10);
|
||||||
}
|
|
||||||
/* USER CODE END 3 */
|
}
|
||||||
}
|
/* USER CODE END 3 */
|
||||||
|
}
|
||||||
/**
|
|
||||||
* @brief System Clock Configuration
|
/**
|
||||||
* @retval None
|
* @brief System Clock Configuration
|
||||||
*/
|
* @retval None
|
||||||
void SystemClock_Config(void)
|
*/
|
||||||
{
|
void SystemClock_Config(void)
|
||||||
RCC_OscInitTypeDef RCC_OscInitStruct = {0};
|
{
|
||||||
RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
|
RCC_OscInitTypeDef RCC_OscInitStruct = {0};
|
||||||
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
|
||||||
|
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
||||||
/** Initializes the RCC Oscillators according to the specified parameters
|
|
||||||
* in the RCC_OscInitTypeDef structure.
|
/** Initializes the RCC Oscillators according to the specified parameters
|
||||||
*/
|
* in the RCC_OscInitTypeDef structure.
|
||||||
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE|RCC_OSCILLATORTYPE_LSE;
|
*/
|
||||||
RCC_OscInitStruct.HSEState = RCC_HSE_ON;
|
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE|RCC_OSCILLATORTYPE_LSE;
|
||||||
RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV5;
|
RCC_OscInitStruct.HSEState = RCC_HSE_ON;
|
||||||
RCC_OscInitStruct.LSEState = RCC_LSE_ON;
|
RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV5;
|
||||||
RCC_OscInitStruct.HSIState = RCC_HSI_ON;
|
RCC_OscInitStruct.LSEState = RCC_LSE_ON;
|
||||||
RCC_OscInitStruct.Prediv1Source = RCC_PREDIV1_SOURCE_PLL2;
|
RCC_OscInitStruct.HSIState = RCC_HSI_ON;
|
||||||
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
|
RCC_OscInitStruct.Prediv1Source = RCC_PREDIV1_SOURCE_PLL2;
|
||||||
RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
|
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
|
||||||
RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
|
RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
|
||||||
RCC_OscInitStruct.PLL2.PLL2State = RCC_PLL2_ON;
|
RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
|
||||||
RCC_OscInitStruct.PLL2.PLL2MUL = RCC_PLL2_MUL8;
|
RCC_OscInitStruct.PLL2.PLL2State = RCC_PLL2_ON;
|
||||||
RCC_OscInitStruct.PLL2.HSEPrediv2Value = RCC_HSE_PREDIV2_DIV5;
|
RCC_OscInitStruct.PLL2.PLL2MUL = RCC_PLL2_MUL8;
|
||||||
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
|
RCC_OscInitStruct.PLL2.HSEPrediv2Value = RCC_HSE_PREDIV2_DIV5;
|
||||||
{
|
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
|
||||||
Error_Handler();
|
{
|
||||||
}
|
Error_Handler();
|
||||||
|
}
|
||||||
/** Initializes the CPU, AHB and APB buses clocks
|
|
||||||
*/
|
/** Initializes the CPU, AHB and APB buses clocks
|
||||||
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|
*/
|
||||||
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
|
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|
||||||
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
|
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
|
||||||
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
|
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
|
||||||
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
|
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
|
||||||
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
|
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
|
||||||
|
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
|
||||||
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
|
|
||||||
{
|
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
|
||||||
Error_Handler();
|
{
|
||||||
}
|
Error_Handler();
|
||||||
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_RTC|RCC_PERIPHCLK_ADC;
|
}
|
||||||
PeriphClkInit.RTCClockSelection = RCC_RTCCLKSOURCE_LSE;
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_RTC|RCC_PERIPHCLK_ADC;
|
||||||
PeriphClkInit.AdcClockSelection = RCC_ADCPCLK2_DIV6;
|
PeriphClkInit.RTCClockSelection = RCC_RTCCLKSOURCE_LSE;
|
||||||
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
PeriphClkInit.AdcClockSelection = RCC_ADCPCLK2_DIV6;
|
||||||
{
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
||||||
Error_Handler();
|
{
|
||||||
}
|
Error_Handler();
|
||||||
|
}
|
||||||
/** Configure the Systick interrupt time
|
|
||||||
*/
|
/** Configure the Systick interrupt time
|
||||||
__HAL_RCC_PLLI2S_ENABLE();
|
*/
|
||||||
}
|
__HAL_RCC_PLLI2S_ENABLE();
|
||||||
|
}
|
||||||
/* USER CODE BEGIN 4 */
|
|
||||||
|
/* USER CODE BEGIN 4 */
|
||||||
/* USER CODE END 4 */
|
|
||||||
|
/* USER CODE END 4 */
|
||||||
/**
|
|
||||||
* @brief This function is executed in case of error occurrence.
|
/**
|
||||||
* @retval None
|
* @brief This function is executed in case of error occurrence.
|
||||||
*/
|
* @retval None
|
||||||
void Error_Handler(void)
|
*/
|
||||||
{
|
void Error_Handler(void)
|
||||||
/* USER CODE BEGIN Error_Handler_Debug */
|
{
|
||||||
/* User can add his own implementation to report the HAL error return state */
|
/* USER CODE BEGIN Error_Handler_Debug */
|
||||||
__disable_irq();
|
/* User can add his own implementation to report the HAL error return state */
|
||||||
while (1)
|
__disable_irq();
|
||||||
{
|
while (1)
|
||||||
}
|
{
|
||||||
/* USER CODE END Error_Handler_Debug */
|
}
|
||||||
}
|
/* USER CODE END Error_Handler_Debug */
|
||||||
#ifdef USE_FULL_ASSERT
|
}
|
||||||
/**
|
#ifdef USE_FULL_ASSERT
|
||||||
* @brief Reports the name of the source file and the source line number
|
/**
|
||||||
* where the assert_param error has occurred.
|
* @brief Reports the name of the source file and the source line number
|
||||||
* @param file: pointer to the source file name
|
* where the assert_param error has occurred.
|
||||||
* @param line: assert_param error line source number
|
* @param file: pointer to the source file name
|
||||||
* @retval None
|
* @param line: assert_param error line source number
|
||||||
*/
|
* @retval None
|
||||||
void assert_failed(uint8_t *file, uint32_t line)
|
*/
|
||||||
{
|
void assert_failed(uint8_t *file, uint32_t line)
|
||||||
/* USER CODE BEGIN 6 */
|
{
|
||||||
/* User can add his own implementation to report the file name and line number,
|
/* USER CODE BEGIN 6 */
|
||||||
ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
|
/* User can add his own implementation to report the file name and line number,
|
||||||
/* USER CODE END 6 */
|
ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
|
||||||
}
|
/* USER CODE END 6 */
|
||||||
#endif /* USE_FULL_ASSERT */
|
}
|
||||||
|
#endif /* USE_FULL_ASSERT */
|
||||||
|
|||||||
+1
-9
@@ -1,13 +1,5 @@
|
|||||||
/*
|
|
||||||
* meter.c
|
|
||||||
*
|
|
||||||
* Created on: 27 сент. 2024 г.
|
|
||||||
* Author: root
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "meter.h"
|
#include "meter.h"
|
||||||
#include "charger_config.h"
|
|
||||||
#include "charger_control.h"
|
#include "charger_control.h"
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
+8
-15
@@ -1,14 +1,13 @@
|
|||||||
|
#include "psu_control.h"
|
||||||
|
|
||||||
#include <psu_control.h>
|
#include "board.h"
|
||||||
|
|
||||||
#include "can.h"
|
#include "can.h"
|
||||||
#include "string.h"
|
|
||||||
#include "stdio.h"
|
|
||||||
#include "charger_config.h"
|
#include "charger_config.h"
|
||||||
#include "charger_control.h"
|
#include "charger_control.h"
|
||||||
#include "board.h"
|
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "isr_opt.h"
|
#include "isr_opt.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
PSU_02_t PSU_02;
|
PSU_02_t PSU_02;
|
||||||
PSU_04_t PSU_04;
|
PSU_04_t PSU_04;
|
||||||
@@ -31,6 +30,8 @@ uint32_t can_lastpacket;
|
|||||||
|
|
||||||
extern CAN_HandleTypeDef hcan2;
|
extern CAN_HandleTypeDef hcan2;
|
||||||
|
|
||||||
|
static void PSU_SendCmd(uint8_t source, uint8_t destination, uint8_t cmd, void *data);
|
||||||
|
|
||||||
static void PSU_SwitchState(PSU_State_t state){
|
static void PSU_SwitchState(PSU_State_t state){
|
||||||
PSU0.state = state;
|
PSU0.state = state;
|
||||||
PSU0.statetick = HAL_GetTick();
|
PSU0.statetick = HAL_GetTick();
|
||||||
@@ -227,7 +228,6 @@ void PSU_SendCmd(uint8_t source, uint8_t destination, uint8_t cmd, void *data){
|
|||||||
/* если отправка удалась, выход */
|
/* если отправка удалась, выход */
|
||||||
if(CAN_result == HAL_OK) {
|
if(CAN_result == HAL_OK) {
|
||||||
return;
|
return;
|
||||||
retry_counter = 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ED_Delay(1);
|
ED_Delay(1);
|
||||||
@@ -237,11 +237,6 @@ void PSU_SendCmd(uint8_t source, uint8_t destination, uint8_t cmd, void *data){
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t max(uint32_t a, uint32_t b){
|
|
||||||
if(a>b) return a;
|
|
||||||
else return b;
|
|
||||||
}
|
|
||||||
|
|
||||||
void PSU_ReadWrite(){
|
void PSU_ReadWrite(){
|
||||||
|
|
||||||
uint8_t zero_data[8] = {0,0,0,0,0,0,0,0};
|
uint8_t zero_data[8] = {0,0,0,0,0,0,0,0};
|
||||||
@@ -264,8 +259,8 @@ void PSU_ReadWrite(){
|
|||||||
CONN.RequestedPower = CONN.RequestedCurrent * CONN.RequestedVoltage / 10;
|
CONN.RequestedPower = CONN.RequestedCurrent * CONN.RequestedVoltage / 10;
|
||||||
|
|
||||||
if(PSU0.ready){
|
if(PSU0.ready){
|
||||||
if (CONN.RequestedVoltage == 500) { // fake
|
if (CONN.RequestedVoltage == FAKE_EVREQ_VOLTAGE_V) {
|
||||||
PSU_SetVoltageCurrent(0, 300, 10); // Normal mode
|
PSU_SetVoltageCurrent(0, (uint16_t)FAKE_PSU_VOLTAGE_V, (uint16_t)FAKE_PSU_CURRENT_0P1A);
|
||||||
}else{
|
}else{
|
||||||
PSU_SetVoltageCurrent(0, CONN.RequestedVoltage, CONN.RequestedCurrent); // Normal mode
|
PSU_SetVoltageCurrent(0, CONN.RequestedVoltage, CONN.RequestedCurrent); // Normal mode
|
||||||
}
|
}
|
||||||
@@ -288,7 +283,6 @@ void PSU_ReadWrite(){
|
|||||||
|
|
||||||
void PSU_Task(void){
|
void PSU_Task(void){
|
||||||
static uint32_t psu_on_tick = 0;
|
static uint32_t psu_on_tick = 0;
|
||||||
static uint32_t dc_on_tick = 0;
|
|
||||||
static uint32_t cont_ok_tick = 0;
|
static uint32_t cont_ok_tick = 0;
|
||||||
|
|
||||||
// Обновляем ONLINE/READY по таймауту
|
// Обновляем ONLINE/READY по таймауту
|
||||||
@@ -368,7 +362,6 @@ void PSU_Task(void){
|
|||||||
case PSU_WAIT_ACK_ON:
|
case PSU_WAIT_ACK_ON:
|
||||||
|
|
||||||
if(PSU0.PSU_enabled && PSU0.ready){
|
if(PSU0.PSU_enabled && PSU0.ready){
|
||||||
dc_on_tick = HAL_GetTick();
|
|
||||||
PSU_SwitchState(PSU_CONT_WAIT_ACK_ON);
|
PSU_SwitchState(PSU_CONT_WAIT_ACK_ON);
|
||||||
}else if(PSU_StateTime() > 10000){
|
}else if(PSU_StateTime() > 10000){
|
||||||
PSU0.psu_fault = 1;
|
PSU0.psu_fault = 1;
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
#include "rgb_controller.h"
|
#include "rgb_controller.h"
|
||||||
#include "main.h"
|
|
||||||
#include "string.h"
|
|
||||||
#include "charger_control.h"
|
|
||||||
#include "board.h"
|
|
||||||
|
|
||||||
|
#include "board.h"
|
||||||
|
#include "charger_control.h"
|
||||||
|
#include "main.h"
|
||||||
#include "tim.h"
|
#include "tim.h"
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
RGB_State_t LED_State;
|
RGB_State_t LED_State;
|
||||||
RGB_Cycle_t LED_Cycle;
|
RGB_Cycle_t LED_Cycle;
|
||||||
@@ -198,36 +198,11 @@ void LED_Init(){
|
|||||||
RGB_SetColor(&color);
|
RGB_SetColor(&color);
|
||||||
}
|
}
|
||||||
|
|
||||||
// void LED_PhaseSync(uint8_t led_n){
|
|
||||||
// if(LED_State[led_n].phasesync){
|
|
||||||
// LED_State[led_n].phasesync = 0;
|
|
||||||
// //default settings
|
|
||||||
// LED_State[led_n].state = LED_HIGH;
|
|
||||||
// LED_State[led_n].tick = 0;
|
|
||||||
// //ищем среди всех светодиодов такую же последовательность
|
|
||||||
// for (uint8_t led_n1 = 0; led_n1 < 5; led_n1++){
|
|
||||||
// if ((LED_Cycle[led_n].Tf == LED_Cycle[led_n1].Tf) &&
|
|
||||||
// (LED_Cycle[led_n].Tr == LED_Cycle[led_n1].Tr) &&
|
|
||||||
// (LED_Cycle[led_n].Th == LED_Cycle[led_n1].Th) &&
|
|
||||||
// (LED_Cycle[led_n].Tl == LED_Cycle[led_n1].Tl) &&
|
|
||||||
// (led_n != led_n1)){
|
|
||||||
// //если нашли, то копируем фазу оттуда
|
|
||||||
// LED_State[led_n].state = LED_State[led_n1].state;
|
|
||||||
// LED_State[led_n].tick = LED_State[led_n1].tick;
|
|
||||||
// return;
|
|
||||||
|
|
||||||
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
void LED_Task(){
|
void LED_Task(){
|
||||||
static uint32_t led_tick;
|
static uint32_t led_tick;
|
||||||
if((HAL_GetTick() - led_tick) > 20){
|
if((HAL_GetTick() - led_tick) > 20){
|
||||||
led_tick = HAL_GetTick();
|
led_tick = HAL_GetTick();
|
||||||
LED_State.tick++;
|
LED_State.tick++;
|
||||||
// LED_PhaseSync(led_n);
|
|
||||||
switch(LED_State.state){
|
switch(LED_State.state){
|
||||||
case LED_RISING:
|
case LED_RISING:
|
||||||
interpolateColors(&LED_Cycle.Color2, &LED_Cycle.Color1, LED_State.tick, LED_Cycle.Tr, &LED_State.color);
|
interpolateColors(&LED_Cycle.Color2, &LED_Cycle.Color1, LED_State.tick, LED_Cycle.Tr, &LED_State.color);
|
||||||
|
|||||||
+6
-11
@@ -1,14 +1,15 @@
|
|||||||
#include "serial.h"
|
#include "serial.h"
|
||||||
#include "cp.h"
|
|
||||||
#include "connector.h"
|
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
|
#include "charger_config.h"
|
||||||
|
#include "connector.h"
|
||||||
|
#include "cp.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "isr_opt.h"
|
#include "isr_opt.h"
|
||||||
#include <stdint.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include "charger_config.h"
|
|
||||||
#include "psu_control.h"
|
#include "psu_control.h"
|
||||||
#include "serial_control.h"
|
#include "serial_control.h"
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
extern UART_HandleTypeDef huart3;
|
extern UART_HandleTypeDef huart3;
|
||||||
extern uint8_t config_initialized;
|
extern uint8_t config_initialized;
|
||||||
@@ -28,15 +29,9 @@ CONN_Control_t last_cmd = CMD_NONE;
|
|||||||
uint8_t ev_enable_output = 0;
|
uint8_t ev_enable_output = 0;
|
||||||
|
|
||||||
#define CMD_INTERVAL 10
|
#define CMD_INTERVAL 10
|
||||||
#define MAX_TX_BUFFER_SIZE 256
|
|
||||||
#define MAX_RX_BUFFER_SIZE 256
|
|
||||||
#define EVEREST_TIMEOUT_WARN_MS 5000u
|
#define EVEREST_TIMEOUT_WARN_MS 5000u
|
||||||
#define EVEREST_TIMEOUT_STOP_MS 10000u
|
#define EVEREST_TIMEOUT_STOP_MS 10000u
|
||||||
#define UART3_REINIT_TIMEOUT_MS 1500u
|
#define UART3_REINIT_TIMEOUT_MS 1500u
|
||||||
/* Everest requests 500 V -> PSU really gets 300 V / 1 A, state still reports 500 V. */
|
|
||||||
#define FAKE_EVREQ_VOLTAGE_V 500u
|
|
||||||
#define FAKE_PSU_VOLTAGE_V 300u
|
|
||||||
#define FAKE_PSU_CURRENT_0P1A 10u
|
|
||||||
|
|
||||||
static uint8_t rx_buffer[MAX_RX_BUFFER_SIZE];
|
static uint8_t rx_buffer[MAX_RX_BUFFER_SIZE];
|
||||||
static uint8_t tx_buffer[MAX_TX_BUFFER_SIZE];
|
static uint8_t tx_buffer[MAX_TX_BUFFER_SIZE];
|
||||||
|
|||||||
@@ -1,9 +1,10 @@
|
|||||||
#include "serial_control.h"
|
#include "serial_control.h"
|
||||||
#include "usart.h"
|
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "serial.h"
|
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "isr_opt.h"
|
#include "isr_opt.h"
|
||||||
|
#include "serial.h"
|
||||||
|
#include "usart.h"
|
||||||
|
|
||||||
// Приватные функции
|
// Приватные функции
|
||||||
ISR_FAST static uint32_t calculate_crc32(const uint8_t* data, uint16_t length);
|
ISR_FAST static uint32_t calculate_crc32(const uint8_t* data, uint16_t length);
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
#include "serial_control.h"
|
#include "serial_control.h"
|
||||||
#include "usart.h"
|
|
||||||
#include "charger_control.h"
|
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "psu_control.h"
|
#include "charger_control.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
#include "psu_control.h"
|
||||||
|
#include "usart.h"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#ifdef USE_WEB_INTERFACE
|
|
||||||
|
|
||||||
extern volatile SC_Source_t g_sc_command_source;
|
extern volatile SC_Source_t g_sc_command_source;
|
||||||
|
static void monitoring_data_callback(void);
|
||||||
|
|
||||||
IsolationStatusPacket_t ISO = {
|
IsolationStatusPacket_t ISO = {
|
||||||
.isolationResistance = 0xFFFF
|
.isolationResistance = 0xFFFF
|
||||||
@@ -122,7 +122,7 @@ void SC_CommandHandler(ReceivedCommand_t* cmd) {
|
|||||||
|
|
||||||
|
|
||||||
// Колбэк для заполнения данных мониторинга
|
// Колбэк для заполнения данных мониторинга
|
||||||
void monitoring_data_callback() {
|
static void monitoring_data_callback(void) {
|
||||||
|
|
||||||
// Информация о зарядной сессии
|
// Информация о зарядной сессии
|
||||||
statusPacket.SOC = CONN.SOC;
|
statusPacket.SOC = CONN.SOC;
|
||||||
@@ -202,4 +202,3 @@ void monitoring_data_callback() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|||||||
+2
-22
@@ -1,11 +1,4 @@
|
|||||||
/*
|
#include "soft_rtc.h"
|
||||||
* rtc.c
|
|
||||||
*
|
|
||||||
* Created on: Jul 22, 2024
|
|
||||||
* Author: colorbass
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <soft_rtc.h>
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
@@ -63,20 +56,7 @@ uint8_t getTimeReg(uint8_t reg_number){
|
|||||||
}else{
|
}else{
|
||||||
return 0x00;
|
return 0x00;
|
||||||
}
|
}
|
||||||
};
|
}
|
||||||
//int main() {
|
|
||||||
// uint32_t unix_time = 1672531199; // Example Unix timestamp
|
|
||||||
// uint8_t time[8];
|
|
||||||
//
|
|
||||||
// unix_to_bcd(unix_time, time);
|
|
||||||
//
|
|
||||||
// // Print the BCD values for verification
|
|
||||||
// for (int i = 0; i < 8; i++) {
|
|
||||||
// log_printf(LOG_INFO, "time[%d]: %02X\n", i, time[i]);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// return 0;
|
|
||||||
//}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Read the time counter available in RTC_CNT registers.
|
* @brief Read the time counter available in RTC_CNT registers.
|
||||||
|
|||||||
@@ -1,86 +1,70 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file stm32f1xx_hal_msp.c
|
|
||||||
* @brief This file provides code for the MSP Initialization
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* and de-Initialization codes.
|
#include "main.h"
|
||||||
******************************************************************************
|
/* USER CODE BEGIN Includes */
|
||||||
* @attention
|
|
||||||
*
|
/* USER CODE END Includes */
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
|
||||||
* All rights reserved.
|
/* Private typedef -----------------------------------------------------------*/
|
||||||
*
|
/* USER CODE BEGIN TD */
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
|
||||||
* in the root directory of this software component.
|
/* USER CODE END TD */
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
|
||||||
*
|
/* Private define ------------------------------------------------------------*/
|
||||||
******************************************************************************
|
/* USER CODE BEGIN Define */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
/* USER CODE END Define */
|
||||||
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* Private macro -------------------------------------------------------------*/
|
||||||
#include "main.h"
|
/* USER CODE BEGIN Macro */
|
||||||
/* USER CODE BEGIN Includes */
|
|
||||||
|
/* USER CODE END Macro */
|
||||||
/* USER CODE END Includes */
|
|
||||||
|
/* Private variables ---------------------------------------------------------*/
|
||||||
/* Private typedef -----------------------------------------------------------*/
|
/* USER CODE BEGIN PV */
|
||||||
/* USER CODE BEGIN TD */
|
|
||||||
|
/* USER CODE END PV */
|
||||||
/* USER CODE END TD */
|
|
||||||
|
/* Private function prototypes -----------------------------------------------*/
|
||||||
/* Private define ------------------------------------------------------------*/
|
/* USER CODE BEGIN PFP */
|
||||||
/* USER CODE BEGIN Define */
|
|
||||||
|
/* USER CODE END PFP */
|
||||||
/* USER CODE END Define */
|
|
||||||
|
/* External functions --------------------------------------------------------*/
|
||||||
/* Private macro -------------------------------------------------------------*/
|
/* USER CODE BEGIN ExternalFunctions */
|
||||||
/* USER CODE BEGIN Macro */
|
|
||||||
|
/* USER CODE END ExternalFunctions */
|
||||||
/* USER CODE END Macro */
|
|
||||||
|
/* USER CODE BEGIN 0 */
|
||||||
/* Private variables ---------------------------------------------------------*/
|
|
||||||
/* USER CODE BEGIN PV */
|
/* USER CODE END 0 */
|
||||||
|
/**
|
||||||
/* USER CODE END PV */
|
* Initializes the Global MSP.
|
||||||
|
*/
|
||||||
/* Private function prototypes -----------------------------------------------*/
|
void HAL_MspInit(void)
|
||||||
/* USER CODE BEGIN PFP */
|
{
|
||||||
|
|
||||||
/* USER CODE END PFP */
|
/* USER CODE BEGIN MspInit 0 */
|
||||||
|
|
||||||
/* External functions --------------------------------------------------------*/
|
/* USER CODE END MspInit 0 */
|
||||||
/* USER CODE BEGIN ExternalFunctions */
|
|
||||||
|
__HAL_RCC_AFIO_CLK_ENABLE();
|
||||||
/* USER CODE END ExternalFunctions */
|
__HAL_RCC_PWR_CLK_ENABLE();
|
||||||
|
|
||||||
/* USER CODE BEGIN 0 */
|
/* System interrupt init*/
|
||||||
|
|
||||||
/* USER CODE END 0 */
|
/** NOJTAG: JTAG-DP Disabled and SW-DP Enabled
|
||||||
/**
|
*/
|
||||||
* Initializes the Global MSP.
|
__HAL_AFIO_REMAP_SWJ_NOJTAG();
|
||||||
*/
|
|
||||||
void HAL_MspInit(void)
|
/* USER CODE BEGIN MspInit 1 */
|
||||||
{
|
|
||||||
|
/* USER CODE END MspInit 1 */
|
||||||
/* USER CODE BEGIN MspInit 0 */
|
}
|
||||||
|
|
||||||
/* USER CODE END MspInit 0 */
|
/* USER CODE BEGIN 1 */
|
||||||
|
|
||||||
__HAL_RCC_AFIO_CLK_ENABLE();
|
/* USER CODE END 1 */
|
||||||
__HAL_RCC_PWR_CLK_ENABLE();
|
|
||||||
|
|
||||||
/* System interrupt init*/
|
|
||||||
|
|
||||||
/** NOJTAG: JTAG-DP Disabled and SW-DP Enabled
|
|
||||||
*/
|
|
||||||
__HAL_AFIO_REMAP_SWJ_NOJTAG();
|
|
||||||
|
|
||||||
/* USER CODE BEGIN MspInit 1 */
|
|
||||||
|
|
||||||
/* USER CODE END MspInit 1 */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
|
||||||
|
|||||||
+399
-414
@@ -1,414 +1,399 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file stm32f1xx_it.c
|
|
||||||
* @brief Interrupt Service Routines.
|
/* Includes ------------------------------------------------------------------*/
|
||||||
******************************************************************************
|
#include "main.h"
|
||||||
* @attention
|
#include "stm32f1xx_it.h"
|
||||||
*
|
/* Private includes ----------------------------------------------------------*/
|
||||||
* Copyright (c) 2024 STMicroelectronics.
|
/* USER CODE BEGIN Includes */
|
||||||
* All rights reserved.
|
#if defined(__GNUC__)
|
||||||
*
|
#pragma GCC optimize("Ofast")
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
#endif
|
||||||
* in the root directory of this software component.
|
/* USER CODE END Includes */
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
|
||||||
*
|
/* Private typedef -----------------------------------------------------------*/
|
||||||
******************************************************************************
|
/* USER CODE BEGIN TD */
|
||||||
*/
|
|
||||||
/* USER CODE END Header */
|
/* USER CODE END TD */
|
||||||
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* Private define ------------------------------------------------------------*/
|
||||||
#include "main.h"
|
/* USER CODE BEGIN PD */
|
||||||
#include "stm32f1xx_it.h"
|
|
||||||
/* Private includes ----------------------------------------------------------*/
|
/* USER CODE END PD */
|
||||||
/* USER CODE BEGIN Includes */
|
|
||||||
#if defined(__GNUC__)
|
/* Private macro -------------------------------------------------------------*/
|
||||||
#pragma GCC optimize("Ofast")
|
/* USER CODE BEGIN PM */
|
||||||
#endif
|
|
||||||
/* USER CODE END Includes */
|
/* USER CODE END PM */
|
||||||
|
|
||||||
/* Private typedef -----------------------------------------------------------*/
|
/* Private variables ---------------------------------------------------------*/
|
||||||
/* USER CODE BEGIN TD */
|
/* USER CODE BEGIN PV */
|
||||||
|
|
||||||
/* USER CODE END TD */
|
/* USER CODE END PV */
|
||||||
|
|
||||||
/* Private define ------------------------------------------------------------*/
|
/* Private function prototypes -----------------------------------------------*/
|
||||||
/* USER CODE BEGIN PD */
|
/* USER CODE BEGIN PFP */
|
||||||
|
|
||||||
/* USER CODE END PD */
|
/* USER CODE END PFP */
|
||||||
|
|
||||||
/* Private macro -------------------------------------------------------------*/
|
/* Private user code ---------------------------------------------------------*/
|
||||||
/* USER CODE BEGIN PM */
|
/* USER CODE BEGIN 0 */
|
||||||
|
|
||||||
/* USER CODE END PM */
|
/* USER CODE END 0 */
|
||||||
|
|
||||||
/* Private variables ---------------------------------------------------------*/
|
/* External variables --------------------------------------------------------*/
|
||||||
/* USER CODE BEGIN PV */
|
extern DMA_HandleTypeDef hdma_adc1;
|
||||||
|
extern ADC_HandleTypeDef hadc1;
|
||||||
/* USER CODE END PV */
|
extern CAN_HandleTypeDef hcan1;
|
||||||
|
extern CAN_HandleTypeDef hcan2;
|
||||||
/* Private function prototypes -----------------------------------------------*/
|
extern TIM_HandleTypeDef htim3;
|
||||||
/* USER CODE BEGIN PFP */
|
extern DMA_HandleTypeDef hdma_usart2_rx;
|
||||||
|
extern DMA_HandleTypeDef hdma_usart2_tx;
|
||||||
/* USER CODE END PFP */
|
extern DMA_HandleTypeDef hdma_usart3_rx;
|
||||||
|
extern DMA_HandleTypeDef hdma_usart3_tx;
|
||||||
/* Private user code ---------------------------------------------------------*/
|
extern UART_HandleTypeDef huart5;
|
||||||
/* USER CODE BEGIN 0 */
|
extern UART_HandleTypeDef huart1;
|
||||||
|
extern UART_HandleTypeDef huart2;
|
||||||
/* USER CODE END 0 */
|
extern UART_HandleTypeDef huart3;
|
||||||
|
/* USER CODE BEGIN EV */
|
||||||
/* External variables --------------------------------------------------------*/
|
|
||||||
extern DMA_HandleTypeDef hdma_adc1;
|
/* USER CODE END EV */
|
||||||
extern ADC_HandleTypeDef hadc1;
|
|
||||||
extern CAN_HandleTypeDef hcan1;
|
/******************************************************************************/
|
||||||
extern CAN_HandleTypeDef hcan2;
|
/* Cortex-M3 Processor Interruption and Exception Handlers */
|
||||||
extern TIM_HandleTypeDef htim3;
|
/******************************************************************************/
|
||||||
extern DMA_HandleTypeDef hdma_usart2_rx;
|
/**
|
||||||
extern DMA_HandleTypeDef hdma_usart2_tx;
|
* @brief This function handles Non maskable interrupt.
|
||||||
extern DMA_HandleTypeDef hdma_usart3_rx;
|
*/
|
||||||
extern DMA_HandleTypeDef hdma_usart3_tx;
|
void NMI_Handler(void)
|
||||||
extern UART_HandleTypeDef huart5;
|
{
|
||||||
extern UART_HandleTypeDef huart1;
|
/* USER CODE BEGIN NonMaskableInt_IRQn 0 */
|
||||||
extern UART_HandleTypeDef huart2;
|
|
||||||
extern UART_HandleTypeDef huart3;
|
/* USER CODE END NonMaskableInt_IRQn 0 */
|
||||||
/* USER CODE BEGIN EV */
|
/* USER CODE BEGIN NonMaskableInt_IRQn 1 */
|
||||||
|
while (1)
|
||||||
/* USER CODE END EV */
|
{
|
||||||
|
}
|
||||||
/******************************************************************************/
|
/* USER CODE END NonMaskableInt_IRQn 1 */
|
||||||
/* Cortex-M3 Processor Interruption and Exception Handlers */
|
}
|
||||||
/******************************************************************************/
|
|
||||||
/**
|
/**
|
||||||
* @brief This function handles Non maskable interrupt.
|
* @brief This function handles Hard fault interrupt.
|
||||||
*/
|
*/
|
||||||
void NMI_Handler(void)
|
void HardFault_Handler(void)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN NonMaskableInt_IRQn 0 */
|
/* USER CODE BEGIN HardFault_IRQn 0 */
|
||||||
|
|
||||||
/* USER CODE END NonMaskableInt_IRQn 0 */
|
/* USER CODE END HardFault_IRQn 0 */
|
||||||
/* USER CODE BEGIN NonMaskableInt_IRQn 1 */
|
while (1)
|
||||||
while (1)
|
{
|
||||||
{
|
/* USER CODE BEGIN W1_HardFault_IRQn 0 */
|
||||||
}
|
/* USER CODE END W1_HardFault_IRQn 0 */
|
||||||
/* USER CODE END NonMaskableInt_IRQn 1 */
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function handles Hard fault interrupt.
|
* @brief This function handles Memory management fault.
|
||||||
*/
|
*/
|
||||||
void HardFault_Handler(void)
|
void MemManage_Handler(void)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN HardFault_IRQn 0 */
|
/* USER CODE BEGIN MemoryManagement_IRQn 0 */
|
||||||
|
|
||||||
/* USER CODE END HardFault_IRQn 0 */
|
/* USER CODE END MemoryManagement_IRQn 0 */
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN W1_HardFault_IRQn 0 */
|
/* USER CODE BEGIN W1_MemoryManagement_IRQn 0 */
|
||||||
/* USER CODE END W1_HardFault_IRQn 0 */
|
/* USER CODE END W1_MemoryManagement_IRQn 0 */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function handles Memory management fault.
|
* @brief This function handles Prefetch fault, memory access fault.
|
||||||
*/
|
*/
|
||||||
void MemManage_Handler(void)
|
void BusFault_Handler(void)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN MemoryManagement_IRQn 0 */
|
/* USER CODE BEGIN BusFault_IRQn 0 */
|
||||||
|
|
||||||
/* USER CODE END MemoryManagement_IRQn 0 */
|
/* USER CODE END BusFault_IRQn 0 */
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN W1_MemoryManagement_IRQn 0 */
|
/* USER CODE BEGIN W1_BusFault_IRQn 0 */
|
||||||
/* USER CODE END W1_MemoryManagement_IRQn 0 */
|
/* USER CODE END W1_BusFault_IRQn 0 */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function handles Prefetch fault, memory access fault.
|
* @brief This function handles Undefined instruction or illegal state.
|
||||||
*/
|
*/
|
||||||
void BusFault_Handler(void)
|
void UsageFault_Handler(void)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN BusFault_IRQn 0 */
|
/* USER CODE BEGIN UsageFault_IRQn 0 */
|
||||||
|
|
||||||
/* USER CODE END BusFault_IRQn 0 */
|
/* USER CODE END UsageFault_IRQn 0 */
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN W1_BusFault_IRQn 0 */
|
/* USER CODE BEGIN W1_UsageFault_IRQn 0 */
|
||||||
/* USER CODE END W1_BusFault_IRQn 0 */
|
/* USER CODE END W1_UsageFault_IRQn 0 */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function handles Undefined instruction or illegal state.
|
* @brief This function handles System service call via SWI instruction.
|
||||||
*/
|
*/
|
||||||
void UsageFault_Handler(void)
|
void SVC_Handler(void)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN UsageFault_IRQn 0 */
|
/* USER CODE BEGIN SVCall_IRQn 0 */
|
||||||
|
|
||||||
/* USER CODE END UsageFault_IRQn 0 */
|
/* USER CODE END SVCall_IRQn 0 */
|
||||||
while (1)
|
/* USER CODE BEGIN SVCall_IRQn 1 */
|
||||||
{
|
|
||||||
/* USER CODE BEGIN W1_UsageFault_IRQn 0 */
|
/* USER CODE END SVCall_IRQn 1 */
|
||||||
/* USER CODE END W1_UsageFault_IRQn 0 */
|
}
|
||||||
}
|
|
||||||
}
|
/**
|
||||||
|
* @brief This function handles Debug monitor.
|
||||||
/**
|
*/
|
||||||
* @brief This function handles System service call via SWI instruction.
|
void DebugMon_Handler(void)
|
||||||
*/
|
{
|
||||||
void SVC_Handler(void)
|
/* USER CODE BEGIN DebugMonitor_IRQn 0 */
|
||||||
{
|
|
||||||
/* USER CODE BEGIN SVCall_IRQn 0 */
|
/* USER CODE END DebugMonitor_IRQn 0 */
|
||||||
|
/* USER CODE BEGIN DebugMonitor_IRQn 1 */
|
||||||
/* USER CODE END SVCall_IRQn 0 */
|
|
||||||
/* USER CODE BEGIN SVCall_IRQn 1 */
|
/* USER CODE END DebugMonitor_IRQn 1 */
|
||||||
|
}
|
||||||
/* USER CODE END SVCall_IRQn 1 */
|
|
||||||
}
|
/**
|
||||||
|
* @brief This function handles Pendable request for system service.
|
||||||
/**
|
*/
|
||||||
* @brief This function handles Debug monitor.
|
void PendSV_Handler(void)
|
||||||
*/
|
{
|
||||||
void DebugMon_Handler(void)
|
/* USER CODE BEGIN PendSV_IRQn 0 */
|
||||||
{
|
|
||||||
/* USER CODE BEGIN DebugMonitor_IRQn 0 */
|
/* USER CODE END PendSV_IRQn 0 */
|
||||||
|
/* USER CODE BEGIN PendSV_IRQn 1 */
|
||||||
/* USER CODE END DebugMonitor_IRQn 0 */
|
|
||||||
/* USER CODE BEGIN DebugMonitor_IRQn 1 */
|
/* USER CODE END PendSV_IRQn 1 */
|
||||||
|
}
|
||||||
/* USER CODE END DebugMonitor_IRQn 1 */
|
|
||||||
}
|
/**
|
||||||
|
* @brief This function handles System tick timer.
|
||||||
/**
|
*/
|
||||||
* @brief This function handles Pendable request for system service.
|
void SysTick_Handler(void)
|
||||||
*/
|
{
|
||||||
void PendSV_Handler(void)
|
/* USER CODE BEGIN SysTick_IRQn 0 */
|
||||||
{
|
|
||||||
/* USER CODE BEGIN PendSV_IRQn 0 */
|
/* USER CODE END SysTick_IRQn 0 */
|
||||||
|
HAL_IncTick();
|
||||||
/* USER CODE END PendSV_IRQn 0 */
|
/* USER CODE BEGIN SysTick_IRQn 1 */
|
||||||
/* USER CODE BEGIN PendSV_IRQn 1 */
|
|
||||||
|
/* USER CODE END SysTick_IRQn 1 */
|
||||||
/* USER CODE END PendSV_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/******************************************************************************/
|
||||||
/**
|
/* STM32F1xx Peripheral Interrupt Handlers */
|
||||||
* @brief This function handles System tick timer.
|
/* Add here the Interrupt Handlers for the used peripherals. */
|
||||||
*/
|
/* For the available peripheral interrupt handler names, */
|
||||||
void SysTick_Handler(void)
|
/* please refer to the startup file (startup_stm32f1xx.s). */
|
||||||
{
|
/******************************************************************************/
|
||||||
/* USER CODE BEGIN SysTick_IRQn 0 */
|
|
||||||
|
/**
|
||||||
/* USER CODE END SysTick_IRQn 0 */
|
* @brief This function handles DMA1 channel1 global interrupt.
|
||||||
HAL_IncTick();
|
*/
|
||||||
/* USER CODE BEGIN SysTick_IRQn 1 */
|
void DMA1_Channel1_IRQHandler(void)
|
||||||
|
{
|
||||||
/* USER CODE END SysTick_IRQn 1 */
|
/* USER CODE BEGIN DMA1_Channel1_IRQn 0 */
|
||||||
}
|
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_SET);
|
||||||
|
/* USER CODE END DMA1_Channel1_IRQn 0 */
|
||||||
/******************************************************************************/
|
HAL_DMA_IRQHandler(&hdma_adc1);
|
||||||
/* STM32F1xx Peripheral Interrupt Handlers */
|
/* USER CODE BEGIN DMA1_Channel1_IRQn 1 */
|
||||||
/* Add here the Interrupt Handlers for the used peripherals. */
|
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_RESET);
|
||||||
/* For the available peripheral interrupt handler names, */
|
/* USER CODE END DMA1_Channel1_IRQn 1 */
|
||||||
/* please refer to the startup file (startup_stm32f1xx.s). */
|
}
|
||||||
/******************************************************************************/
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles DMA1 channel2 global interrupt.
|
||||||
* @brief This function handles DMA1 channel1 global interrupt.
|
*/
|
||||||
*/
|
void DMA1_Channel2_IRQHandler(void)
|
||||||
void DMA1_Channel1_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN DMA1_Channel2_IRQn 0 */
|
||||||
/* USER CODE BEGIN DMA1_Channel1_IRQn 0 */
|
|
||||||
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_SET);
|
/* USER CODE END DMA1_Channel2_IRQn 0 */
|
||||||
/* USER CODE END DMA1_Channel1_IRQn 0 */
|
HAL_DMA_IRQHandler(&hdma_usart3_tx);
|
||||||
HAL_DMA_IRQHandler(&hdma_adc1);
|
/* USER CODE BEGIN DMA1_Channel2_IRQn 1 */
|
||||||
/* USER CODE BEGIN DMA1_Channel1_IRQn 1 */
|
|
||||||
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_RESET);
|
/* USER CODE END DMA1_Channel2_IRQn 1 */
|
||||||
/* USER CODE END DMA1_Channel1_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles DMA1 channel3 global interrupt.
|
||||||
* @brief This function handles DMA1 channel2 global interrupt.
|
*/
|
||||||
*/
|
void DMA1_Channel3_IRQHandler(void)
|
||||||
void DMA1_Channel2_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN DMA1_Channel3_IRQn 0 */
|
||||||
/* USER CODE BEGIN DMA1_Channel2_IRQn 0 */
|
|
||||||
|
/* USER CODE END DMA1_Channel3_IRQn 0 */
|
||||||
/* USER CODE END DMA1_Channel2_IRQn 0 */
|
HAL_DMA_IRQHandler(&hdma_usart3_rx);
|
||||||
HAL_DMA_IRQHandler(&hdma_usart3_tx);
|
/* USER CODE BEGIN DMA1_Channel3_IRQn 1 */
|
||||||
/* USER CODE BEGIN DMA1_Channel2_IRQn 1 */
|
|
||||||
|
/* USER CODE END DMA1_Channel3_IRQn 1 */
|
||||||
/* USER CODE END DMA1_Channel2_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles DMA1 channel6 global interrupt.
|
||||||
* @brief This function handles DMA1 channel3 global interrupt.
|
*/
|
||||||
*/
|
void DMA1_Channel6_IRQHandler(void)
|
||||||
void DMA1_Channel3_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN DMA1_Channel6_IRQn 0 */
|
||||||
/* USER CODE BEGIN DMA1_Channel3_IRQn 0 */
|
|
||||||
|
/* USER CODE END DMA1_Channel6_IRQn 0 */
|
||||||
/* USER CODE END DMA1_Channel3_IRQn 0 */
|
HAL_DMA_IRQHandler(&hdma_usart2_rx);
|
||||||
HAL_DMA_IRQHandler(&hdma_usart3_rx);
|
/* USER CODE BEGIN DMA1_Channel6_IRQn 1 */
|
||||||
/* USER CODE BEGIN DMA1_Channel3_IRQn 1 */
|
|
||||||
|
/* USER CODE END DMA1_Channel6_IRQn 1 */
|
||||||
/* USER CODE END DMA1_Channel3_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles DMA1 channel7 global interrupt.
|
||||||
* @brief This function handles DMA1 channel6 global interrupt.
|
*/
|
||||||
*/
|
void DMA1_Channel7_IRQHandler(void)
|
||||||
void DMA1_Channel6_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN DMA1_Channel7_IRQn 0 */
|
||||||
/* USER CODE BEGIN DMA1_Channel6_IRQn 0 */
|
|
||||||
|
/* USER CODE END DMA1_Channel7_IRQn 0 */
|
||||||
/* USER CODE END DMA1_Channel6_IRQn 0 */
|
HAL_DMA_IRQHandler(&hdma_usart2_tx);
|
||||||
HAL_DMA_IRQHandler(&hdma_usart2_rx);
|
/* USER CODE BEGIN DMA1_Channel7_IRQn 1 */
|
||||||
/* USER CODE BEGIN DMA1_Channel6_IRQn 1 */
|
|
||||||
|
/* USER CODE END DMA1_Channel7_IRQn 1 */
|
||||||
/* USER CODE END DMA1_Channel6_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles ADC1 and ADC2 global interrupts.
|
||||||
* @brief This function handles DMA1 channel7 global interrupt.
|
*/
|
||||||
*/
|
void ADC1_2_IRQHandler(void)
|
||||||
void DMA1_Channel7_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN ADC1_2_IRQn 0 */
|
||||||
/* USER CODE BEGIN DMA1_Channel7_IRQn 0 */
|
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_SET);
|
||||||
|
/* USER CODE END ADC1_2_IRQn 0 */
|
||||||
/* USER CODE END DMA1_Channel7_IRQn 0 */
|
HAL_ADC_IRQHandler(&hadc1);
|
||||||
HAL_DMA_IRQHandler(&hdma_usart2_tx);
|
/* USER CODE BEGIN ADC1_2_IRQn 1 */
|
||||||
/* USER CODE BEGIN DMA1_Channel7_IRQn 1 */
|
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_RESET);
|
||||||
|
/* USER CODE END ADC1_2_IRQn 1 */
|
||||||
/* USER CODE END DMA1_Channel7_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles CAN1 RX0 interrupt.
|
||||||
* @brief This function handles ADC1 and ADC2 global interrupts.
|
*/
|
||||||
*/
|
void CAN1_RX0_IRQHandler(void)
|
||||||
void ADC1_2_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN CAN1_RX0_IRQn 0 */
|
||||||
/* USER CODE BEGIN ADC1_2_IRQn 0 */
|
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_SET);
|
/* USER CODE END CAN1_RX0_IRQn 0 */
|
||||||
/* USER CODE END ADC1_2_IRQn 0 */
|
HAL_CAN_IRQHandler(&hcan1);
|
||||||
HAL_ADC_IRQHandler(&hadc1);
|
/* USER CODE BEGIN CAN1_RX0_IRQn 1 */
|
||||||
/* USER CODE BEGIN ADC1_2_IRQn 1 */
|
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_RESET);
|
||||||
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_RESET);
|
/* USER CODE END CAN1_RX0_IRQn 1 */
|
||||||
/* USER CODE END ADC1_2_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles TIM3 global interrupt.
|
||||||
* @brief This function handles CAN1 RX0 interrupt.
|
*/
|
||||||
*/
|
void TIM3_IRQHandler(void)
|
||||||
void CAN1_RX0_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN TIM3_IRQn 0 */
|
||||||
/* USER CODE BEGIN CAN1_RX0_IRQn 0 */
|
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_SET);
|
/* USER CODE END TIM3_IRQn 0 */
|
||||||
/* USER CODE END CAN1_RX0_IRQn 0 */
|
HAL_TIM_IRQHandler(&htim3);
|
||||||
HAL_CAN_IRQHandler(&hcan1);
|
/* USER CODE BEGIN TIM3_IRQn 1 */
|
||||||
/* USER CODE BEGIN CAN1_RX0_IRQn 1 */
|
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_RESET);
|
||||||
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_RESET);
|
/* USER CODE END TIM3_IRQn 1 */
|
||||||
/* USER CODE END CAN1_RX0_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles USART1 global interrupt.
|
||||||
* @brief This function handles TIM3 global interrupt.
|
*/
|
||||||
*/
|
void USART1_IRQHandler(void)
|
||||||
void TIM3_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN USART1_IRQn 0 */
|
||||||
/* USER CODE BEGIN TIM3_IRQn 0 */
|
|
||||||
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_SET);
|
/* USER CODE END USART1_IRQn 0 */
|
||||||
/* USER CODE END TIM3_IRQn 0 */
|
HAL_UART_IRQHandler(&huart1);
|
||||||
HAL_TIM_IRQHandler(&htim3);
|
/* USER CODE BEGIN USART1_IRQn 1 */
|
||||||
/* USER CODE BEGIN TIM3_IRQn 1 */
|
|
||||||
HAL_GPIO_WritePin(DBG4_GPIO_Port, DBG4_Pin, GPIO_PIN_RESET);
|
/* USER CODE END USART1_IRQn 1 */
|
||||||
/* USER CODE END TIM3_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles USART2 global interrupt.
|
||||||
* @brief This function handles USART1 global interrupt.
|
*/
|
||||||
*/
|
void USART2_IRQHandler(void)
|
||||||
void USART1_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN USART2_IRQn 0 */
|
||||||
/* USER CODE BEGIN USART1_IRQn 0 */
|
HAL_GPIO_WritePin(DBG2_GPIO_Port, DBG2_Pin, GPIO_PIN_SET);
|
||||||
|
/* USER CODE END USART2_IRQn 0 */
|
||||||
/* USER CODE END USART1_IRQn 0 */
|
HAL_UART_IRQHandler(&huart2);
|
||||||
HAL_UART_IRQHandler(&huart1);
|
/* USER CODE BEGIN USART2_IRQn 1 */
|
||||||
/* USER CODE BEGIN USART1_IRQn 1 */
|
HAL_GPIO_WritePin(DBG2_GPIO_Port, DBG2_Pin, GPIO_PIN_RESET);
|
||||||
|
/* USER CODE END USART2_IRQn 1 */
|
||||||
/* USER CODE END USART1_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles USART3 global interrupt.
|
||||||
* @brief This function handles USART2 global interrupt.
|
*/
|
||||||
*/
|
void USART3_IRQHandler(void)
|
||||||
void USART2_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN USART3_IRQn 0 */
|
||||||
/* USER CODE BEGIN USART2_IRQn 0 */
|
HAL_GPIO_WritePin(DBG3_GPIO_Port, DBG3_Pin, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(DBG2_GPIO_Port, DBG2_Pin, GPIO_PIN_SET);
|
/* USER CODE END USART3_IRQn 0 */
|
||||||
/* USER CODE END USART2_IRQn 0 */
|
HAL_UART_IRQHandler(&huart3);
|
||||||
HAL_UART_IRQHandler(&huart2);
|
/* USER CODE BEGIN USART3_IRQn 1 */
|
||||||
/* USER CODE BEGIN USART2_IRQn 1 */
|
HAL_GPIO_WritePin(DBG3_GPIO_Port, DBG3_Pin, GPIO_PIN_RESET);
|
||||||
HAL_GPIO_WritePin(DBG2_GPIO_Port, DBG2_Pin, GPIO_PIN_RESET);
|
/* USER CODE END USART3_IRQn 1 */
|
||||||
/* USER CODE END USART2_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles UART5 global interrupt.
|
||||||
* @brief This function handles USART3 global interrupt.
|
*/
|
||||||
*/
|
void UART5_IRQHandler(void)
|
||||||
void USART3_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN UART5_IRQn 0 */
|
||||||
/* USER CODE BEGIN USART3_IRQn 0 */
|
HAL_GPIO_WritePin(DBG1_GPIO_Port, DBG1_Pin, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(DBG3_GPIO_Port, DBG3_Pin, GPIO_PIN_SET);
|
/* USER CODE END UART5_IRQn 0 */
|
||||||
/* USER CODE END USART3_IRQn 0 */
|
HAL_UART_IRQHandler(&huart5);
|
||||||
HAL_UART_IRQHandler(&huart3);
|
/* USER CODE BEGIN UART5_IRQn 1 */
|
||||||
/* USER CODE BEGIN USART3_IRQn 1 */
|
HAL_GPIO_WritePin(DBG1_GPIO_Port, DBG1_Pin, GPIO_PIN_RESET);
|
||||||
HAL_GPIO_WritePin(DBG3_GPIO_Port, DBG3_Pin, GPIO_PIN_RESET);
|
/* USER CODE END UART5_IRQn 1 */
|
||||||
/* USER CODE END USART3_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles CAN2 TX interrupt.
|
||||||
* @brief This function handles UART5 global interrupt.
|
*/
|
||||||
*/
|
void CAN2_TX_IRQHandler(void)
|
||||||
void UART5_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN CAN2_TX_IRQn 0 */
|
||||||
/* USER CODE BEGIN UART5_IRQn 0 */
|
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(DBG1_GPIO_Port, DBG1_Pin, GPIO_PIN_SET);
|
/* USER CODE END CAN2_TX_IRQn 0 */
|
||||||
/* USER CODE END UART5_IRQn 0 */
|
HAL_CAN_IRQHandler(&hcan2);
|
||||||
HAL_UART_IRQHandler(&huart5);
|
/* USER CODE BEGIN CAN2_TX_IRQn 1 */
|
||||||
/* USER CODE BEGIN UART5_IRQn 1 */
|
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_RESET);
|
||||||
HAL_GPIO_WritePin(DBG1_GPIO_Port, DBG1_Pin, GPIO_PIN_RESET);
|
/* USER CODE END CAN2_TX_IRQn 1 */
|
||||||
/* USER CODE END UART5_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
/**
|
* @brief This function handles CAN2 RX1 interrupt.
|
||||||
* @brief This function handles CAN2 TX interrupt.
|
*/
|
||||||
*/
|
void CAN2_RX1_IRQHandler(void)
|
||||||
void CAN2_TX_IRQHandler(void)
|
{
|
||||||
{
|
/* USER CODE BEGIN CAN2_RX1_IRQn 0 */
|
||||||
/* USER CODE BEGIN CAN2_TX_IRQn 0 */
|
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_SET);
|
/* USER CODE END CAN2_RX1_IRQn 0 */
|
||||||
/* USER CODE END CAN2_TX_IRQn 0 */
|
HAL_CAN_IRQHandler(&hcan2);
|
||||||
HAL_CAN_IRQHandler(&hcan2);
|
/* USER CODE BEGIN CAN2_RX1_IRQn 1 */
|
||||||
/* USER CODE BEGIN CAN2_TX_IRQn 1 */
|
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_RESET);
|
||||||
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_RESET);
|
/* USER CODE END CAN2_RX1_IRQn 1 */
|
||||||
/* USER CODE END CAN2_TX_IRQn 1 */
|
}
|
||||||
}
|
|
||||||
|
/* USER CODE BEGIN 1 */
|
||||||
/**
|
|
||||||
* @brief This function handles CAN2 RX1 interrupt.
|
/* USER CODE END 1 */
|
||||||
*/
|
|
||||||
void CAN2_RX1_IRQHandler(void)
|
|
||||||
{
|
|
||||||
/* USER CODE BEGIN CAN2_RX1_IRQn 0 */
|
|
||||||
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_SET);
|
|
||||||
/* USER CODE END CAN2_RX1_IRQn 0 */
|
|
||||||
HAL_CAN_IRQHandler(&hcan2);
|
|
||||||
/* USER CODE BEGIN CAN2_RX1_IRQn 1 */
|
|
||||||
HAL_GPIO_WritePin(DBG5_GPIO_Port, DBG5_Pin, GPIO_PIN_RESET);
|
|
||||||
/* USER CODE END CAN2_RX1_IRQn 1 */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
|
||||||
|
|||||||
+251
-267
@@ -1,267 +1,251 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file tim.c
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* @brief This file provides code for the configuration
|
#include "tim.h"
|
||||||
* of the TIM instances.
|
|
||||||
******************************************************************************
|
/* USER CODE BEGIN 0 */
|
||||||
* @attention
|
|
||||||
*
|
/* USER CODE END 0 */
|
||||||
* Copyright (c) 2025 STMicroelectronics.
|
|
||||||
* All rights reserved.
|
TIM_HandleTypeDef htim3;
|
||||||
*
|
TIM_HandleTypeDef htim4;
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
|
||||||
* in the root directory of this software component.
|
/* TIM3 init function */
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
void MX_TIM3_Init(void)
|
||||||
*
|
{
|
||||||
******************************************************************************
|
|
||||||
*/
|
/* USER CODE BEGIN TIM3_Init 0 */
|
||||||
/* USER CODE END Header */
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* USER CODE END TIM3_Init 0 */
|
||||||
#include "tim.h"
|
|
||||||
|
TIM_ClockConfigTypeDef sClockSourceConfig = {0};
|
||||||
/* USER CODE BEGIN 0 */
|
TIM_MasterConfigTypeDef sMasterConfig = {0};
|
||||||
|
TIM_OC_InitTypeDef sConfigOC = {0};
|
||||||
/* USER CODE END 0 */
|
|
||||||
|
/* USER CODE BEGIN TIM3_Init 1 */
|
||||||
TIM_HandleTypeDef htim3;
|
|
||||||
TIM_HandleTypeDef htim4;
|
/* USER CODE END TIM3_Init 1 */
|
||||||
|
htim3.Instance = TIM3;
|
||||||
/* TIM3 init function */
|
htim3.Init.Prescaler = 0;
|
||||||
void MX_TIM3_Init(void)
|
htim3.Init.CounterMode = TIM_COUNTERMODE_UP;
|
||||||
{
|
htim3.Init.Period = 65535;
|
||||||
|
htim3.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
|
||||||
/* USER CODE BEGIN TIM3_Init 0 */
|
htim3.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
|
||||||
|
if (HAL_TIM_Base_Init(&htim3) != HAL_OK)
|
||||||
/* USER CODE END TIM3_Init 0 */
|
{
|
||||||
|
Error_Handler();
|
||||||
TIM_ClockConfigTypeDef sClockSourceConfig = {0};
|
}
|
||||||
TIM_MasterConfigTypeDef sMasterConfig = {0};
|
sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
|
||||||
TIM_OC_InitTypeDef sConfigOC = {0};
|
if (HAL_TIM_ConfigClockSource(&htim3, &sClockSourceConfig) != HAL_OK)
|
||||||
|
{
|
||||||
/* USER CODE BEGIN TIM3_Init 1 */
|
Error_Handler();
|
||||||
|
}
|
||||||
/* USER CODE END TIM3_Init 1 */
|
if (HAL_TIM_OC_Init(&htim3) != HAL_OK)
|
||||||
htim3.Instance = TIM3;
|
{
|
||||||
htim3.Init.Prescaler = 0;
|
Error_Handler();
|
||||||
htim3.Init.CounterMode = TIM_COUNTERMODE_UP;
|
}
|
||||||
htim3.Init.Period = 65535;
|
if (HAL_TIM_PWM_Init(&htim3) != HAL_OK)
|
||||||
htim3.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
|
{
|
||||||
htim3.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
|
Error_Handler();
|
||||||
if (HAL_TIM_Base_Init(&htim3) != HAL_OK)
|
}
|
||||||
{
|
sMasterConfig.MasterOutputTrigger = TIM_TRGO_OC1;
|
||||||
Error_Handler();
|
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
|
||||||
}
|
if (HAL_TIMEx_MasterConfigSynchronization(&htim3, &sMasterConfig) != HAL_OK)
|
||||||
sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
|
{
|
||||||
if (HAL_TIM_ConfigClockSource(&htim3, &sClockSourceConfig) != HAL_OK)
|
Error_Handler();
|
||||||
{
|
}
|
||||||
Error_Handler();
|
sConfigOC.OCMode = TIM_OCMODE_TIMING;
|
||||||
}
|
sConfigOC.Pulse = 1;
|
||||||
if (HAL_TIM_OC_Init(&htim3) != HAL_OK)
|
sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
|
||||||
{
|
sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
|
||||||
Error_Handler();
|
if (HAL_TIM_OC_ConfigChannel(&htim3, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
|
||||||
}
|
{
|
||||||
if (HAL_TIM_PWM_Init(&htim3) != HAL_OK)
|
Error_Handler();
|
||||||
{
|
}
|
||||||
Error_Handler();
|
sConfigOC.OCMode = TIM_OCMODE_PWM1;
|
||||||
}
|
sConfigOC.Pulse = 0;
|
||||||
sMasterConfig.MasterOutputTrigger = TIM_TRGO_OC1;
|
if (HAL_TIM_PWM_ConfigChannel(&htim3, &sConfigOC, TIM_CHANNEL_2) != HAL_OK)
|
||||||
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
|
{
|
||||||
if (HAL_TIMEx_MasterConfigSynchronization(&htim3, &sMasterConfig) != HAL_OK)
|
Error_Handler();
|
||||||
{
|
}
|
||||||
Error_Handler();
|
/* USER CODE BEGIN TIM3_Init 2 */
|
||||||
}
|
|
||||||
sConfigOC.OCMode = TIM_OCMODE_TIMING;
|
/* USER CODE END TIM3_Init 2 */
|
||||||
sConfigOC.Pulse = 1;
|
HAL_TIM_MspPostInit(&htim3);
|
||||||
sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
|
|
||||||
sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
|
}
|
||||||
if (HAL_TIM_OC_ConfigChannel(&htim3, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
|
/* TIM4 init function */
|
||||||
{
|
void MX_TIM4_Init(void)
|
||||||
Error_Handler();
|
{
|
||||||
}
|
|
||||||
sConfigOC.OCMode = TIM_OCMODE_PWM1;
|
/* USER CODE BEGIN TIM4_Init 0 */
|
||||||
sConfigOC.Pulse = 0;
|
|
||||||
if (HAL_TIM_PWM_ConfigChannel(&htim3, &sConfigOC, TIM_CHANNEL_2) != HAL_OK)
|
/* USER CODE END TIM4_Init 0 */
|
||||||
{
|
|
||||||
Error_Handler();
|
TIM_ClockConfigTypeDef sClockSourceConfig = {0};
|
||||||
}
|
TIM_MasterConfigTypeDef sMasterConfig = {0};
|
||||||
/* USER CODE BEGIN TIM3_Init 2 */
|
TIM_OC_InitTypeDef sConfigOC = {0};
|
||||||
|
|
||||||
/* USER CODE END TIM3_Init 2 */
|
/* USER CODE BEGIN TIM4_Init 1 */
|
||||||
HAL_TIM_MspPostInit(&htim3);
|
|
||||||
|
/* USER CODE END TIM4_Init 1 */
|
||||||
}
|
htim4.Instance = TIM4;
|
||||||
/* TIM4 init function */
|
htim4.Init.Prescaler = 720;
|
||||||
void MX_TIM4_Init(void)
|
htim4.Init.CounterMode = TIM_COUNTERMODE_UP;
|
||||||
{
|
htim4.Init.Period = 100;
|
||||||
|
htim4.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
|
||||||
/* USER CODE BEGIN TIM4_Init 0 */
|
htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
|
||||||
|
if (HAL_TIM_Base_Init(&htim4) != HAL_OK)
|
||||||
/* USER CODE END TIM4_Init 0 */
|
{
|
||||||
|
Error_Handler();
|
||||||
TIM_ClockConfigTypeDef sClockSourceConfig = {0};
|
}
|
||||||
TIM_MasterConfigTypeDef sMasterConfig = {0};
|
sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
|
||||||
TIM_OC_InitTypeDef sConfigOC = {0};
|
if (HAL_TIM_ConfigClockSource(&htim4, &sClockSourceConfig) != HAL_OK)
|
||||||
|
{
|
||||||
/* USER CODE BEGIN TIM4_Init 1 */
|
Error_Handler();
|
||||||
|
}
|
||||||
/* USER CODE END TIM4_Init 1 */
|
if (HAL_TIM_PWM_Init(&htim4) != HAL_OK)
|
||||||
htim4.Instance = TIM4;
|
{
|
||||||
htim4.Init.Prescaler = 720;
|
Error_Handler();
|
||||||
htim4.Init.CounterMode = TIM_COUNTERMODE_UP;
|
}
|
||||||
htim4.Init.Period = 100;
|
sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
|
||||||
htim4.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
|
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
|
||||||
htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
|
if (HAL_TIMEx_MasterConfigSynchronization(&htim4, &sMasterConfig) != HAL_OK)
|
||||||
if (HAL_TIM_Base_Init(&htim4) != HAL_OK)
|
{
|
||||||
{
|
Error_Handler();
|
||||||
Error_Handler();
|
}
|
||||||
}
|
sConfigOC.OCMode = TIM_OCMODE_PWM1;
|
||||||
sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
|
sConfigOC.Pulse = 0;
|
||||||
if (HAL_TIM_ConfigClockSource(&htim4, &sClockSourceConfig) != HAL_OK)
|
sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
|
||||||
{
|
sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
|
||||||
Error_Handler();
|
if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_2) != HAL_OK)
|
||||||
}
|
{
|
||||||
if (HAL_TIM_PWM_Init(&htim4) != HAL_OK)
|
Error_Handler();
|
||||||
{
|
}
|
||||||
Error_Handler();
|
if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_3) != HAL_OK)
|
||||||
}
|
{
|
||||||
sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
|
Error_Handler();
|
||||||
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
|
}
|
||||||
if (HAL_TIMEx_MasterConfigSynchronization(&htim4, &sMasterConfig) != HAL_OK)
|
if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
sConfigOC.OCMode = TIM_OCMODE_PWM1;
|
/* USER CODE BEGIN TIM4_Init 2 */
|
||||||
sConfigOC.Pulse = 0;
|
|
||||||
sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
|
/* USER CODE END TIM4_Init 2 */
|
||||||
sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
|
HAL_TIM_MspPostInit(&htim4);
|
||||||
if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_2) != HAL_OK)
|
|
||||||
{
|
}
|
||||||
Error_Handler();
|
|
||||||
}
|
void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle)
|
||||||
if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_3) != HAL_OK)
|
{
|
||||||
{
|
|
||||||
Error_Handler();
|
if(tim_baseHandle->Instance==TIM3)
|
||||||
}
|
{
|
||||||
if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
|
/* USER CODE BEGIN TIM3_MspInit 0 */
|
||||||
{
|
|
||||||
Error_Handler();
|
/* USER CODE END TIM3_MspInit 0 */
|
||||||
}
|
/* TIM3 clock enable */
|
||||||
/* USER CODE BEGIN TIM4_Init 2 */
|
__HAL_RCC_TIM3_CLK_ENABLE();
|
||||||
|
|
||||||
/* USER CODE END TIM4_Init 2 */
|
/* TIM3 interrupt Init */
|
||||||
HAL_TIM_MspPostInit(&htim4);
|
HAL_NVIC_SetPriority(TIM3_IRQn, 6, 0);
|
||||||
|
HAL_NVIC_EnableIRQ(TIM3_IRQn);
|
||||||
}
|
/* USER CODE BEGIN TIM3_MspInit 1 */
|
||||||
|
|
||||||
void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle)
|
/* USER CODE END TIM3_MspInit 1 */
|
||||||
{
|
}
|
||||||
|
else if(tim_baseHandle->Instance==TIM4)
|
||||||
if(tim_baseHandle->Instance==TIM3)
|
{
|
||||||
{
|
/* USER CODE BEGIN TIM4_MspInit 0 */
|
||||||
/* USER CODE BEGIN TIM3_MspInit 0 */
|
|
||||||
|
/* USER CODE END TIM4_MspInit 0 */
|
||||||
/* USER CODE END TIM3_MspInit 0 */
|
/* TIM4 clock enable */
|
||||||
/* TIM3 clock enable */
|
__HAL_RCC_TIM4_CLK_ENABLE();
|
||||||
__HAL_RCC_TIM3_CLK_ENABLE();
|
/* USER CODE BEGIN TIM4_MspInit 1 */
|
||||||
|
|
||||||
/* TIM3 interrupt Init */
|
/* USER CODE END TIM4_MspInit 1 */
|
||||||
HAL_NVIC_SetPriority(TIM3_IRQn, 6, 0);
|
}
|
||||||
HAL_NVIC_EnableIRQ(TIM3_IRQn);
|
}
|
||||||
/* USER CODE BEGIN TIM3_MspInit 1 */
|
void HAL_TIM_MspPostInit(TIM_HandleTypeDef* timHandle)
|
||||||
|
{
|
||||||
/* USER CODE END TIM3_MspInit 1 */
|
|
||||||
}
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
||||||
else if(tim_baseHandle->Instance==TIM4)
|
if(timHandle->Instance==TIM3)
|
||||||
{
|
{
|
||||||
/* USER CODE BEGIN TIM4_MspInit 0 */
|
/* USER CODE BEGIN TIM3_MspPostInit 0 */
|
||||||
|
|
||||||
/* USER CODE END TIM4_MspInit 0 */
|
/* USER CODE END TIM3_MspPostInit 0 */
|
||||||
/* TIM4 clock enable */
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
||||||
__HAL_RCC_TIM4_CLK_ENABLE();
|
/**TIM3 GPIO Configuration
|
||||||
/* USER CODE BEGIN TIM4_MspInit 1 */
|
PA7 ------> TIM3_CH2
|
||||||
|
*/
|
||||||
/* USER CODE END TIM4_MspInit 1 */
|
GPIO_InitStruct.Pin = CP_PWM_Pin;
|
||||||
}
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
}
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
||||||
void HAL_TIM_MspPostInit(TIM_HandleTypeDef* timHandle)
|
HAL_GPIO_Init(CP_PWM_GPIO_Port, &GPIO_InitStruct);
|
||||||
{
|
|
||||||
|
/* USER CODE BEGIN TIM3_MspPostInit 1 */
|
||||||
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
||||||
if(timHandle->Instance==TIM3)
|
/* USER CODE END TIM3_MspPostInit 1 */
|
||||||
{
|
}
|
||||||
/* USER CODE BEGIN TIM3_MspPostInit 0 */
|
else if(timHandle->Instance==TIM4)
|
||||||
|
{
|
||||||
/* USER CODE END TIM3_MspPostInit 0 */
|
/* USER CODE BEGIN TIM4_MspPostInit 0 */
|
||||||
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
||||||
/**TIM3 GPIO Configuration
|
/* USER CODE END TIM4_MspPostInit 0 */
|
||||||
PA7 ------> TIM3_CH2
|
|
||||||
*/
|
__HAL_RCC_GPIOD_CLK_ENABLE();
|
||||||
GPIO_InitStruct.Pin = CP_PWM_Pin;
|
/**TIM4 GPIO Configuration
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
PD13 ------> TIM4_CH2
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
PD14 ------> TIM4_CH3
|
||||||
HAL_GPIO_Init(CP_PWM_GPIO_Port, &GPIO_InitStruct);
|
PD15 ------> TIM4_CH4
|
||||||
|
*/
|
||||||
/* USER CODE BEGIN TIM3_MspPostInit 1 */
|
GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_14|GPIO_PIN_15;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
/* USER CODE END TIM3_MspPostInit 1 */
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
||||||
}
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
||||||
else if(timHandle->Instance==TIM4)
|
|
||||||
{
|
__HAL_AFIO_REMAP_TIM4_ENABLE();
|
||||||
/* USER CODE BEGIN TIM4_MspPostInit 0 */
|
|
||||||
|
/* USER CODE BEGIN TIM4_MspPostInit 1 */
|
||||||
/* USER CODE END TIM4_MspPostInit 0 */
|
|
||||||
|
/* USER CODE END TIM4_MspPostInit 1 */
|
||||||
__HAL_RCC_GPIOD_CLK_ENABLE();
|
}
|
||||||
/**TIM4 GPIO Configuration
|
|
||||||
PD13 ------> TIM4_CH2
|
}
|
||||||
PD14 ------> TIM4_CH3
|
|
||||||
PD15 ------> TIM4_CH4
|
void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* tim_baseHandle)
|
||||||
*/
|
{
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_14|GPIO_PIN_15;
|
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
if(tim_baseHandle->Instance==TIM3)
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
{
|
||||||
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
/* USER CODE BEGIN TIM3_MspDeInit 0 */
|
||||||
|
|
||||||
__HAL_AFIO_REMAP_TIM4_ENABLE();
|
/* USER CODE END TIM3_MspDeInit 0 */
|
||||||
|
/* Peripheral clock disable */
|
||||||
/* USER CODE BEGIN TIM4_MspPostInit 1 */
|
__HAL_RCC_TIM3_CLK_DISABLE();
|
||||||
|
|
||||||
/* USER CODE END TIM4_MspPostInit 1 */
|
/* TIM3 interrupt Deinit */
|
||||||
}
|
HAL_NVIC_DisableIRQ(TIM3_IRQn);
|
||||||
|
/* USER CODE BEGIN TIM3_MspDeInit 1 */
|
||||||
}
|
|
||||||
|
/* USER CODE END TIM3_MspDeInit 1 */
|
||||||
void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* tim_baseHandle)
|
}
|
||||||
{
|
else if(tim_baseHandle->Instance==TIM4)
|
||||||
|
{
|
||||||
if(tim_baseHandle->Instance==TIM3)
|
/* USER CODE BEGIN TIM4_MspDeInit 0 */
|
||||||
{
|
|
||||||
/* USER CODE BEGIN TIM3_MspDeInit 0 */
|
/* USER CODE END TIM4_MspDeInit 0 */
|
||||||
|
/* Peripheral clock disable */
|
||||||
/* USER CODE END TIM3_MspDeInit 0 */
|
__HAL_RCC_TIM4_CLK_DISABLE();
|
||||||
/* Peripheral clock disable */
|
/* USER CODE BEGIN TIM4_MspDeInit 1 */
|
||||||
__HAL_RCC_TIM3_CLK_DISABLE();
|
|
||||||
|
/* USER CODE END TIM4_MspDeInit 1 */
|
||||||
/* TIM3 interrupt Deinit */
|
}
|
||||||
HAL_NVIC_DisableIRQ(TIM3_IRQn);
|
}
|
||||||
/* USER CODE BEGIN TIM3_MspDeInit 1 */
|
|
||||||
|
/* USER CODE BEGIN 1 */
|
||||||
/* USER CODE END TIM3_MspDeInit 1 */
|
|
||||||
}
|
/* USER CODE END 1 */
|
||||||
else if(tim_baseHandle->Instance==TIM4)
|
|
||||||
{
|
|
||||||
/* USER CODE BEGIN TIM4_MspDeInit 0 */
|
|
||||||
|
|
||||||
/* USER CODE END TIM4_MspDeInit 0 */
|
|
||||||
/* Peripheral clock disable */
|
|
||||||
__HAL_RCC_TIM4_CLK_DISABLE();
|
|
||||||
/* USER CODE BEGIN TIM4_MspDeInit 1 */
|
|
||||||
|
|
||||||
/* USER CODE END TIM4_MspDeInit 1 */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
|
||||||
|
|||||||
+430
-446
@@ -1,446 +1,430 @@
|
|||||||
/* USER CODE BEGIN Header */
|
/* USER CODE BEGIN Header */
|
||||||
/**
|
|
||||||
******************************************************************************
|
/* USER CODE END Header */
|
||||||
* @file usart.c
|
/* Includes ------------------------------------------------------------------*/
|
||||||
* @brief This file provides code for the configuration
|
#include "usart.h"
|
||||||
* of the USART instances.
|
|
||||||
******************************************************************************
|
/* USER CODE BEGIN 0 */
|
||||||
* @attention
|
|
||||||
*
|
/* USER CODE END 0 */
|
||||||
* Copyright (c) 2025 STMicroelectronics.
|
|
||||||
* All rights reserved.
|
UART_HandleTypeDef huart5;
|
||||||
*
|
UART_HandleTypeDef huart1;
|
||||||
* This software is licensed under terms that can be found in the LICENSE file
|
UART_HandleTypeDef huart2;
|
||||||
* in the root directory of this software component.
|
UART_HandleTypeDef huart3;
|
||||||
* If no LICENSE file comes with this software, it is provided AS-IS.
|
DMA_HandleTypeDef hdma_usart2_rx;
|
||||||
*
|
DMA_HandleTypeDef hdma_usart2_tx;
|
||||||
******************************************************************************
|
DMA_HandleTypeDef hdma_usart3_rx;
|
||||||
*/
|
DMA_HandleTypeDef hdma_usart3_tx;
|
||||||
/* USER CODE END Header */
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* UART5 init function */
|
||||||
#include "usart.h"
|
void MX_UART5_Init(void)
|
||||||
|
{
|
||||||
/* USER CODE BEGIN 0 */
|
|
||||||
|
/* USER CODE BEGIN UART5_Init 0 */
|
||||||
/* USER CODE END 0 */
|
|
||||||
|
/* USER CODE END UART5_Init 0 */
|
||||||
UART_HandleTypeDef huart5;
|
|
||||||
UART_HandleTypeDef huart1;
|
/* USER CODE BEGIN UART5_Init 1 */
|
||||||
UART_HandleTypeDef huart2;
|
|
||||||
UART_HandleTypeDef huart3;
|
/* USER CODE END UART5_Init 1 */
|
||||||
DMA_HandleTypeDef hdma_usart2_rx;
|
huart5.Instance = UART5;
|
||||||
DMA_HandleTypeDef hdma_usart2_tx;
|
huart5.Init.BaudRate = 9600;
|
||||||
DMA_HandleTypeDef hdma_usart3_rx;
|
huart5.Init.WordLength = UART_WORDLENGTH_8B;
|
||||||
DMA_HandleTypeDef hdma_usart3_tx;
|
huart5.Init.StopBits = UART_STOPBITS_1;
|
||||||
|
huart5.Init.Parity = UART_PARITY_NONE;
|
||||||
/* UART5 init function */
|
huart5.Init.Mode = UART_MODE_TX_RX;
|
||||||
void MX_UART5_Init(void)
|
huart5.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
||||||
{
|
huart5.Init.OverSampling = UART_OVERSAMPLING_16;
|
||||||
|
if (HAL_UART_Init(&huart5) != HAL_OK)
|
||||||
/* USER CODE BEGIN UART5_Init 0 */
|
{
|
||||||
|
Error_Handler();
|
||||||
/* USER CODE END UART5_Init 0 */
|
}
|
||||||
|
/* USER CODE BEGIN UART5_Init 2 */
|
||||||
/* USER CODE BEGIN UART5_Init 1 */
|
|
||||||
|
/* USER CODE END UART5_Init 2 */
|
||||||
/* USER CODE END UART5_Init 1 */
|
|
||||||
huart5.Instance = UART5;
|
}
|
||||||
huart5.Init.BaudRate = 9600;
|
/* USART1 init function */
|
||||||
huart5.Init.WordLength = UART_WORDLENGTH_8B;
|
|
||||||
huart5.Init.StopBits = UART_STOPBITS_1;
|
void MX_USART1_UART_Init(void)
|
||||||
huart5.Init.Parity = UART_PARITY_NONE;
|
{
|
||||||
huart5.Init.Mode = UART_MODE_TX_RX;
|
|
||||||
huart5.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
/* USER CODE BEGIN USART1_Init 0 */
|
||||||
huart5.Init.OverSampling = UART_OVERSAMPLING_16;
|
|
||||||
if (HAL_UART_Init(&huart5) != HAL_OK)
|
/* USER CODE END USART1_Init 0 */
|
||||||
{
|
|
||||||
Error_Handler();
|
/* USER CODE BEGIN USART1_Init 1 */
|
||||||
}
|
|
||||||
/* USER CODE BEGIN UART5_Init 2 */
|
/* USER CODE END USART1_Init 1 */
|
||||||
|
huart1.Instance = USART1;
|
||||||
/* USER CODE END UART5_Init 2 */
|
huart1.Init.BaudRate = 115200;
|
||||||
|
huart1.Init.WordLength = UART_WORDLENGTH_8B;
|
||||||
}
|
huart1.Init.StopBits = UART_STOPBITS_1;
|
||||||
/* USART1 init function */
|
huart1.Init.Parity = UART_PARITY_NONE;
|
||||||
|
huart1.Init.Mode = UART_MODE_TX_RX;
|
||||||
void MX_USART1_UART_Init(void)
|
huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
||||||
{
|
huart1.Init.OverSampling = UART_OVERSAMPLING_16;
|
||||||
|
if (HAL_UART_Init(&huart1) != HAL_OK)
|
||||||
/* USER CODE BEGIN USART1_Init 0 */
|
{
|
||||||
|
Error_Handler();
|
||||||
/* USER CODE END USART1_Init 0 */
|
}
|
||||||
|
/* USER CODE BEGIN USART1_Init 2 */
|
||||||
/* USER CODE BEGIN USART1_Init 1 */
|
|
||||||
|
/* USER CODE END USART1_Init 2 */
|
||||||
/* USER CODE END USART1_Init 1 */
|
|
||||||
huart1.Instance = USART1;
|
}
|
||||||
huart1.Init.BaudRate = 115200;
|
/* USART2 init function */
|
||||||
huart1.Init.WordLength = UART_WORDLENGTH_8B;
|
|
||||||
huart1.Init.StopBits = UART_STOPBITS_1;
|
void MX_USART2_UART_Init(void)
|
||||||
huart1.Init.Parity = UART_PARITY_NONE;
|
{
|
||||||
huart1.Init.Mode = UART_MODE_TX_RX;
|
|
||||||
huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
/* USER CODE BEGIN USART2_Init 0 */
|
||||||
huart1.Init.OverSampling = UART_OVERSAMPLING_16;
|
|
||||||
if (HAL_UART_Init(&huart1) != HAL_OK)
|
/* USER CODE END USART2_Init 0 */
|
||||||
{
|
|
||||||
Error_Handler();
|
/* USER CODE BEGIN USART2_Init 1 */
|
||||||
}
|
|
||||||
/* USER CODE BEGIN USART1_Init 2 */
|
/* USER CODE END USART2_Init 1 */
|
||||||
|
huart2.Instance = USART2;
|
||||||
/* USER CODE END USART1_Init 2 */
|
huart2.Init.BaudRate = 115200;
|
||||||
|
huart2.Init.WordLength = UART_WORDLENGTH_8B;
|
||||||
}
|
huart2.Init.StopBits = UART_STOPBITS_1;
|
||||||
/* USART2 init function */
|
huart2.Init.Parity = UART_PARITY_NONE;
|
||||||
|
huart2.Init.Mode = UART_MODE_TX_RX;
|
||||||
void MX_USART2_UART_Init(void)
|
huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
||||||
{
|
huart2.Init.OverSampling = UART_OVERSAMPLING_16;
|
||||||
|
if (HAL_UART_Init(&huart2) != HAL_OK)
|
||||||
/* USER CODE BEGIN USART2_Init 0 */
|
{
|
||||||
|
Error_Handler();
|
||||||
/* USER CODE END USART2_Init 0 */
|
}
|
||||||
|
/* USER CODE BEGIN USART2_Init 2 */
|
||||||
/* USER CODE BEGIN USART2_Init 1 */
|
|
||||||
|
/* USER CODE END USART2_Init 2 */
|
||||||
/* USER CODE END USART2_Init 1 */
|
|
||||||
huart2.Instance = USART2;
|
}
|
||||||
huart2.Init.BaudRate = 115200;
|
/* USART3 init function */
|
||||||
huart2.Init.WordLength = UART_WORDLENGTH_8B;
|
|
||||||
huart2.Init.StopBits = UART_STOPBITS_1;
|
void MX_USART3_UART_Init(void)
|
||||||
huart2.Init.Parity = UART_PARITY_NONE;
|
{
|
||||||
huart2.Init.Mode = UART_MODE_TX_RX;
|
|
||||||
huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
/* USER CODE BEGIN USART3_Init 0 */
|
||||||
huart2.Init.OverSampling = UART_OVERSAMPLING_16;
|
|
||||||
if (HAL_UART_Init(&huart2) != HAL_OK)
|
/* USER CODE END USART3_Init 0 */
|
||||||
{
|
|
||||||
Error_Handler();
|
/* USER CODE BEGIN USART3_Init 1 */
|
||||||
}
|
|
||||||
/* USER CODE BEGIN USART2_Init 2 */
|
/* USER CODE END USART3_Init 1 */
|
||||||
|
huart3.Instance = USART3;
|
||||||
/* USER CODE END USART2_Init 2 */
|
huart3.Init.BaudRate = 115200;
|
||||||
|
huart3.Init.WordLength = UART_WORDLENGTH_8B;
|
||||||
}
|
huart3.Init.StopBits = UART_STOPBITS_1;
|
||||||
/* USART3 init function */
|
huart3.Init.Parity = UART_PARITY_NONE;
|
||||||
|
huart3.Init.Mode = UART_MODE_TX_RX;
|
||||||
void MX_USART3_UART_Init(void)
|
huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
||||||
{
|
huart3.Init.OverSampling = UART_OVERSAMPLING_16;
|
||||||
|
if (HAL_UART_Init(&huart3) != HAL_OK)
|
||||||
/* USER CODE BEGIN USART3_Init 0 */
|
{
|
||||||
|
Error_Handler();
|
||||||
/* USER CODE END USART3_Init 0 */
|
}
|
||||||
|
/* USER CODE BEGIN USART3_Init 2 */
|
||||||
/* USER CODE BEGIN USART3_Init 1 */
|
|
||||||
|
/* USER CODE END USART3_Init 2 */
|
||||||
/* USER CODE END USART3_Init 1 */
|
|
||||||
huart3.Instance = USART3;
|
}
|
||||||
huart3.Init.BaudRate = 115200;
|
|
||||||
huart3.Init.WordLength = UART_WORDLENGTH_8B;
|
void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
|
||||||
huart3.Init.StopBits = UART_STOPBITS_1;
|
{
|
||||||
huart3.Init.Parity = UART_PARITY_NONE;
|
|
||||||
huart3.Init.Mode = UART_MODE_TX_RX;
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
||||||
huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
if(uartHandle->Instance==UART5)
|
||||||
huart3.Init.OverSampling = UART_OVERSAMPLING_16;
|
{
|
||||||
if (HAL_UART_Init(&huart3) != HAL_OK)
|
/* USER CODE BEGIN UART5_MspInit 0 */
|
||||||
{
|
|
||||||
Error_Handler();
|
/* USER CODE END UART5_MspInit 0 */
|
||||||
}
|
/* UART5 clock enable */
|
||||||
/* USER CODE BEGIN USART3_Init 2 */
|
__HAL_RCC_UART5_CLK_ENABLE();
|
||||||
|
|
||||||
/* USER CODE END USART3_Init 2 */
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
||||||
|
__HAL_RCC_GPIOD_CLK_ENABLE();
|
||||||
}
|
/**UART5 GPIO Configuration
|
||||||
|
PC12 ------> UART5_TX
|
||||||
void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
|
PD2 ------> UART5_RX
|
||||||
{
|
*/
|
||||||
|
GPIO_InitStruct.Pin = GPIO_PIN_12;
|
||||||
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
if(uartHandle->Instance==UART5)
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
{
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
||||||
/* USER CODE BEGIN UART5_MspInit 0 */
|
|
||||||
|
GPIO_InitStruct.Pin = GPIO_PIN_2;
|
||||||
/* USER CODE END UART5_MspInit 0 */
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
/* UART5 clock enable */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
__HAL_RCC_UART5_CLK_ENABLE();
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
||||||
|
|
||||||
__HAL_RCC_GPIOC_CLK_ENABLE();
|
/* UART5 interrupt Init */
|
||||||
__HAL_RCC_GPIOD_CLK_ENABLE();
|
HAL_NVIC_SetPriority(UART5_IRQn, 5, 0);
|
||||||
/**UART5 GPIO Configuration
|
HAL_NVIC_EnableIRQ(UART5_IRQn);
|
||||||
PC12 ------> UART5_TX
|
/* USER CODE BEGIN UART5_MspInit 1 */
|
||||||
PD2 ------> UART5_RX
|
|
||||||
*/
|
/* USER CODE END UART5_MspInit 1 */
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_12;
|
}
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
else if(uartHandle->Instance==USART1)
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
{
|
||||||
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
/* USER CODE BEGIN USART1_MspInit 0 */
|
||||||
|
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_2;
|
/* USER CODE END USART1_MspInit 0 */
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
/* USART1 clock enable */
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
__HAL_RCC_USART1_CLK_ENABLE();
|
||||||
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
|
||||||
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
||||||
/* UART5 interrupt Init */
|
/**USART1 GPIO Configuration
|
||||||
HAL_NVIC_SetPriority(UART5_IRQn, 5, 0);
|
PA9 ------> USART1_TX
|
||||||
HAL_NVIC_EnableIRQ(UART5_IRQn);
|
PA10 ------> USART1_RX
|
||||||
/* USER CODE BEGIN UART5_MspInit 1 */
|
*/
|
||||||
|
GPIO_InitStruct.Pin = GPIO_PIN_9;
|
||||||
/* USER CODE END UART5_MspInit 1 */
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
}
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
else if(uartHandle->Instance==USART1)
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
||||||
{
|
|
||||||
/* USER CODE BEGIN USART1_MspInit 0 */
|
GPIO_InitStruct.Pin = GPIO_PIN_10;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
/* USER CODE END USART1_MspInit 0 */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
/* USART1 clock enable */
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
||||||
__HAL_RCC_USART1_CLK_ENABLE();
|
|
||||||
|
/* USART1 interrupt Init */
|
||||||
__HAL_RCC_GPIOA_CLK_ENABLE();
|
HAL_NVIC_SetPriority(USART1_IRQn, 5, 0);
|
||||||
/**USART1 GPIO Configuration
|
HAL_NVIC_EnableIRQ(USART1_IRQn);
|
||||||
PA9 ------> USART1_TX
|
/* USER CODE BEGIN USART1_MspInit 1 */
|
||||||
PA10 ------> USART1_RX
|
|
||||||
*/
|
/* USER CODE END USART1_MspInit 1 */
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_9;
|
}
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
else if(uartHandle->Instance==USART2)
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
{
|
||||||
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
/* USER CODE BEGIN USART2_MspInit 0 */
|
||||||
|
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_10;
|
/* USER CODE END USART2_MspInit 0 */
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
/* USART2 clock enable */
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
__HAL_RCC_USART2_CLK_ENABLE();
|
||||||
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
||||||
|
__HAL_RCC_GPIOD_CLK_ENABLE();
|
||||||
/* USART1 interrupt Init */
|
/**USART2 GPIO Configuration
|
||||||
HAL_NVIC_SetPriority(USART1_IRQn, 5, 0);
|
PD5 ------> USART2_TX
|
||||||
HAL_NVIC_EnableIRQ(USART1_IRQn);
|
PD6 ------> USART2_RX
|
||||||
/* USER CODE BEGIN USART1_MspInit 1 */
|
*/
|
||||||
|
GPIO_InitStruct.Pin = GPIO_PIN_5;
|
||||||
/* USER CODE END USART1_MspInit 1 */
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
}
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
else if(uartHandle->Instance==USART2)
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
||||||
{
|
|
||||||
/* USER CODE BEGIN USART2_MspInit 0 */
|
GPIO_InitStruct.Pin = GPIO_PIN_6;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
/* USER CODE END USART2_MspInit 0 */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
/* USART2 clock enable */
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
||||||
__HAL_RCC_USART2_CLK_ENABLE();
|
|
||||||
|
__HAL_AFIO_REMAP_USART2_ENABLE();
|
||||||
__HAL_RCC_GPIOD_CLK_ENABLE();
|
|
||||||
/**USART2 GPIO Configuration
|
/* USART2 DMA Init */
|
||||||
PD5 ------> USART2_TX
|
/* USART2_RX Init */
|
||||||
PD6 ------> USART2_RX
|
hdma_usart2_rx.Instance = DMA1_Channel6;
|
||||||
*/
|
hdma_usart2_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_5;
|
hdma_usart2_rx.Init.PeriphInc = DMA_PINC_DISABLE;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
hdma_usart2_rx.Init.MemInc = DMA_MINC_ENABLE;
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
hdma_usart2_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
||||||
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
hdma_usart2_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
||||||
|
hdma_usart2_rx.Init.Mode = DMA_NORMAL;
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_6;
|
hdma_usart2_rx.Init.Priority = DMA_PRIORITY_VERY_HIGH;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
if (HAL_DMA_Init(&hdma_usart2_rx) != HAL_OK)
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
{
|
||||||
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
Error_Handler();
|
||||||
|
}
|
||||||
__HAL_AFIO_REMAP_USART2_ENABLE();
|
|
||||||
|
__HAL_LINKDMA(uartHandle,hdmarx,hdma_usart2_rx);
|
||||||
/* USART2 DMA Init */
|
|
||||||
/* USART2_RX Init */
|
/* USART2_TX Init */
|
||||||
hdma_usart2_rx.Instance = DMA1_Channel6;
|
hdma_usart2_tx.Instance = DMA1_Channel7;
|
||||||
hdma_usart2_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
hdma_usart2_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
||||||
hdma_usart2_rx.Init.PeriphInc = DMA_PINC_DISABLE;
|
hdma_usart2_tx.Init.PeriphInc = DMA_PINC_DISABLE;
|
||||||
hdma_usart2_rx.Init.MemInc = DMA_MINC_ENABLE;
|
hdma_usart2_tx.Init.MemInc = DMA_MINC_ENABLE;
|
||||||
hdma_usart2_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
hdma_usart2_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
||||||
hdma_usart2_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
hdma_usart2_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
||||||
hdma_usart2_rx.Init.Mode = DMA_NORMAL;
|
hdma_usart2_tx.Init.Mode = DMA_NORMAL;
|
||||||
hdma_usart2_rx.Init.Priority = DMA_PRIORITY_VERY_HIGH;
|
hdma_usart2_tx.Init.Priority = DMA_PRIORITY_HIGH;
|
||||||
if (HAL_DMA_Init(&hdma_usart2_rx) != HAL_OK)
|
if (HAL_DMA_Init(&hdma_usart2_tx) != HAL_OK)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
|
|
||||||
__HAL_LINKDMA(uartHandle,hdmarx,hdma_usart2_rx);
|
__HAL_LINKDMA(uartHandle,hdmatx,hdma_usart2_tx);
|
||||||
|
|
||||||
/* USART2_TX Init */
|
/* USART2 interrupt Init */
|
||||||
hdma_usart2_tx.Instance = DMA1_Channel7;
|
HAL_NVIC_SetPriority(USART2_IRQn, 2, 0);
|
||||||
hdma_usart2_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
HAL_NVIC_EnableIRQ(USART2_IRQn);
|
||||||
hdma_usart2_tx.Init.PeriphInc = DMA_PINC_DISABLE;
|
/* USER CODE BEGIN USART2_MspInit 1 */
|
||||||
hdma_usart2_tx.Init.MemInc = DMA_MINC_ENABLE;
|
|
||||||
hdma_usart2_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
/* USER CODE END USART2_MspInit 1 */
|
||||||
hdma_usart2_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
}
|
||||||
hdma_usart2_tx.Init.Mode = DMA_NORMAL;
|
else if(uartHandle->Instance==USART3)
|
||||||
hdma_usart2_tx.Init.Priority = DMA_PRIORITY_HIGH;
|
{
|
||||||
if (HAL_DMA_Init(&hdma_usart2_tx) != HAL_OK)
|
/* USER CODE BEGIN USART3_MspInit 0 */
|
||||||
{
|
|
||||||
Error_Handler();
|
/* USER CODE END USART3_MspInit 0 */
|
||||||
}
|
/* USART3 clock enable */
|
||||||
|
__HAL_RCC_USART3_CLK_ENABLE();
|
||||||
__HAL_LINKDMA(uartHandle,hdmatx,hdma_usart2_tx);
|
|
||||||
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
||||||
/* USART2 interrupt Init */
|
/**USART3 GPIO Configuration
|
||||||
HAL_NVIC_SetPriority(USART2_IRQn, 2, 0);
|
PC10 ------> USART3_TX
|
||||||
HAL_NVIC_EnableIRQ(USART2_IRQn);
|
PC11 ------> USART3_RX
|
||||||
/* USER CODE BEGIN USART2_MspInit 1 */
|
*/
|
||||||
|
GPIO_InitStruct.Pin = GPIO_PIN_10;
|
||||||
/* USER CODE END USART2_MspInit 1 */
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
}
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
||||||
else if(uartHandle->Instance==USART3)
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
||||||
{
|
|
||||||
/* USER CODE BEGIN USART3_MspInit 0 */
|
GPIO_InitStruct.Pin = GPIO_PIN_11;
|
||||||
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
||||||
/* USER CODE END USART3_MspInit 0 */
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
/* USART3 clock enable */
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
||||||
__HAL_RCC_USART3_CLK_ENABLE();
|
|
||||||
|
__HAL_AFIO_REMAP_USART3_PARTIAL();
|
||||||
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
||||||
/**USART3 GPIO Configuration
|
/* USART3 DMA Init */
|
||||||
PC10 ------> USART3_TX
|
/* USART3_RX Init */
|
||||||
PC11 ------> USART3_RX
|
hdma_usart3_rx.Instance = DMA1_Channel3;
|
||||||
*/
|
hdma_usart3_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_10;
|
hdma_usart3_rx.Init.PeriphInc = DMA_PINC_DISABLE;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
hdma_usart3_rx.Init.MemInc = DMA_MINC_ENABLE;
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
hdma_usart3_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
||||||
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
hdma_usart3_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
||||||
|
hdma_usart3_rx.Init.Mode = DMA_NORMAL;
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_11;
|
hdma_usart3_rx.Init.Priority = DMA_PRIORITY_VERY_HIGH;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
if (HAL_DMA_Init(&hdma_usart3_rx) != HAL_OK)
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
{
|
||||||
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
Error_Handler();
|
||||||
|
}
|
||||||
__HAL_AFIO_REMAP_USART3_PARTIAL();
|
|
||||||
|
__HAL_LINKDMA(uartHandle,hdmarx,hdma_usart3_rx);
|
||||||
/* USART3 DMA Init */
|
|
||||||
/* USART3_RX Init */
|
/* USART3_TX Init */
|
||||||
hdma_usart3_rx.Instance = DMA1_Channel3;
|
hdma_usart3_tx.Instance = DMA1_Channel2;
|
||||||
hdma_usart3_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
hdma_usart3_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
||||||
hdma_usart3_rx.Init.PeriphInc = DMA_PINC_DISABLE;
|
hdma_usart3_tx.Init.PeriphInc = DMA_PINC_DISABLE;
|
||||||
hdma_usart3_rx.Init.MemInc = DMA_MINC_ENABLE;
|
hdma_usart3_tx.Init.MemInc = DMA_MINC_ENABLE;
|
||||||
hdma_usart3_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
hdma_usart3_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
||||||
hdma_usart3_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
hdma_usart3_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
||||||
hdma_usart3_rx.Init.Mode = DMA_NORMAL;
|
hdma_usart3_tx.Init.Mode = DMA_NORMAL;
|
||||||
hdma_usart3_rx.Init.Priority = DMA_PRIORITY_VERY_HIGH;
|
hdma_usart3_tx.Init.Priority = DMA_PRIORITY_HIGH;
|
||||||
if (HAL_DMA_Init(&hdma_usart3_rx) != HAL_OK)
|
if (HAL_DMA_Init(&hdma_usart3_tx) != HAL_OK)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
|
|
||||||
__HAL_LINKDMA(uartHandle,hdmarx,hdma_usart3_rx);
|
__HAL_LINKDMA(uartHandle,hdmatx,hdma_usart3_tx);
|
||||||
|
|
||||||
/* USART3_TX Init */
|
/* USART3 interrupt Init */
|
||||||
hdma_usart3_tx.Instance = DMA1_Channel2;
|
HAL_NVIC_SetPriority(USART3_IRQn, 2, 0);
|
||||||
hdma_usart3_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
HAL_NVIC_EnableIRQ(USART3_IRQn);
|
||||||
hdma_usart3_tx.Init.PeriphInc = DMA_PINC_DISABLE;
|
/* USER CODE BEGIN USART3_MspInit 1 */
|
||||||
hdma_usart3_tx.Init.MemInc = DMA_MINC_ENABLE;
|
|
||||||
hdma_usart3_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
/* USER CODE END USART3_MspInit 1 */
|
||||||
hdma_usart3_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
}
|
||||||
hdma_usart3_tx.Init.Mode = DMA_NORMAL;
|
}
|
||||||
hdma_usart3_tx.Init.Priority = DMA_PRIORITY_HIGH;
|
|
||||||
if (HAL_DMA_Init(&hdma_usart3_tx) != HAL_OK)
|
void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
|
||||||
}
|
if(uartHandle->Instance==UART5)
|
||||||
|
{
|
||||||
__HAL_LINKDMA(uartHandle,hdmatx,hdma_usart3_tx);
|
/* USER CODE BEGIN UART5_MspDeInit 0 */
|
||||||
|
|
||||||
/* USART3 interrupt Init */
|
/* USER CODE END UART5_MspDeInit 0 */
|
||||||
HAL_NVIC_SetPriority(USART3_IRQn, 2, 0);
|
/* Peripheral clock disable */
|
||||||
HAL_NVIC_EnableIRQ(USART3_IRQn);
|
__HAL_RCC_UART5_CLK_DISABLE();
|
||||||
/* USER CODE BEGIN USART3_MspInit 1 */
|
|
||||||
|
/**UART5 GPIO Configuration
|
||||||
/* USER CODE END USART3_MspInit 1 */
|
PC12 ------> UART5_TX
|
||||||
}
|
PD2 ------> UART5_RX
|
||||||
}
|
*/
|
||||||
|
HAL_GPIO_DeInit(GPIOC, GPIO_PIN_12);
|
||||||
void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
|
|
||||||
{
|
HAL_GPIO_DeInit(GPIOD, GPIO_PIN_2);
|
||||||
|
|
||||||
if(uartHandle->Instance==UART5)
|
/* UART5 interrupt Deinit */
|
||||||
{
|
HAL_NVIC_DisableIRQ(UART5_IRQn);
|
||||||
/* USER CODE BEGIN UART5_MspDeInit 0 */
|
/* USER CODE BEGIN UART5_MspDeInit 1 */
|
||||||
|
|
||||||
/* USER CODE END UART5_MspDeInit 0 */
|
/* USER CODE END UART5_MspDeInit 1 */
|
||||||
/* Peripheral clock disable */
|
}
|
||||||
__HAL_RCC_UART5_CLK_DISABLE();
|
else if(uartHandle->Instance==USART1)
|
||||||
|
{
|
||||||
/**UART5 GPIO Configuration
|
/* USER CODE BEGIN USART1_MspDeInit 0 */
|
||||||
PC12 ------> UART5_TX
|
|
||||||
PD2 ------> UART5_RX
|
/* USER CODE END USART1_MspDeInit 0 */
|
||||||
*/
|
/* Peripheral clock disable */
|
||||||
HAL_GPIO_DeInit(GPIOC, GPIO_PIN_12);
|
__HAL_RCC_USART1_CLK_DISABLE();
|
||||||
|
|
||||||
HAL_GPIO_DeInit(GPIOD, GPIO_PIN_2);
|
/**USART1 GPIO Configuration
|
||||||
|
PA9 ------> USART1_TX
|
||||||
/* UART5 interrupt Deinit */
|
PA10 ------> USART1_RX
|
||||||
HAL_NVIC_DisableIRQ(UART5_IRQn);
|
*/
|
||||||
/* USER CODE BEGIN UART5_MspDeInit 1 */
|
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
|
||||||
|
|
||||||
/* USER CODE END UART5_MspDeInit 1 */
|
/* USART1 interrupt Deinit */
|
||||||
}
|
HAL_NVIC_DisableIRQ(USART1_IRQn);
|
||||||
else if(uartHandle->Instance==USART1)
|
/* USER CODE BEGIN USART1_MspDeInit 1 */
|
||||||
{
|
|
||||||
/* USER CODE BEGIN USART1_MspDeInit 0 */
|
/* USER CODE END USART1_MspDeInit 1 */
|
||||||
|
}
|
||||||
/* USER CODE END USART1_MspDeInit 0 */
|
else if(uartHandle->Instance==USART2)
|
||||||
/* Peripheral clock disable */
|
{
|
||||||
__HAL_RCC_USART1_CLK_DISABLE();
|
/* USER CODE BEGIN USART2_MspDeInit 0 */
|
||||||
|
|
||||||
/**USART1 GPIO Configuration
|
/* USER CODE END USART2_MspDeInit 0 */
|
||||||
PA9 ------> USART1_TX
|
/* Peripheral clock disable */
|
||||||
PA10 ------> USART1_RX
|
__HAL_RCC_USART2_CLK_DISABLE();
|
||||||
*/
|
|
||||||
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
|
/**USART2 GPIO Configuration
|
||||||
|
PD5 ------> USART2_TX
|
||||||
/* USART1 interrupt Deinit */
|
PD6 ------> USART2_RX
|
||||||
HAL_NVIC_DisableIRQ(USART1_IRQn);
|
*/
|
||||||
/* USER CODE BEGIN USART1_MspDeInit 1 */
|
HAL_GPIO_DeInit(GPIOD, GPIO_PIN_5|GPIO_PIN_6);
|
||||||
|
|
||||||
/* USER CODE END USART1_MspDeInit 1 */
|
/* USART2 DMA DeInit */
|
||||||
}
|
HAL_DMA_DeInit(uartHandle->hdmarx);
|
||||||
else if(uartHandle->Instance==USART2)
|
HAL_DMA_DeInit(uartHandle->hdmatx);
|
||||||
{
|
|
||||||
/* USER CODE BEGIN USART2_MspDeInit 0 */
|
/* USART2 interrupt Deinit */
|
||||||
|
HAL_NVIC_DisableIRQ(USART2_IRQn);
|
||||||
/* USER CODE END USART2_MspDeInit 0 */
|
/* USER CODE BEGIN USART2_MspDeInit 1 */
|
||||||
/* Peripheral clock disable */
|
|
||||||
__HAL_RCC_USART2_CLK_DISABLE();
|
/* USER CODE END USART2_MspDeInit 1 */
|
||||||
|
}
|
||||||
/**USART2 GPIO Configuration
|
else if(uartHandle->Instance==USART3)
|
||||||
PD5 ------> USART2_TX
|
{
|
||||||
PD6 ------> USART2_RX
|
/* USER CODE BEGIN USART3_MspDeInit 0 */
|
||||||
*/
|
|
||||||
HAL_GPIO_DeInit(GPIOD, GPIO_PIN_5|GPIO_PIN_6);
|
/* USER CODE END USART3_MspDeInit 0 */
|
||||||
|
/* Peripheral clock disable */
|
||||||
/* USART2 DMA DeInit */
|
__HAL_RCC_USART3_CLK_DISABLE();
|
||||||
HAL_DMA_DeInit(uartHandle->hdmarx);
|
|
||||||
HAL_DMA_DeInit(uartHandle->hdmatx);
|
/**USART3 GPIO Configuration
|
||||||
|
PC10 ------> USART3_TX
|
||||||
/* USART2 interrupt Deinit */
|
PC11 ------> USART3_RX
|
||||||
HAL_NVIC_DisableIRQ(USART2_IRQn);
|
*/
|
||||||
/* USER CODE BEGIN USART2_MspDeInit 1 */
|
HAL_GPIO_DeInit(GPIOC, GPIO_PIN_10|GPIO_PIN_11);
|
||||||
|
|
||||||
/* USER CODE END USART2_MspDeInit 1 */
|
/* USART3 DMA DeInit */
|
||||||
}
|
HAL_DMA_DeInit(uartHandle->hdmarx);
|
||||||
else if(uartHandle->Instance==USART3)
|
HAL_DMA_DeInit(uartHandle->hdmatx);
|
||||||
{
|
|
||||||
/* USER CODE BEGIN USART3_MspDeInit 0 */
|
/* USART3 interrupt Deinit */
|
||||||
|
HAL_NVIC_DisableIRQ(USART3_IRQn);
|
||||||
/* USER CODE END USART3_MspDeInit 0 */
|
/* USER CODE BEGIN USART3_MspDeInit 1 */
|
||||||
/* Peripheral clock disable */
|
|
||||||
__HAL_RCC_USART3_CLK_DISABLE();
|
/* USER CODE END USART3_MspDeInit 1 */
|
||||||
|
}
|
||||||
/**USART3 GPIO Configuration
|
}
|
||||||
PC10 ------> USART3_TX
|
|
||||||
PC11 ------> USART3_RX
|
/* USER CODE BEGIN 1 */
|
||||||
*/
|
|
||||||
HAL_GPIO_DeInit(GPIOC, GPIO_PIN_10|GPIO_PIN_11);
|
/* USER CODE END 1 */
|
||||||
|
|
||||||
/* USART3 DMA DeInit */
|
|
||||||
HAL_DMA_DeInit(uartHandle->hdmarx);
|
|
||||||
HAL_DMA_DeInit(uartHandle->hdmatx);
|
|
||||||
|
|
||||||
/* USART3 interrupt Deinit */
|
|
||||||
HAL_NVIC_DisableIRQ(USART3_IRQn);
|
|
||||||
/* USER CODE BEGIN USART3_MspDeInit 1 */
|
|
||||||
|
|
||||||
/* USER CODE END USART3_MspDeInit 1 */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
+3651
-3658
File diff suppressed because it is too large
Load Diff
+22696
-22752
File diff suppressed because it is too large
Load Diff
+2019
-2087
File diff suppressed because it is too large
Load Diff
+3650
-3658
File diff suppressed because it is too large
Load Diff
@@ -1,5 +1,5 @@
|
|||||||
../Core/Src/adc.c:29:6:ADC_ScanStart 2
|
../Core/Src/adc.c:13:6:ADC_ScanStart 2
|
||||||
../Core/Src/adc.c:37:15:HAL_ADC_ConvCpltCallback 2
|
../Core/Src/adc.c:21:15:HAL_ADC_ConvCpltCallback 2
|
||||||
../Core/Src/adc.c:59:6:MX_ADC1_Init 8
|
../Core/Src/adc.c:43:6:MX_ADC1_Init 8
|
||||||
../Core/Src/adc.c:146:6:HAL_ADC_MspInit 3
|
../Core/Src/adc.c:130:6:HAL_ADC_MspInit 3
|
||||||
../Core/Src/adc.c:200:6:HAL_ADC_MspDeInit 2
|
../Core/Src/adc.c:184:6:HAL_ADC_MspDeInit 2
|
||||||
|
|||||||
+13
-13
@@ -1,13 +1,13 @@
|
|||||||
../Core/Src/board.c:18:6:RELAY_Write 9
|
../Core/Src/board.c:14:6:RELAY_Write 9
|
||||||
../Core/Src/board.c:51:9:RELAY_Read 1
|
../Core/Src/board.c:47:9:RELAY_Read 1
|
||||||
../Core/Src/board.c:56:9:IN_ReadInput 8
|
../Core/Src/board.c:52:9:IN_ReadInput 8
|
||||||
../Core/Src/board.c:77:9:GetBoardTemp 1
|
../Core/Src/board.c:74:9:GetBoardTemp 1
|
||||||
../Core/Src/board.c:89:6:Init_Peripheral 1
|
../Core/Src/board.c:78:6:Init_Peripheral 1
|
||||||
../Core/Src/board.c:106:7:pt1000_to_temperature 1
|
../Core/Src/board.c:95:7:pt1000_to_temperature 1
|
||||||
../Core/Src/board.c:117:7:calculate_NTC_resistance 2
|
../Core/Src/board.c:106:7:calculate_NTC_resistance 2
|
||||||
../Core/Src/board.c:132:9:CONN_ReadTemp 4
|
../Core/Src/board.c:121:9:CONN_ReadTemp 4
|
||||||
../Core/Src/board.c:152:9:GBT_ReadTemp 1
|
../Core/Src/board.c:140:9:GBT_ReadTemp 1
|
||||||
../Core/Src/board.c:156:6:ADC_Select_Channel 2
|
../Core/Src/board.c:144:6:ADC_Select_Channel 2
|
||||||
../Core/Src/board.c:167:9:ADC_TryLock 4
|
../Core/Src/board.c:155:9:ADC_TryLock 4
|
||||||
../Core/Src/board.c:183:6:ADC_LockBlocking 2
|
../Core/Src/board.c:171:6:ADC_LockBlocking 2
|
||||||
../Core/Src/board.c:189:6:ADC_Unlock 2
|
../Core/Src/board.c:177:6:ADC_Unlock 2
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
../Core/Src/can.c:31:6:MX_CAN1_Init 2
|
../Core/Src/can.c:15:6:MX_CAN1_Init 2
|
||||||
../Core/Src/can.c:63:6:MX_CAN2_Init 2
|
../Core/Src/can.c:47:6:MX_CAN2_Init 2
|
||||||
../Core/Src/can.c:97:6:HAL_CAN_MspInit 5
|
../Core/Src/can.c:81:6:HAL_CAN_MspInit 5
|
||||||
../Core/Src/can.c:176:6:HAL_CAN_MspDeInit 5
|
../Core/Src/can.c:160:6:HAL_CAN_MspDeInit 5
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
../Core/Src/charger_control.c:12:6:CONN_Init 1
|
../Core/Src/charger_control.c:10:6:CONN_Init 1
|
||||||
../Core/Src/charger_control.c:20:6:CONN_Loop 6
|
../Core/Src/charger_control.c:18:6:CONN_Loop 6
|
||||||
../Core/Src/charger_control.c:42:6:CONN_Task 1
|
../Core/Src/charger_control.c:39:6:CONN_SetState 16
|
||||||
../Core/Src/charger_control.c:49:6:CONN_SetState 16
|
|
||||||
../Core/Src/charger_control.c:75:6:CONN_PrintChargingTotal 1
|
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
../Core/Src/cp.c:19:16:CP_ReadVoltageMv 1
|
../Core/Src/cp.c:20:16:CP_ReadVoltageMv 1
|
||||||
../Core/Src/cp.c:36:6:CP_Init 1
|
../Core/Src/cp.c:37:6:CP_Init 1
|
||||||
../Core/Src/cp.c:53:6:CP_SetDuty 1
|
../Core/Src/cp.c:54:6:CP_SetDuty 1
|
||||||
../Core/Src/cp.c:66:9:CP_GetDuty 1
|
../Core/Src/cp.c:67:9:CP_GetDuty 1
|
||||||
../Core/Src/cp.c:70:9:CP_GetVoltage 1
|
../Core/Src/cp.c:71:9:CP_GetVoltage 1
|
||||||
../Core/Src/cp.c:75:12:CP_GetState 12
|
../Core/Src/cp.c:76:12:CP_GetState 12
|
||||||
../Core/Src/cp.c:99:12:CP_GetFilteredState 1
|
../Core/Src/cp.c:100:12:CP_GetFilteredState 1
|
||||||
../Core/Src/cp.c:103:6:CP_FilterState 5
|
../Core/Src/cp.c:104:6:CP_FilterState 5
|
||||||
../Core/Src/cp.c:131:6:CP_Loop 5
|
../Core/Src/cp.c:132:6:CP_Loop 5
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
../Core/Src/crc.c:30:6:MX_CRC_Init 2
|
../Core/Src/crc.c:14:6:MX_CRC_Init 2
|
||||||
../Core/Src/crc.c:51:6:HAL_CRC_MspInit 2
|
../Core/Src/crc.c:35:6:HAL_CRC_MspInit 2
|
||||||
../Core/Src/crc.c:67:6:HAL_CRC_MspDeInit 2
|
../Core/Src/crc.c:51:6:HAL_CRC_MspDeInit 2
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
../Core/Src/debug.c:42:5:_write 1
|
../Core/Src/debug.c:35:5:_write 1
|
||||||
../Core/Src/debug.c:50:6:debug_buffer_add 3
|
../Core/Src/debug.c:43:6:debug_buffer_add 3
|
||||||
../Core/Src/debug.c:70:10:debug_buffer_available 1
|
../Core/Src/debug.c:63:10:debug_buffer_available 1
|
||||||
../Core/Src/debug.c:79:6:debug_buffer_send 5
|
../Core/Src/debug.c:72:6:debug_buffer_send 5
|
||||||
../Core/Src/debug.c:119:5:log_printf 3
|
../Core/Src/debug.c:112:5:log_printf 3
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
../Core/Src/dma.c:39:6:MX_DMA_Init 1
|
../Core/Src/dma.c:23:6:MX_DMA_Init 1
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
../Core/Src/gpio.c:44:6:MX_GPIO_Init 1
|
../Core/Src/gpio.c:28:6:MX_GPIO_Init 1
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
../Drivers/CMSIS/Include/core_cm3.h:1762:34:__NVIC_SystemReset 1
|
../Drivers/CMSIS/Include/core_cm3.h:1762:34:__NVIC_SystemReset 1
|
||||||
../Core/Src/main.c:65:13:VectorBase_Config 1
|
../Core/Src/main.c:69:13:VectorBase_Config 1
|
||||||
../Core/Src/main.c:76:9:ED_TraceWarning 3
|
../Core/Src/main.c:80:9:ED_TraceWarning 3
|
||||||
../Core/Src/main.c:88:6:ED_Delay 3
|
../Core/Src/main.c:92:6:ED_Delay 3
|
||||||
../Core/Src/main.c:108:6:StopButtonControl 8
|
../Core/Src/main.c:111:13:StopButtonControl 8
|
||||||
../Core/Src/main.c:151:13:CAN1_MinimalReInit 3
|
../Core/Src/main.c:152:13:CAN1_MinimalReInit 3
|
||||||
../Core/Src/main.c:169:5:main 1
|
../Core/Src/main.c:170:5:main 1
|
||||||
../Core/Src/main.c:250:6:SystemClock_Config 4
|
../Core/Src/main.c:251:6:SystemClock_Config 4
|
||||||
../Core/Src/main.c:310:6:Error_Handler 1
|
../Core/Src/main.c:311:6:Error_Handler 1
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
../Core/Src/meter.c:17:6:METER_CalculateEnergy 3
|
../Core/Src/meter.c:9:6:METER_CalculateEnergy 3
|
||||||
|
|||||||
@@ -1,12 +1,11 @@
|
|||||||
../Core/Src/psu_control.c:34:13:PSU_SwitchState 1
|
../Core/Src/psu_control.c:35:13:PSU_SwitchState 1
|
||||||
../Core/Src/psu_control.c:39:17:PSU_StateTime 1
|
../Core/Src/psu_control.c:40:17:PSU_StateTime 1
|
||||||
../Core/Src/psu_control.c:43:15:HAL_CAN_RxFifo1MsgPendingCallback 9
|
../Core/Src/psu_control.c:44:15:HAL_CAN_RxFifo1MsgPendingCallback 9
|
||||||
../Core/Src/psu_control.c:117:6:PSU_CAN_FilterInit 2
|
../Core/Src/psu_control.c:118:6:PSU_CAN_FilterInit 2
|
||||||
../Core/Src/psu_control.c:140:6:PSU_Init 1
|
../Core/Src/psu_control.c:141:6:PSU_Init 1
|
||||||
../Core/Src/psu_control.c:158:6:PSU_Enable 3
|
../Core/Src/psu_control.c:159:6:PSU_Enable 3
|
||||||
../Core/Src/psu_control.c:170:6:PSU_SetHVMode 2
|
../Core/Src/psu_control.c:171:6:PSU_SetHVMode 2
|
||||||
../Core/Src/psu_control.c:177:6:PSU_SetVoltageCurrent 5
|
../Core/Src/psu_control.c:178:6:PSU_SetVoltageCurrent 5
|
||||||
../Core/Src/psu_control.c:204:6:PSU_SendCmd 4
|
../Core/Src/psu_control.c:205:6:PSU_SendCmd 4
|
||||||
../Core/Src/psu_control.c:240:10:max 2
|
../Core/Src/psu_control.c:240:6:PSU_ReadWrite 8
|
||||||
../Core/Src/psu_control.c:245:6:PSU_ReadWrite 8
|
../Core/Src/psu_control.c:281:6:PSU_Task 41
|
||||||
../Core/Src/psu_control.c:289:6:PSU_Task 41
|
|
||||||
|
|||||||
@@ -3,4 +3,4 @@
|
|||||||
../Core/Src/rgb_controller.c:182:6:RGB_SetColor 1
|
../Core/Src/rgb_controller.c:182:6:RGB_SetColor 1
|
||||||
../Core/Src/rgb_controller.c:188:6:LED_SetColor 1
|
../Core/Src/rgb_controller.c:188:6:LED_SetColor 1
|
||||||
../Core/Src/rgb_controller.c:193:6:LED_Init 1
|
../Core/Src/rgb_controller.c:193:6:LED_Init 1
|
||||||
../Core/Src/rgb_controller.c:225:6:LED_Task 10
|
../Core/Src/rgb_controller.c:201:6:LED_Task 10
|
||||||
|
|||||||
+20
-20
@@ -1,20 +1,20 @@
|
|||||||
../Core/Src/serial.c:70:22:uart3_log_hal_error 3
|
../Core/Src/serial.c:65:22:uart3_log_hal_error 3
|
||||||
../Core/Src/serial.c:90:22:uart3_arm_rx_or_log 3
|
../Core/Src/serial.c:85:22:uart3_arm_rx_or_log 3
|
||||||
../Core/Src/serial.c:106:15:CCS_RxEventCallback 4
|
../Core/Src/serial.c:101:15:CCS_RxEventCallback 4
|
||||||
../Core/Src/serial.c:129:15:HAL_UART_ErrorCallback 5
|
../Core/Src/serial.c:124:15:HAL_UART_ErrorCallback 5
|
||||||
../Core/Src/serial.c:149:6:CCS_TxCpltCallback 4
|
../Core/Src/serial.c:144:6:CCS_TxCpltCallback 4
|
||||||
../Core/Src/serial.c:165:6:CCS_SerialLoop 62
|
../Core/Src/serial.c:160:6:CCS_SerialLoop 62
|
||||||
../Core/Src/serial.c:365:6:CCS_Init 1
|
../Core/Src/serial.c:360:6:CCS_Init 1
|
||||||
../Core/Src/serial.c:380:26:crc16_ibm 3
|
../Core/Src/serial.c:375:26:crc16_ibm 3
|
||||||
../Core/Src/serial.c:395:17:CCS_BuildPacket 4
|
../Core/Src/serial.c:390:17:CCS_BuildPacket 4
|
||||||
../Core/Src/serial.c:411:13:CCS_SendPacket 4
|
../Core/Src/serial.c:406:13:CCS_SendPacket 4
|
||||||
../Core/Src/serial.c:428:13:CCS_SendResetReason 1
|
../Core/Src/serial.c:423:13:CCS_SendResetReason 1
|
||||||
../Core/Src/serial.c:432:6:CCS_SendEmergencyStop 1
|
../Core/Src/serial.c:427:6:CCS_SendEmergencyStop 1
|
||||||
../Core/Src/serial.c:436:6:CCS_SendStart 1
|
../Core/Src/serial.c:431:6:CCS_SendStart 1
|
||||||
../Core/Src/serial.c:440:13:CCS_CalculateEnergy 2
|
../Core/Src/serial.c:435:13:CCS_CalculateEnergy 2
|
||||||
../Core/Src/serial.c:455:13:send_state 3
|
../Core/Src/serial.c:450:13:send_state 3
|
||||||
../Core/Src/serial.c:485:26:expected_payload_len 2
|
../Core/Src/serial.c:480:26:expected_payload_len 2
|
||||||
../Core/Src/serial.c:501:22:apply_command 15
|
../Core/Src/serial.c:496:22:apply_command 15
|
||||||
../Core/Src/serial.c:583:25:process_received_packet 8
|
../Core/Src/serial.c:578:25:process_received_packet 8
|
||||||
../Core/Src/serial.c:636:13:CCS_UART3_Watchdog 4
|
../Core/Src/serial.c:631:13:CCS_UART3_Watchdog 4
|
||||||
../Core/Src/serial.c:649:13:CCS_LogUart3Error 1
|
../Core/Src/serial.c:644:13:CCS_LogUart3Error 1
|
||||||
|
|||||||
@@ -1,15 +1,15 @@
|
|||||||
../Core/Src/serial_control.c:71:6:ReadVersion 1
|
../Core/Src/serial_control.c:72:6:ReadVersion 1
|
||||||
../Core/Src/serial_control.c:83:6:SC_Init 1
|
../Core/Src/serial_control.c:84:6:SC_Init 1
|
||||||
../Core/Src/serial_control.c:94:6:SC_Task 7
|
../Core/Src/serial_control.c:95:6:SC_Task 7
|
||||||
../Core/Src/serial_control.c:122:15:HAL_UARTEx_RxEventCallback 8
|
../Core/Src/serial_control.c:123:15:HAL_UARTEx_RxEventCallback 8
|
||||||
../Core/Src/serial_control.c:152:15:HAL_UART_TxCpltCallback 3
|
../Core/Src/serial_control.c:153:15:HAL_UART_TxCpltCallback 3
|
||||||
../Core/Src/serial_control.c:163:26:calculate_crc32 3
|
../Core/Src/serial_control.c:164:26:calculate_crc32 3
|
||||||
../Core/Src/serial_control.c:180:26:encode_packet 5
|
../Core/Src/serial_control.c:181:26:encode_packet 5
|
||||||
../Core/Src/serial_control.c:213:15:SC_SendPacket 4
|
../Core/Src/serial_control.c:214:15:SC_SendPacket 4
|
||||||
../Core/Src/serial_control.c:230:25:parse_packet 3
|
../Core/Src/serial_control.c:231:25:parse_packet 3
|
||||||
../Core/Src/serial_control.c:263:25:process_received_packet 2
|
../Core/Src/serial_control.c:264:25:process_received_packet 2
|
||||||
../Core/Src/serial_control.c:272:13:SC_UART2_Watchdog 5
|
../Core/Src/serial_control.c:273:13:SC_UART2_Watchdog 5
|
||||||
../Core/Src/serial_control.c:293:13:SC_ArmUart2RxDma 4
|
../Core/Src/serial_control.c:294:13:SC_ArmUart2RxDma 4
|
||||||
../Core/Src/serial_control.c:301:13:SC_ArmUart5RxDma 3
|
../Core/Src/serial_control.c:302:13:SC_ArmUart5RxDma 3
|
||||||
../Core/Src/serial_control.c:310:6:SC_RecoverUartDma 3
|
../Core/Src/serial_control.c:311:6:SC_RecoverUartDma 3
|
||||||
../Core/Src/serial_control.c:325:13:SC_LogUartError 3
|
../Core/Src/serial_control.c:326:13:SC_LogUartError 3
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
../Drivers/CMSIS/Include/core_cm3.h:1762:34:__NVIC_SystemReset 1
|
../Drivers/CMSIS/Include/core_cm3.h:1762:34:__NVIC_SystemReset 1
|
||||||
../Core/Src/serial_handler.c:26:6:SC_CommandHandler 19
|
../Core/Src/serial_handler.c:26:6:SC_CommandHandler 19
|
||||||
../Core/Src/serial_handler.c:125:6:monitoring_data_callback 1
|
../Core/Src/serial_handler.c:125:13:monitoring_data_callback 1
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
../Core/Src/soft_rtc.c:22:10:get_Current_Time 1
|
../Core/Src/soft_rtc.c:15:10:get_Current_Time 1
|
||||||
../Core/Src/soft_rtc.c:26:6:set_Time 1
|
../Core/Src/soft_rtc.c:19:6:set_Time 1
|
||||||
../Core/Src/soft_rtc.c:30:9:to_bcd 1
|
../Core/Src/soft_rtc.c:23:9:to_bcd 1
|
||||||
../Core/Src/soft_rtc.c:34:6:unix_to_bcd 1
|
../Core/Src/soft_rtc.c:27:6:unix_to_bcd 1
|
||||||
../Core/Src/soft_rtc.c:48:6:writeTimeReg 2
|
../Core/Src/soft_rtc.c:41:6:writeTimeReg 2
|
||||||
../Core/Src/soft_rtc.c:53:9:getTimeReg 5
|
../Core/Src/soft_rtc.c:46:9:getTimeReg 5
|
||||||
../Core/Src/soft_rtc.c:87:17:RTC1_ReadTimeCounter 2
|
../Core/Src/soft_rtc.c:67:17:RTC1_ReadTimeCounter 2
|
||||||
../Core/Src/soft_rtc.c:119:26:RTC1_WriteTimeCounter 3
|
../Core/Src/soft_rtc.c:99:26:RTC1_WriteTimeCounter 3
|
||||||
../Core/Src/soft_rtc.c:151:26:RTC1_EnterInitMode 3
|
../Core/Src/soft_rtc.c:131:26:RTC1_EnterInitMode 3
|
||||||
../Core/Src/soft_rtc.c:178:26:RTC1_ExitInitMode 3
|
../Core/Src/soft_rtc.c:158:26:RTC1_ExitInitMode 3
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
../Core/Src/stm32f1xx_hal_msp.c:63:6:HAL_MspInit 1
|
../Core/Src/stm32f1xx_hal_msp.c:47:6:HAL_MspInit 1
|
||||||
|
|||||||
@@ -1,23 +1,23 @@
|
|||||||
../Core/Src/stm32f1xx_it.c:84:6:NMI_Handler 1
|
../Core/Src/stm32f1xx_it.c:69:6:NMI_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:99:6:HardFault_Handler 1
|
../Core/Src/stm32f1xx_it.c:84:6:HardFault_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:114:6:MemManage_Handler 1
|
../Core/Src/stm32f1xx_it.c:99:6:MemManage_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:129:6:BusFault_Handler 1
|
../Core/Src/stm32f1xx_it.c:114:6:BusFault_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:144:6:UsageFault_Handler 1
|
../Core/Src/stm32f1xx_it.c:129:6:UsageFault_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:159:6:SVC_Handler 1
|
../Core/Src/stm32f1xx_it.c:144:6:SVC_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:172:6:DebugMon_Handler 1
|
../Core/Src/stm32f1xx_it.c:157:6:DebugMon_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:185:6:PendSV_Handler 1
|
../Core/Src/stm32f1xx_it.c:170:6:PendSV_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:198:6:SysTick_Handler 1
|
../Core/Src/stm32f1xx_it.c:183:6:SysTick_Handler 1
|
||||||
../Core/Src/stm32f1xx_it.c:219:6:DMA1_Channel1_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:204:6:DMA1_Channel1_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:233:6:DMA1_Channel2_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:218:6:DMA1_Channel2_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:247:6:DMA1_Channel3_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:232:6:DMA1_Channel3_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:261:6:DMA1_Channel6_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:246:6:DMA1_Channel6_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:275:6:DMA1_Channel7_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:260:6:DMA1_Channel7_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:289:6:ADC1_2_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:274:6:ADC1_2_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:303:6:CAN1_RX0_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:288:6:CAN1_RX0_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:317:6:TIM3_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:302:6:TIM3_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:331:6:USART1_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:316:6:USART1_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:345:6:USART2_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:330:6:USART2_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:359:6:USART3_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:344:6:USART3_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:373:6:UART5_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:358:6:UART5_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:387:6:CAN2_TX_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:372:6:CAN2_TX_IRQHandler 1
|
||||||
../Core/Src/stm32f1xx_it.c:401:6:CAN2_RX1_IRQHandler 1
|
../Core/Src/stm32f1xx_it.c:386:6:CAN2_RX1_IRQHandler 1
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
../Core/Src/tim.c:31:6:MX_TIM3_Init 8
|
../Core/Src/tim.c:15:6:MX_TIM3_Init 8
|
||||||
../Core/Src/tim.c:95:6:MX_TIM4_Init 8
|
../Core/Src/tim.c:79:6:MX_TIM4_Init 8
|
||||||
../Core/Src/tim.c:157:6:HAL_TIM_Base_MspInit 3
|
../Core/Src/tim.c:141:6:HAL_TIM_Base_MspInit 3
|
||||||
../Core/Src/tim.c:187:6:HAL_TIM_MspPostInit 3
|
../Core/Src/tim.c:171:6:HAL_TIM_MspPostInit 3
|
||||||
../Core/Src/tim.c:235:6:HAL_TIM_Base_MspDeInit 3
|
../Core/Src/tim.c:219:6:HAL_TIM_Base_MspDeInit 3
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
../Core/Src/usart.c:37:6:MX_UART5_Init 2
|
../Core/Src/usart.c:21:6:MX_UART5_Init 2
|
||||||
../Core/Src/usart.c:66:6:MX_USART1_UART_Init 2
|
../Core/Src/usart.c:50:6:MX_USART1_UART_Init 2
|
||||||
../Core/Src/usart.c:95:6:MX_USART2_UART_Init 2
|
../Core/Src/usart.c:79:6:MX_USART2_UART_Init 2
|
||||||
../Core/Src/usart.c:124:6:MX_USART3_UART_Init 2
|
../Core/Src/usart.c:108:6:MX_USART3_UART_Init 2
|
||||||
../Core/Src/usart.c:152:6:HAL_UART_MspInit 9
|
../Core/Src/usart.c:136:6:HAL_UART_MspInit 9
|
||||||
../Core/Src/usart.c:349:6:HAL_UART_MspDeInit 5
|
../Core/Src/usart.c:333:6:HAL_UART_MspDeInit 5
|
||||||
|
|||||||
+2
-2
@@ -69,8 +69,8 @@ all: main-build
|
|||||||
main-build: CCSModuleSW30Web.elf secondary-outputs
|
main-build: CCSModuleSW30Web.elf secondary-outputs
|
||||||
|
|
||||||
# Tool invocations
|
# Tool invocations
|
||||||
CCSModuleSW30Web.elf CCSModuleSW30Web.map: $(OBJS) $(USER_OBJS) /Users/colorbass/STM32CubeIDE/workspace_1.12.0/fork/CCSModuleSW30Web/STM32F107VCTX_FLASH.ld makefile objects.list $(OPTIONAL_TOOL_DEPS)
|
CCSModuleSW30Web.elf CCSModuleSW30Web.map: $(OBJS) $(USER_OBJS) /Users/colorbass/STM32CubeIDE/workspace_1.12.0/CCSModuleSW30Web/STM32F107VCTX_FLASH.ld makefile objects.list $(OPTIONAL_TOOL_DEPS)
|
||||||
arm-none-eabi-gcc -o "CCSModuleSW30Web.elf" @"objects.list" $(USER_OBJS) $(LIBS) -mcpu=cortex-m3 -T"/Users/colorbass/STM32CubeIDE/workspace_1.12.0/fork/CCSModuleSW30Web/STM32F107VCTX_FLASH.ld" --specs=nosys.specs -Wl,-Map="CCSModuleSW30Web.map" -Wl,--gc-sections -static --specs=nano.specs -mfloat-abi=soft -mthumb -u _printf_float -Wl,--start-group -lc -lm -Wl,--end-group
|
arm-none-eabi-gcc -o "CCSModuleSW30Web.elf" @"objects.list" $(USER_OBJS) $(LIBS) -mcpu=cortex-m3 -T"/Users/colorbass/STM32CubeIDE/workspace_1.12.0/CCSModuleSW30Web/STM32F107VCTX_FLASH.ld" --specs=nosys.specs -Wl,-Map="CCSModuleSW30Web.map" -Wl,--gc-sections -Wl,--no-warn-rwx-segments -static --specs=nano.specs -mfloat-abi=soft -mthumb -u _printf_float -Wl,--start-group -lc -lm -Wl,--end-group
|
||||||
@echo 'Finished building target: $@'
|
@echo 'Finished building target: $@'
|
||||||
@echo ' '
|
@echo ' '
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +0,0 @@
|
|||||||
MIT License
|
|
||||||
|
|
||||||
Copyright (c) 2024 EDISON
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
@@ -1,5 +1,141 @@
|
|||||||
# GbTModuleSW
|
# CCSModuleSW30Web
|
||||||
|
|
||||||
Программное обеспечение для блока управления зарядом Gb/T
|
Прошивка контроллера DC-зарядного модуля на STM32F107 (STM32CubeIDE).
|
||||||
|
Проект реализует управление зарядной сессией, обработку состояния EV по CP-линии, управление силовым блоком через CAN и обмен с верхним уровнем по UART.
|
||||||
|
|
||||||
Git-репозиторий: https://git.141922.ru/EDISON/GbTModuleSW30Web
|
## Архитектура прошивки
|
||||||
|
|
||||||
|
Логика разделена на несколько уровней:
|
||||||
|
|
||||||
|
- Оркестрация и планировщик задач: `Core/Src/main.c`
|
||||||
|
- Состояния зарядной сессии и протокол с Everest: `Core/Src/serial.c`
|
||||||
|
- Управление силовой частью и контакторами: `Core/Src/psu_control.c`
|
||||||
|
- Обработка CP (PWM/состояние EV): `Core/Src/cp.c`
|
||||||
|
- Единая модель состояния коннектора: `Core/Src/charger_control.c`, `Core/Inc/charger_control.h`
|
||||||
|
- Локальный протокол управления/мониторинга: `Core/Src/serial_control.c`, `Core/Src/serial_handler.c`
|
||||||
|
- Низкоуровневое управление платой: `Core/Src/board.c`, `Core/Src/gpio.c`, `Core/Src/can.c`, `Core/Src/usart.c`
|
||||||
|
|
||||||
|
## Основной цикл и выполнение задач
|
||||||
|
|
||||||
|
`main()` инициализирует периферию и подсистемы (`CCS_Init`, `SC_Init`, `PSU_Init`, `CONN_Init`), после чего переходит в бесконечный цикл.
|
||||||
|
|
||||||
|
В основном цикле выполняются:
|
||||||
|
|
||||||
|
- `PSU_ReadWrite()` — цикл опроса/команд силового блока и расчёт целевых значений.
|
||||||
|
- `PSU_Task()` — state machine силовой части, включение/выключение контакторов, контроль аварий.
|
||||||
|
- `METER_CalculateEnergy()` — расчёт энергии.
|
||||||
|
- `CONN_Loop()` — консолидация ошибок и общих флагов состояния сессии.
|
||||||
|
- `LED_Write()` — применение рассчитанного состояния индикации.
|
||||||
|
|
||||||
|
Ключевой механизм: `ED_Delay()` используется как кооперативный мини-планировщик и внутри задержки вызывает:
|
||||||
|
|
||||||
|
- `CCS_SerialLoop()` — обмен с Everest и переходы состояния коннектора;
|
||||||
|
- `StopButtonControl()` — обработка кнопки STOP/FORCE UNLOCK/RESET;
|
||||||
|
- `CP_Loop()` — чтение и фильтрация состояния CP;
|
||||||
|
- `CONN_Task()` — управление индикацией/сигнализацией;
|
||||||
|
- `LED_Task()` — анимация RGB;
|
||||||
|
- `SC_Task()` — локальный UART-протокол.
|
||||||
|
|
||||||
|
Таким образом, даже во время "задержек" критичные сервисные задачи продолжают выполняться.
|
||||||
|
|
||||||
|
## Модель управления зарядной сессией
|
||||||
|
|
||||||
|
Центр логики сессии находится в `CCS_SerialLoop()` (`serial.c`).
|
||||||
|
Она работает как state machine EVSE-стороны и переводит систему между состояниями:
|
||||||
|
|
||||||
|
- неизвестное/инициализация,
|
||||||
|
- отсутствие автомобиля,
|
||||||
|
- требование авторизации,
|
||||||
|
- подключено/заряд,
|
||||||
|
- режим переподключения,
|
||||||
|
- отключено по команде или по таймауту связи.
|
||||||
|
|
||||||
|
Переходы определяются комбинацией факторов:
|
||||||
|
|
||||||
|
- текущее состояние CP (автомобиль не подключен/подключен/готов),
|
||||||
|
- команды внешней системы (`start`, `stop`, `force unlock`),
|
||||||
|
- разрешение выдачи мощности (`EnableOutput`),
|
||||||
|
- наличие ошибок в силовой части и контакторах,
|
||||||
|
- состояние обмена с Everest.
|
||||||
|
|
||||||
|
Структура `CONN` выступает как единый контейнер рабочего состояния сессии, где сводятся:
|
||||||
|
|
||||||
|
- требуемые напряжение/ток,
|
||||||
|
- разрешение на выдачу мощности,
|
||||||
|
- команда оператора (start/stop/unlock),
|
||||||
|
- текущая стадия сессии,
|
||||||
|
- ошибки коннектора/силовой части.
|
||||||
|
|
||||||
|
## CP-линия и взаимодействие с EV
|
||||||
|
|
||||||
|
`cp.c` отвечает за:
|
||||||
|
|
||||||
|
- генерацию PWM на CP-линии (`CP_SetDuty`),
|
||||||
|
- измерение уровня CP и преобразование в дискретное состояние EV,
|
||||||
|
- цифровую фильтрацию переходов состояния (`CP_FilterState`) для подавления дребезга.
|
||||||
|
|
||||||
|
Команды верхнего уровня могут менять duty CP, что влияет на допустимый ток/режим со стороны EV.
|
||||||
|
Результат фильтрации CP непосредственно используется в state machine сессии (`serial.c`).
|
||||||
|
|
||||||
|
## Силовая часть и контакторы
|
||||||
|
|
||||||
|
`psu_control.c` реализует state machine источника питания и цепи контакторов:
|
||||||
|
|
||||||
|
- инициализация и проверка готовности PSU;
|
||||||
|
- отправка уставок напряжения/тока;
|
||||||
|
- включение/выключение силовой части;
|
||||||
|
- ожидание подтверждений и контроль таймаутов;
|
||||||
|
- контроль обратной связи контактора;
|
||||||
|
- аварийный останов при несогласованности состояния.
|
||||||
|
|
||||||
|
Управление силовыми выходами выполняется через реле платы (`RELAY_AC`, `RELAY_DC`), а факт замыкания контролируется входом обратной связи контактора.
|
||||||
|
При неисправностях флаги `contactor_fault`/`psu_fault` поднимаются и транслируются в общую модель `CONN`, что блокирует дальнейшую выдачу мощности.
|
||||||
|
|
||||||
|
## Интерфейсы обмена
|
||||||
|
|
||||||
|
### UART3: канал к Everest
|
||||||
|
|
||||||
|
`serial.c` реализует пакетный обмен с CRC:
|
||||||
|
|
||||||
|
- приём команд, их валидация и применение к текущей сессии;
|
||||||
|
- отправка телеметрии/состояния с фиксированной периодикой;
|
||||||
|
- обработка ошибок UART и восстановление DMA-приёма.
|
||||||
|
|
||||||
|
Встроен watchdog канала: при потере связи сначала выдаётся предупреждение, затем выполняется защитный переход в безопасное состояние с остановкой выдачи мощности.
|
||||||
|
|
||||||
|
### UART2/UART5: локальное управление и мониторинг
|
||||||
|
|
||||||
|
`serial_control.c` и `serial_handler.c` реализуют отдельный локальный протокол:
|
||||||
|
|
||||||
|
- разбор пакетов и CRC32-проверка;
|
||||||
|
- команды чтения состояния/информации;
|
||||||
|
- команды управления (разрешение заряда, ограничение мощности, reset и т.д.);
|
||||||
|
- публикация телеметрии.
|
||||||
|
|
||||||
|
### CAN2: управление силовым источником
|
||||||
|
|
||||||
|
`psu_control.c` использует CAN2 для обмена с PSU:
|
||||||
|
|
||||||
|
- передача управляющих команд и уставок;
|
||||||
|
- запрос/получение телеметрии;
|
||||||
|
- обработка приёмных кадров в callback и обновление внутренних переменных состояния.
|
||||||
|
|
||||||
|
## Защиты и отказобезопасность
|
||||||
|
|
||||||
|
В прошивке заложены независимые защитные механизмы:
|
||||||
|
|
||||||
|
- E-STOP (короткое/долгое/очень долгое удержание): stop, force unlock, reset.
|
||||||
|
- Потеря обмена с Everest: автоматическая остановка зарядки и перевод в безопасное состояние.
|
||||||
|
- Контроль контактора: проверка соответствия команды и физической обратной связи.
|
||||||
|
- Таймауты включения/выключения PSU: переход в fault при отсутствии ожидаемого подтверждения.
|
||||||
|
- Фильтрация CP-переходов: исключение ложных переключений от помех.
|
||||||
|
|
||||||
|
## Где смотреть ключевую логику в первую очередь
|
||||||
|
|
||||||
|
Для быстрого входа в проект:
|
||||||
|
|
||||||
|
- `Core/Src/main.c` — архитектурный "скелет" и расписание вызовов.
|
||||||
|
- `Core/Src/serial.c` — главная state machine зарядной сессии.
|
||||||
|
- `Core/Src/psu_control.c` — силовая логика, контакторы, fault-handling.
|
||||||
|
- `Core/Src/cp.c` — физика CP и распознавание состояния EV.
|
||||||
|
- `Core/Src/serial_control.c` + `Core/Src/serial_handler.c` — локальный протокол управления.
|
||||||
Reference in New Issue
Block a user