update to hal1.8.3
parent
b28818536a
commit
68e8de8642
|
@ -10,6 +10,7 @@
|
||||||
<extension id="org.eclipse.cdt.core.GmakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
<extension id="org.eclipse.cdt.core.GmakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
||||||
<extension id="org.eclipse.cdt.core.CWDLocator" point="org.eclipse.cdt.core.ErrorParser"/>
|
<extension id="org.eclipse.cdt.core.CWDLocator" point="org.eclipse.cdt.core.ErrorParser"/>
|
||||||
<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
||||||
|
<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
||||||
</extensions>
|
</extensions>
|
||||||
</storageModule>
|
</storageModule>
|
||||||
<storageModule moduleId="cdtBuildSystem" version="4.0.0">
|
<storageModule moduleId="cdtBuildSystem" version="4.0.0">
|
||||||
|
@ -103,6 +104,7 @@
|
||||||
<extension id="org.eclipse.cdt.core.GmakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
<extension id="org.eclipse.cdt.core.GmakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
||||||
<extension id="org.eclipse.cdt.core.CWDLocator" point="org.eclipse.cdt.core.ErrorParser"/>
|
<extension id="org.eclipse.cdt.core.CWDLocator" point="org.eclipse.cdt.core.ErrorParser"/>
|
||||||
<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
||||||
|
<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
|
||||||
</extensions>
|
</extensions>
|
||||||
</storageModule>
|
</storageModule>
|
||||||
<storageModule moduleId="cdtBuildSystem" version="4.0.0">
|
<storageModule moduleId="cdtBuildSystem" version="4.0.0">
|
||||||
|
|
76
.mxproject
76
.mxproject
File diff suppressed because one or more lines are too long
1
.project
1
.project
|
@ -29,5 +29,6 @@
|
||||||
<nature>com.st.stm32cube.ide.mcu.MCURootProjectNature</nature>
|
<nature>com.st.stm32cube.ide.mcu.MCURootProjectNature</nature>
|
||||||
<nature>org.eclipse.cdt.managedbuilder.core.managedBuildNature</nature>
|
<nature>org.eclipse.cdt.managedbuilder.core.managedBuildNature</nature>
|
||||||
<nature>org.eclipse.cdt.managedbuilder.core.ScannerConfigNature</nature>
|
<nature>org.eclipse.cdt.managedbuilder.core.ScannerConfigNature</nature>
|
||||||
|
<nature>com.st.stm32cube.ide.mcu.MCUCubeIdeServicesRevAev2ProjectNature</nature>
|
||||||
</natures>
|
</natures>
|
||||||
</projectDescription>
|
</projectDescription>
|
||||||
|
|
|
@ -42,9 +42,9 @@
|
||||||
* See http://www.freertos.org/a00110.html
|
* See http://www.freertos.org/a00110.html
|
||||||
*----------------------------------------------------------*/
|
*----------------------------------------------------------*/
|
||||||
|
|
||||||
/* USER CODE BEGIN Includes */
|
/* USER CODE BEGIN Includes */
|
||||||
/* Section where include file can be added */
|
/* Section where include file can be added */
|
||||||
/* USER CODE END Includes */
|
/* USER CODE END Includes */
|
||||||
|
|
||||||
/* Ensure definitions are only used by the compiler, and not by the assembler. */
|
/* Ensure definitions are only used by the compiler, and not by the assembler. */
|
||||||
#if defined(__ICCARM__) || defined(__CC_ARM) || defined(__GNUC__)
|
#if defined(__ICCARM__) || defined(__CC_ARM) || defined(__GNUC__)
|
||||||
|
@ -96,7 +96,7 @@ to exclude the API function. */
|
||||||
#define INCLUDE_eTaskGetState 1
|
#define INCLUDE_eTaskGetState 1
|
||||||
#define INCLUDE_xTaskGetHandle 1
|
#define INCLUDE_xTaskGetHandle 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The CMSIS-RTOS V2 FreeRTOS wrapper is dependent on the heap implementation used
|
* The CMSIS-RTOS V2 FreeRTOS wrapper is dependent on the heap implementation used
|
||||||
* by the application thus the correct define need to be enabled below
|
* by the application thus the correct define need to be enabled below
|
||||||
*/
|
*/
|
||||||
|
@ -140,11 +140,11 @@ standard names. */
|
||||||
|
|
||||||
/* IMPORTANT: This define is commented when used with STM32Cube firmware, when the timebase source is SysTick,
|
/* IMPORTANT: This define is commented when used with STM32Cube firmware, when the timebase source is SysTick,
|
||||||
to prevent overwriting SysTick_Handler defined within STM32Cube HAL */
|
to prevent overwriting SysTick_Handler defined within STM32Cube HAL */
|
||||||
|
|
||||||
#define xPortSysTickHandler SysTick_Handler
|
#define xPortSysTickHandler SysTick_Handler
|
||||||
|
|
||||||
/* USER CODE BEGIN Defines */
|
/* USER CODE BEGIN Defines */
|
||||||
/* Section where parameter definitions can be added (for instance, to override default ones in FreeRTOS.h) */
|
/* Section where parameter definitions can be added (for instance, to override default ones in FreeRTOS.h) */
|
||||||
/* USER CODE END Defines */
|
/* USER CODE END Defines */
|
||||||
|
|
||||||
#endif /* FREERTOS_CONFIG_H */
|
#endif /* FREERTOS_CONFIG_H */
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/**
|
/**
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
* File Name : gpio.h
|
* File Name : gpio.h
|
||||||
* Description : This file contains all the functions prototypes for
|
* Description : This file contains all the functions prototypes for
|
||||||
* the gpio
|
* the gpio
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
* @attention
|
* @attention
|
||||||
*
|
*
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
* opensource.org/licenses/BSD-3-Clause
|
* opensource.org/licenses/BSD-3-Clause
|
||||||
*
|
*
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
#ifndef __STM32F1xx_HAL_CONF_H
|
#ifndef __STM32F1xx_HAL_CONF_H
|
||||||
|
@ -29,10 +29,10 @@
|
||||||
|
|
||||||
/* ########################## Module Selection ############################## */
|
/* ########################## Module Selection ############################## */
|
||||||
/**
|
/**
|
||||||
* @brief This is the list of modules to be used in the HAL driver
|
* @brief This is the list of modules to be used in the HAL driver
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define HAL_MODULE_ENABLED
|
#define HAL_MODULE_ENABLED
|
||||||
#define HAL_ADC_MODULE_ENABLED
|
#define HAL_ADC_MODULE_ENABLED
|
||||||
/*#define HAL_CRYP_MODULE_ENABLED */
|
/*#define HAL_CRYP_MODULE_ENABLED */
|
||||||
/*#define HAL_CAN_MODULE_ENABLED */
|
/*#define HAL_CAN_MODULE_ENABLED */
|
||||||
|
@ -80,29 +80,29 @@
|
||||||
/**
|
/**
|
||||||
* @brief Adjust the value of External High Speed oscillator (HSE) used in your application.
|
* @brief Adjust the value of External High Speed oscillator (HSE) used in your application.
|
||||||
* This value is used by the RCC HAL module to compute the system frequency
|
* 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).
|
* (when HSE is used as system clock source, directly or through the PLL).
|
||||||
*/
|
*/
|
||||||
#if !defined (HSE_VALUE)
|
#if !defined (HSE_VALUE)
|
||||||
#define HSE_VALUE ((uint32_t)12000000) /*!< Value of the External oscillator in Hz */
|
#define HSE_VALUE 12000000U /*!< Value of the External oscillator in Hz */
|
||||||
#endif /* HSE_VALUE */
|
#endif /* HSE_VALUE */
|
||||||
|
|
||||||
#if !defined (HSE_STARTUP_TIMEOUT)
|
#if !defined (HSE_STARTUP_TIMEOUT)
|
||||||
#define HSE_STARTUP_TIMEOUT ((uint32_t)100) /*!< Time out for HSE start up, in ms */
|
#define HSE_STARTUP_TIMEOUT 100U /*!< Time out for HSE start up, in ms */
|
||||||
#endif /* HSE_STARTUP_TIMEOUT */
|
#endif /* HSE_STARTUP_TIMEOUT */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Internal High Speed oscillator (HSI) value.
|
* @brief Internal High Speed oscillator (HSI) value.
|
||||||
* This value is used by the RCC HAL module to compute the system frequency
|
* 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).
|
* (when HSI is used as system clock source, directly or through the PLL).
|
||||||
*/
|
*/
|
||||||
#if !defined (HSI_VALUE)
|
#if !defined (HSI_VALUE)
|
||||||
#define HSI_VALUE ((uint32_t)8000000) /*!< Value of the Internal oscillator in Hz*/
|
#define HSI_VALUE 8000000U /*!< Value of the Internal oscillator in Hz*/
|
||||||
#endif /* HSI_VALUE */
|
#endif /* HSI_VALUE */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Internal Low Speed oscillator (LSI) value.
|
* @brief Internal Low Speed oscillator (LSI) value.
|
||||||
*/
|
*/
|
||||||
#if !defined (LSI_VALUE)
|
#if !defined (LSI_VALUE)
|
||||||
#define LSI_VALUE 40000U /*!< LSI Typical Value in Hz */
|
#define LSI_VALUE 40000U /*!< LSI Typical Value in Hz */
|
||||||
#endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz
|
#endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz
|
||||||
The real value may vary depending on the variations
|
The real value may vary depending on the variations
|
||||||
|
@ -113,11 +113,11 @@
|
||||||
* This value is used by the UART, RTC HAL module to compute the system frequency
|
* This value is used by the UART, RTC HAL module to compute the system frequency
|
||||||
*/
|
*/
|
||||||
#if !defined (LSE_VALUE)
|
#if !defined (LSE_VALUE)
|
||||||
#define LSE_VALUE ((uint32_t)32768) /*!< Value of the External oscillator in Hz*/
|
#define LSE_VALUE 32768U /*!< Value of the External oscillator in Hz*/
|
||||||
#endif /* LSE_VALUE */
|
#endif /* LSE_VALUE */
|
||||||
|
|
||||||
#if !defined (LSE_STARTUP_TIMEOUT)
|
#if !defined (LSE_STARTUP_TIMEOUT)
|
||||||
#define LSE_STARTUP_TIMEOUT ((uint32_t)5000) /*!< Time out for LSE start up, in ms */
|
#define LSE_STARTUP_TIMEOUT 5000U /*!< Time out for LSE start up, in ms */
|
||||||
#endif /* LSE_STARTUP_TIMEOUT */
|
#endif /* LSE_STARTUP_TIMEOUT */
|
||||||
|
|
||||||
/* Tip: To avoid modifying this file each time you need to use different HSE,
|
/* Tip: To avoid modifying this file each time you need to use different HSE,
|
||||||
|
@ -126,11 +126,11 @@
|
||||||
/* ########################### System Configuration ######################### */
|
/* ########################### System Configuration ######################### */
|
||||||
/**
|
/**
|
||||||
* @brief This is the HAL system configuration section
|
* @brief This is the HAL system configuration section
|
||||||
*/
|
*/
|
||||||
#define VDD_VALUE ((uint32_t)3300) /*!< Value of VDD in mv */
|
#define VDD_VALUE 3300U /*!< Value of VDD in mv */
|
||||||
#define TICK_INT_PRIORITY ((uint32_t)0) /*!< tick interrupt priority (lowest by default) */
|
#define TICK_INT_PRIORITY 0U /*!< tick interrupt priority (lowest by default) */
|
||||||
#define USE_RTOS 0
|
#define USE_RTOS 0U
|
||||||
#define PREFETCH_ENABLE 1
|
#define PREFETCH_ENABLE 1U
|
||||||
|
|
||||||
#define USE_HAL_ADC_REGISTER_CALLBACKS 0U /* ADC register callback disabled */
|
#define USE_HAL_ADC_REGISTER_CALLBACKS 0U /* ADC register callback disabled */
|
||||||
#define USE_HAL_CAN_REGISTER_CALLBACKS 0U /* CAN register callback disabled */
|
#define USE_HAL_CAN_REGISTER_CALLBACKS 0U /* CAN register callback disabled */
|
||||||
|
@ -158,7 +158,7 @@
|
||||||
|
|
||||||
/* ########################## Assert Selection ############################## */
|
/* ########################## Assert Selection ############################## */
|
||||||
/**
|
/**
|
||||||
* @brief Uncomment the line below to expanse the "assert_param" macro in the
|
* @brief Uncomment the line below to expanse the "assert_param" macro in the
|
||||||
* HAL drivers code
|
* HAL drivers code
|
||||||
*/
|
*/
|
||||||
/* #define USE_FULL_ASSERT 1U */
|
/* #define USE_FULL_ASSERT 1U */
|
||||||
|
@ -168,36 +168,36 @@
|
||||||
/* Section 1 : Ethernet peripheral configuration */
|
/* Section 1 : Ethernet peripheral configuration */
|
||||||
|
|
||||||
/* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */
|
/* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */
|
||||||
#define MAC_ADDR0 2
|
#define MAC_ADDR0 2U
|
||||||
#define MAC_ADDR1 0
|
#define MAC_ADDR1 0U
|
||||||
#define MAC_ADDR2 0
|
#define MAC_ADDR2 0U
|
||||||
#define MAC_ADDR3 0
|
#define MAC_ADDR3 0U
|
||||||
#define MAC_ADDR4 0
|
#define MAC_ADDR4 0U
|
||||||
#define MAC_ADDR5 0
|
#define MAC_ADDR5 0U
|
||||||
|
|
||||||
/* Definition of the Ethernet driver buffers size and count */
|
/* Definition of the Ethernet driver buffers size and count */
|
||||||
#define ETH_RX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for receive */
|
#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 */
|
#define ETH_TX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for transmit */
|
||||||
#define ETH_RXBUFNB ((uint32_t)8) /* 4 Rx buffers of size ETH_RX_BUF_SIZE */
|
#define ETH_RXBUFNB 8U /* 4 Rx buffers of size ETH_RX_BUF_SIZE */
|
||||||
#define ETH_TXBUFNB ((uint32_t)4) /* 4 Tx buffers of size ETH_TX_BUF_SIZE */
|
#define ETH_TXBUFNB 4U /* 4 Tx buffers of size ETH_TX_BUF_SIZE */
|
||||||
|
|
||||||
/* Section 2: PHY configuration section */
|
/* Section 2: PHY configuration section */
|
||||||
|
|
||||||
/* DP83848_PHY_ADDRESS Address*/
|
/* DP83848_PHY_ADDRESS Address*/
|
||||||
#define DP83848_PHY_ADDRESS 0x01U
|
#define DP83848_PHY_ADDRESS 0x01U
|
||||||
/* PHY Reset delay these values are based on a 1 ms Systick interrupt*/
|
/* PHY Reset delay these values are based on a 1 ms Systick interrupt*/
|
||||||
#define PHY_RESET_DELAY ((uint32_t)0x000000FF)
|
#define PHY_RESET_DELAY 0x000000FFU
|
||||||
/* PHY Configuration delay */
|
/* PHY Configuration delay */
|
||||||
#define PHY_CONFIG_DELAY ((uint32_t)0x00000FFF)
|
#define PHY_CONFIG_DELAY 0x00000FFFU
|
||||||
|
|
||||||
#define PHY_READ_TO ((uint32_t)0x0000FFFF)
|
#define PHY_READ_TO 0x0000FFFFU
|
||||||
#define PHY_WRITE_TO ((uint32_t)0x0000FFFF)
|
#define PHY_WRITE_TO 0x0000FFFFU
|
||||||
|
|
||||||
/* Section 3: Common PHY Registers */
|
/* Section 3: Common PHY Registers */
|
||||||
|
|
||||||
#define PHY_BCR ((uint16_t)0x00) /*!< Transceiver Basic Control Register */
|
#define PHY_BCR ((uint16_t)0x00) /*!< Transceiver Basic Control Register */
|
||||||
#define PHY_BSR ((uint16_t)0x01) /*!< Transceiver Basic Status Register */
|
#define PHY_BSR ((uint16_t)0x01) /*!< Transceiver Basic Status Register */
|
||||||
|
|
||||||
#define PHY_RESET ((uint16_t)0x8000) /*!< PHY Reset */
|
#define PHY_RESET ((uint16_t)0x8000) /*!< PHY Reset */
|
||||||
#define PHY_LOOPBACK ((uint16_t)0x4000) /*!< Select loop-back mode */
|
#define PHY_LOOPBACK ((uint16_t)0x4000) /*!< Select loop-back mode */
|
||||||
#define PHY_FULLDUPLEX_100M ((uint16_t)0x2100) /*!< Set the full-duplex mode at 100 Mb/s */
|
#define PHY_FULLDUPLEX_100M ((uint16_t)0x2100) /*!< Set the full-duplex mode at 100 Mb/s */
|
||||||
|
@ -212,7 +212,7 @@
|
||||||
#define PHY_AUTONEGO_COMPLETE ((uint16_t)0x0020) /*!< Auto-Negotiation process completed */
|
#define PHY_AUTONEGO_COMPLETE ((uint16_t)0x0020) /*!< Auto-Negotiation process completed */
|
||||||
#define PHY_LINKED_STATUS ((uint16_t)0x0004) /*!< Valid link established */
|
#define PHY_LINKED_STATUS ((uint16_t)0x0004) /*!< Valid link established */
|
||||||
#define PHY_JABBER_DETECTION ((uint16_t)0x0002) /*!< Jabber condition detected */
|
#define PHY_JABBER_DETECTION ((uint16_t)0x0002) /*!< Jabber condition detected */
|
||||||
|
|
||||||
/* Section 4: Extended PHY Registers */
|
/* Section 4: Extended PHY Registers */
|
||||||
#define PHY_SR ((uint16_t)0x10U) /*!< PHY status register Offset */
|
#define PHY_SR ((uint16_t)0x10U) /*!< PHY status register Offset */
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Private includes ----------------------------------------------------------*/
|
/* Private includes ----------------------------------------------------------*/
|
||||||
/* USER CODE BEGIN Includes */
|
/* USER CODE BEGIN Includes */
|
||||||
|
|
|
@ -36,7 +36,7 @@ void MX_ADC1_Init(void)
|
||||||
ADC_AnalogWDGConfTypeDef AnalogWDGConfig = {0};
|
ADC_AnalogWDGConfTypeDef AnalogWDGConfig = {0};
|
||||||
ADC_ChannelConfTypeDef sConfig = {0};
|
ADC_ChannelConfTypeDef sConfig = {0};
|
||||||
|
|
||||||
/** Common config
|
/** Common config
|
||||||
*/
|
*/
|
||||||
hadc1.Instance = ADC1;
|
hadc1.Instance = ADC1;
|
||||||
hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
|
hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
|
||||||
|
@ -49,7 +49,7 @@ void MX_ADC1_Init(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Configure Analog WatchDog 1
|
/** Configure Analog WatchDog 1
|
||||||
*/
|
*/
|
||||||
AnalogWDGConfig.WatchdogMode = ADC_ANALOGWATCHDOG_SINGLE_REG;
|
AnalogWDGConfig.WatchdogMode = ADC_ANALOGWATCHDOG_SINGLE_REG;
|
||||||
AnalogWDGConfig.HighThreshold = 1828;
|
AnalogWDGConfig.HighThreshold = 1828;
|
||||||
|
@ -60,7 +60,7 @@ void MX_ADC1_Init(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Configure Regular Channel
|
/** Configure Regular Channel
|
||||||
*/
|
*/
|
||||||
sConfig.Channel = ADC_CHANNEL_TEMPSENSOR;
|
sConfig.Channel = ADC_CHANNEL_TEMPSENSOR;
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_1;
|
sConfig.Rank = ADC_REGULAR_RANK_1;
|
||||||
|
@ -69,7 +69,7 @@ void MX_ADC1_Init(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Configure Regular Channel
|
/** Configure Regular Channel
|
||||||
*/
|
*/
|
||||||
sConfig.Channel = ADC_CHANNEL_VREFINT;
|
sConfig.Channel = ADC_CHANNEL_VREFINT;
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_2;
|
sConfig.Rank = ADC_REGULAR_RANK_2;
|
||||||
|
@ -77,7 +77,7 @@ void MX_ADC1_Init(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Configure Regular Channel
|
/** Configure Regular Channel
|
||||||
*/
|
*/
|
||||||
sConfig.Channel = ADC_CHANNEL_3;
|
sConfig.Channel = ADC_CHANNEL_3;
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_3;
|
sConfig.Rank = ADC_REGULAR_RANK_3;
|
||||||
|
@ -85,7 +85,7 @@ void MX_ADC1_Init(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Configure Regular Channel
|
/** Configure Regular Channel
|
||||||
*/
|
*/
|
||||||
sConfig.Channel = ADC_CHANNEL_4;
|
sConfig.Channel = ADC_CHANNEL_4;
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_4;
|
sConfig.Rank = ADC_REGULAR_RANK_4;
|
||||||
|
@ -93,7 +93,7 @@ void MX_ADC1_Init(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Configure Regular Channel
|
/** Configure Regular Channel
|
||||||
*/
|
*/
|
||||||
sConfig.Channel = ADC_CHANNEL_5;
|
sConfig.Channel = ADC_CHANNEL_5;
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_5;
|
sConfig.Rank = ADC_REGULAR_RANK_5;
|
||||||
|
@ -101,7 +101,7 @@ void MX_ADC1_Init(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Configure Regular Channel
|
/** Configure Regular Channel
|
||||||
*/
|
*/
|
||||||
sConfig.Channel = ADC_CHANNEL_6;
|
sConfig.Channel = ADC_CHANNEL_6;
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_6;
|
sConfig.Rank = ADC_REGULAR_RANK_6;
|
||||||
|
@ -109,7 +109,7 @@ void MX_ADC1_Init(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Configure Regular Channel
|
/** Configure Regular Channel
|
||||||
*/
|
*/
|
||||||
sConfig.Channel = ADC_CHANNEL_7;
|
sConfig.Channel = ADC_CHANNEL_7;
|
||||||
sConfig.Rank = ADC_REGULAR_RANK_7;
|
sConfig.Rank = ADC_REGULAR_RANK_7;
|
||||||
|
@ -131,16 +131,16 @@ void HAL_ADC_MspInit(ADC_HandleTypeDef* adcHandle)
|
||||||
/* USER CODE END ADC1_MspInit 0 */
|
/* USER CODE END ADC1_MspInit 0 */
|
||||||
/* ADC1 clock enable */
|
/* ADC1 clock enable */
|
||||||
__HAL_RCC_ADC1_CLK_ENABLE();
|
__HAL_RCC_ADC1_CLK_ENABLE();
|
||||||
|
|
||||||
__HAL_RCC_GPIOA_CLK_ENABLE();
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
||||||
/**ADC1 GPIO Configuration
|
/**ADC1 GPIO Configuration
|
||||||
PA3 ------> ADC1_IN3
|
PA3 ------> ADC1_IN3
|
||||||
PA4 ------> ADC1_IN4
|
PA4 ------> ADC1_IN4
|
||||||
PA5 ------> ADC1_IN5
|
PA5 ------> ADC1_IN5
|
||||||
PA6 ------> ADC1_IN6
|
PA6 ------> ADC1_IN6
|
||||||
PA7 ------> ADC1_IN7
|
PA7 ------> ADC1_IN7
|
||||||
*/
|
*/
|
||||||
GPIO_InitStruct.Pin = MON_24V0_DIV16_Pin|MON_5V0_DIV8_Pin|MON_12V0_DIV8_Pin|MON_BKP_BAT_DIV8_Pin
|
GPIO_InitStruct.Pin = MON_24V0_DIV16_Pin|MON_5V0_DIV8_Pin|MON_12V0_DIV8_Pin|MON_BKP_BAT_DIV8_Pin
|
||||||
|MON_MAIN_PWR_DIV16_Pin;
|
|MON_MAIN_PWR_DIV16_Pin;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
||||||
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
||||||
|
@ -178,15 +178,15 @@ void HAL_ADC_MspDeInit(ADC_HandleTypeDef* adcHandle)
|
||||||
/* USER CODE END ADC1_MspDeInit 0 */
|
/* USER CODE END ADC1_MspDeInit 0 */
|
||||||
/* Peripheral clock disable */
|
/* Peripheral clock disable */
|
||||||
__HAL_RCC_ADC1_CLK_DISABLE();
|
__HAL_RCC_ADC1_CLK_DISABLE();
|
||||||
|
|
||||||
/**ADC1 GPIO Configuration
|
/**ADC1 GPIO Configuration
|
||||||
PA3 ------> ADC1_IN3
|
PA3 ------> ADC1_IN3
|
||||||
PA4 ------> ADC1_IN4
|
PA4 ------> ADC1_IN4
|
||||||
PA5 ------> ADC1_IN5
|
PA5 ------> ADC1_IN5
|
||||||
PA6 ------> ADC1_IN6
|
PA6 ------> ADC1_IN6
|
||||||
PA7 ------> ADC1_IN7
|
PA7 ------> ADC1_IN7
|
||||||
*/
|
*/
|
||||||
HAL_GPIO_DeInit(GPIOA, MON_24V0_DIV16_Pin|MON_5V0_DIV8_Pin|MON_12V0_DIV8_Pin|MON_BKP_BAT_DIV8_Pin
|
HAL_GPIO_DeInit(GPIOA, MON_24V0_DIV16_Pin|MON_5V0_DIV8_Pin|MON_12V0_DIV8_Pin|MON_BKP_BAT_DIV8_Pin
|
||||||
|MON_MAIN_PWR_DIV16_Pin);
|
|MON_MAIN_PWR_DIV16_Pin);
|
||||||
|
|
||||||
/* ADC1 DMA DeInit */
|
/* ADC1 DMA DeInit */
|
||||||
|
@ -198,7 +198,7 @@ void HAL_ADC_MspDeInit(ADC_HandleTypeDef* adcHandle)
|
||||||
|
|
||||||
/* USER CODE END ADC1_MspDeInit 1 */
|
/* USER CODE END ADC1_MspDeInit 1 */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
/* USER CODE BEGIN 1 */
|
||||||
|
|
||||||
|
|
|
@ -32,10 +32,10 @@
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
/* USER CODE END 1 */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enable DMA controller clock
|
* Enable DMA controller clock
|
||||||
*/
|
*/
|
||||||
void MX_DMA_Init(void)
|
void MX_DMA_Init(void)
|
||||||
{
|
{
|
||||||
|
|
||||||
/* DMA controller clock enable */
|
/* DMA controller clock enable */
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
#include "cmsis_os.h"
|
#include "cmsis_os.h"
|
||||||
|
|
||||||
/* Private includes ----------------------------------------------------------*/
|
/* Private includes ----------------------------------------------------------*/
|
||||||
/* USER CODE BEGIN Includes */
|
/* USER CODE BEGIN Includes */
|
||||||
#include "iwdg.h"
|
#include "iwdg.h"
|
||||||
#include "gpio.h"
|
#include "gpio.h"
|
||||||
#include "usart.h"
|
#include "usart.h"
|
||||||
|
@ -157,7 +157,7 @@ void MX_FREERTOS_Init(void) {
|
||||||
|
|
||||||
/* Create the queue(s) */
|
/* Create the queue(s) */
|
||||||
/* creation of uartQueue */
|
/* creation of uartQueue */
|
||||||
uartQueueHandle = osMessageQueueNew (1024, sizeof(uint8_t), &uartQueue_attributes);
|
uartQueueHandle = osMessageQueueNew (128, sizeof(uint8_t), &uartQueue_attributes);
|
||||||
|
|
||||||
/* USER CODE BEGIN RTOS_QUEUES */
|
/* USER CODE BEGIN RTOS_QUEUES */
|
||||||
/* add queues, ... */
|
/* add queues, ... */
|
||||||
|
@ -177,7 +177,7 @@ void MX_FREERTOS_Init(void) {
|
||||||
EventDetectHandle = osThreadNew(StartEventDetect, NULL, &EventDetect_attributes);
|
EventDetectHandle = osThreadNew(StartEventDetect, NULL, &EventDetect_attributes);
|
||||||
|
|
||||||
/* creation of CoulombRead */
|
/* creation of CoulombRead */
|
||||||
CoulombReadHandle = osThreadNew(StartCoulombRead, NULL, &CoulombRead_attributes);
|
// CoulombReadHandle = osThreadNew(StartCoulombRead, NULL, &CoulombRead_attributes);
|
||||||
|
|
||||||
/* creation of StateSwitchTask */
|
/* creation of StateSwitchTask */
|
||||||
StateSwitchTaskHandle = osThreadNew(StartStateSwitchTask, NULL, &StateSwitchTask_attributes);
|
StateSwitchTaskHandle = osThreadNew(StartStateSwitchTask, NULL, &StateSwitchTask_attributes);
|
||||||
|
|
|
@ -31,9 +31,9 @@ extern NaviKit_t NaviKit;
|
||||||
|
|
||||||
/* USER CODE END 1 */
|
/* USER CODE END 1 */
|
||||||
|
|
||||||
/** Configure pins as
|
/** Configure pins as
|
||||||
* Analog
|
* Analog
|
||||||
* Input
|
* Input
|
||||||
* Output
|
* Output
|
||||||
* EVENT_OUT
|
* EVENT_OUT
|
||||||
* EXTI
|
* EXTI
|
||||||
|
@ -63,13 +63,13 @@ void MX_GPIO_Init(void)
|
||||||
HAL_GPIO_WritePin(GPIOC, PMB_TEMP_SEN_EN_Pin|SYS_RUN_LED_CTL_Pin|SOC_U2_HUB_PWR_CTL_Pin, GPIO_PIN_RESET);
|
HAL_GPIO_WritePin(GPIOC, PMB_TEMP_SEN_EN_Pin|SYS_RUN_LED_CTL_Pin|SOC_U2_HUB_PWR_CTL_Pin, GPIO_PIN_RESET);
|
||||||
|
|
||||||
/*Configure GPIO pin Output Level */
|
/*Configure GPIO pin Output Level */
|
||||||
HAL_GPIO_WritePin(GPIOB, IIC2_SCL_Pin|IIC2_SDA_Pin|USB2_VBUS_CTL_1_Pin|USB2_VBUS_CTL_2_Pin
|
HAL_GPIO_WritePin(GPIOB, IIC2_SCL_Pin|IIC2_SDA_Pin|USB2_VBUS_CTL_1_Pin|USB2_VBUS_CTL_2_Pin
|
||||||
|USB2_VBUS_CTL_3_Pin|USB2_VBUS_CTL_4_Pin, GPIO_PIN_RESET);
|
|USB2_VBUS_CTL_3_Pin|USB2_VBUS_CTL_4_Pin, GPIO_PIN_RESET);
|
||||||
|
|
||||||
/*Configure GPIO pin Output Level */
|
/*Configure GPIO pin Output Level */
|
||||||
HAL_GPIO_WritePin(GPIOD, USB2_VBUS_CTL_5_Pin|USB2_VBUS_CTL_6_Pin|USB3_VBUS_CTL_5_Pin|USB3_VBUS_CTL_6_Pin
|
HAL_GPIO_WritePin(GPIOD, USB2_VBUS_CTL_5_Pin|USB2_VBUS_CTL_6_Pin|USB3_VBUS_CTL_5_Pin|USB3_VBUS_CTL_6_Pin
|
||||||
|USB3_VBUS_CTL_1_Pin|USB3_VBUS_CTL_2_Pin|USB3_VBUS_CTL_3_Pin|USB3_VBUS_CTL_4_Pin
|
|USB3_VBUS_CTL_1_Pin|USB3_VBUS_CTL_2_Pin|USB3_VBUS_CTL_3_Pin|USB3_VBUS_CTL_4_Pin
|
||||||
|SOC_U3_HUB_PWR_CTL_Pin|SOC_U3_HOST_PWR_CTL_Pin|SOC_U3_GEC_PWR_CTL_Pin|SOC_GE_SW_PWR_CTL_Pin
|
|SOC_U3_HUB_PWR_CTL_Pin|SOC_U3_HOST_PWR_CTL_Pin|SOC_U3_GEC_PWR_CTL_Pin|SOC_GE_SW_PWR_CTL_Pin
|
||||||
|SOM_POWER_EN_Pin, GPIO_PIN_RESET);
|
|SOM_POWER_EN_Pin, GPIO_PIN_RESET);
|
||||||
|
|
||||||
/*Configure GPIO pin Output Level */
|
/*Configure GPIO pin Output Level */
|
||||||
|
@ -81,9 +81,9 @@ void MX_GPIO_Init(void)
|
||||||
/*Configure GPIO pin Output Level */
|
/*Configure GPIO pin Output Level */
|
||||||
HAL_GPIO_WritePin(SOM_SYS_RESET_GPIO_Port, SOM_SYS_RESET_Pin, GPIO_PIN_SET);
|
HAL_GPIO_WritePin(SOM_SYS_RESET_GPIO_Port, SOM_SYS_RESET_Pin, GPIO_PIN_SET);
|
||||||
|
|
||||||
/*Configure GPIO pins : PEPin PEPin PEPin PEPin
|
/*Configure GPIO pins : PEPin PEPin PEPin PEPin
|
||||||
PEPin */
|
PEPin */
|
||||||
GPIO_InitStruct.Pin = SYS_POWER_LED_CTL_Pin|PMB_PS_ON_Pin|SYS_FAN_CTL_1_Pin|SYS_FAN_CTL_2_Pin
|
GPIO_InitStruct.Pin = SYS_POWER_LED_CTL_Pin|PMB_PS_ON_Pin|SYS_FAN_CTL_1_Pin|SYS_FAN_CTL_2_Pin
|
||||||
|SYS_FAN_CTL_3_Pin;
|
|SYS_FAN_CTL_3_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;
|
||||||
|
@ -102,9 +102,9 @@ void MX_GPIO_Init(void)
|
||||||
GPIO_InitStruct.Pull = GPIO_PULLUP;
|
GPIO_InitStruct.Pull = GPIO_PULLUP;
|
||||||
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
||||||
|
|
||||||
/*Configure GPIO pins : PCPin PCPin PCPin PCPin
|
/*Configure GPIO pins : PCPin PCPin PCPin PCPin
|
||||||
PCPin */
|
PCPin */
|
||||||
GPIO_InitStruct.Pin = PMB_CHRG_SHDN_Pin|PMB_TEMP_SEN_EN_Pin|SYS_RUN_LED_CTL_Pin|SYS_BUZZ_CTL_Pin
|
GPIO_InitStruct.Pin = PMB_CHRG_SHDN_Pin|PMB_TEMP_SEN_EN_Pin|SYS_RUN_LED_CTL_Pin|SYS_BUZZ_CTL_Pin
|
||||||
|SOC_U2_HUB_PWR_CTL_Pin;
|
|SOC_U2_HUB_PWR_CTL_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;
|
||||||
|
@ -129,22 +129,22 @@ void MX_GPIO_Init(void)
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
||||||
|
|
||||||
/*Configure GPIO pins : PBPin PBPin PBPin PBPin
|
/*Configure GPIO pins : PBPin PBPin PBPin PBPin
|
||||||
PBPin PBPin PBPin */
|
PBPin PBPin PBPin */
|
||||||
GPIO_InitStruct.Pin = IIC2_SCL_Pin|IIC2_SDA_Pin|USB2_VBUS_CTL_1_Pin|USB2_VBUS_CTL_2_Pin
|
GPIO_InitStruct.Pin = IIC2_SCL_Pin|IIC2_SDA_Pin|USB2_VBUS_CTL_1_Pin|USB2_VBUS_CTL_2_Pin
|
||||||
|USB2_VBUS_CTL_3_Pin|USB2_VBUS_CTL_4_Pin|SOM_SYS_RESET_Pin;
|
|USB2_VBUS_CTL_3_Pin|USB2_VBUS_CTL_4_Pin|SOM_SYS_RESET_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_LOW;
|
||||||
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
||||||
|
|
||||||
/*Configure GPIO pins : PDPin PDPin PDPin PDPin
|
/*Configure GPIO pins : PDPin PDPin PDPin PDPin
|
||||||
PDPin PDPin PDPin PDPin
|
PDPin PDPin PDPin PDPin
|
||||||
PDPin PDPin PDPin PDPin
|
PDPin PDPin PDPin PDPin
|
||||||
PDPin PDPin PDPin */
|
PDPin PDPin PDPin */
|
||||||
GPIO_InitStruct.Pin = USB2_VBUS_CTL_5_Pin|USB2_VBUS_CTL_6_Pin|USB3_VBUS_CTL_5_Pin|USB3_VBUS_CTL_6_Pin
|
GPIO_InitStruct.Pin = USB2_VBUS_CTL_5_Pin|USB2_VBUS_CTL_6_Pin|USB3_VBUS_CTL_5_Pin|USB3_VBUS_CTL_6_Pin
|
||||||
|USB3_VBUS_CTL_1_Pin|USB3_VBUS_CTL_2_Pin|USB3_VBUS_CTL_3_Pin|USB3_VBUS_CTL_4_Pin
|
|USB3_VBUS_CTL_1_Pin|USB3_VBUS_CTL_2_Pin|USB3_VBUS_CTL_3_Pin|USB3_VBUS_CTL_4_Pin
|
||||||
|SOC_U3_HUB_PWR_CTL_Pin|SOC_U3_HOST_PWR_CTL_Pin|SOC_U3_GEC_PWR_CTL_Pin|SOC_GE_SW_PWR_CTL_Pin
|
|SOC_U3_HUB_PWR_CTL_Pin|SOC_U3_HOST_PWR_CTL_Pin|SOC_U3_GEC_PWR_CTL_Pin|SOC_GE_SW_PWR_CTL_Pin
|
||||||
|SOM_POWER_EN_Pin|SOM_SLEEP_WAKE_Pin|SOM_FORCE_RECOVERY_Pin;
|
|SOM_POWER_EN_Pin|SOM_SLEEP_WAKE_Pin|SOM_FORCE_RECOVERY_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;
|
||||||
|
|
|
@ -76,11 +76,11 @@ void HAL_I2C_MspInit(I2C_HandleTypeDef* i2cHandle)
|
||||||
/* USER CODE BEGIN I2C1_MspInit 0 */
|
/* USER CODE BEGIN I2C1_MspInit 0 */
|
||||||
|
|
||||||
/* USER CODE END I2C1_MspInit 0 */
|
/* USER CODE END I2C1_MspInit 0 */
|
||||||
|
|
||||||
__HAL_RCC_GPIOB_CLK_ENABLE();
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
||||||
/**I2C1 GPIO Configuration
|
/**I2C1 GPIO Configuration
|
||||||
PB8 ------> I2C1_SCL
|
PB8 ------> I2C1_SCL
|
||||||
PB9 ------> I2C1_SDA
|
PB9 ------> I2C1_SDA
|
||||||
*/
|
*/
|
||||||
GPIO_InitStruct.Pin = IIC1_SCL_Pin|IIC1_SDA_Pin;
|
GPIO_InitStruct.Pin = IIC1_SCL_Pin|IIC1_SDA_Pin;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
|
||||||
|
@ -107,12 +107,14 @@ void HAL_I2C_MspDeInit(I2C_HandleTypeDef* i2cHandle)
|
||||||
/* USER CODE END I2C1_MspDeInit 0 */
|
/* USER CODE END I2C1_MspDeInit 0 */
|
||||||
/* Peripheral clock disable */
|
/* Peripheral clock disable */
|
||||||
__HAL_RCC_I2C1_CLK_DISABLE();
|
__HAL_RCC_I2C1_CLK_DISABLE();
|
||||||
|
|
||||||
/**I2C1 GPIO Configuration
|
/**I2C1 GPIO Configuration
|
||||||
PB8 ------> I2C1_SCL
|
PB8 ------> I2C1_SCL
|
||||||
PB9 ------> I2C1_SDA
|
PB9 ------> I2C1_SDA
|
||||||
*/
|
*/
|
||||||
HAL_GPIO_DeInit(GPIOB, IIC1_SCL_Pin|IIC1_SDA_Pin);
|
HAL_GPIO_DeInit(IIC1_SCL_GPIO_Port, IIC1_SCL_Pin);
|
||||||
|
|
||||||
|
HAL_GPIO_DeInit(IIC1_SDA_GPIO_Port, IIC1_SDA_Pin);
|
||||||
|
|
||||||
/* I2C1 interrupt Deinit */
|
/* I2C1 interrupt Deinit */
|
||||||
HAL_NVIC_DisableIRQ(I2C1_EV_IRQn);
|
HAL_NVIC_DisableIRQ(I2C1_EV_IRQn);
|
||||||
|
@ -121,7 +123,7 @@ void HAL_I2C_MspDeInit(I2C_HandleTypeDef* i2cHandle)
|
||||||
|
|
||||||
/* USER CODE END I2C1_MspDeInit 1 */
|
/* USER CODE END I2C1_MspDeInit 1 */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
/* USER CODE BEGIN 1 */
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
*/
|
*/
|
||||||
/* USER CODE END Header */
|
/* USER CODE END Header */
|
||||||
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* Includes ------------------------------------------------------------------*/
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "cmsis_os.h"
|
#include "cmsis_os.h"
|
||||||
|
@ -99,7 +98,7 @@ int main(void)
|
||||||
MX_GPIO_Init();
|
MX_GPIO_Init();
|
||||||
MX_DMA_Init();
|
MX_DMA_Init();
|
||||||
MX_I2C1_Init();
|
MX_I2C1_Init();
|
||||||
// MX_IWDG_Init();
|
MX_IWDG_Init();
|
||||||
MX_UART4_Init();
|
MX_UART4_Init();
|
||||||
MX_ADC1_Init();
|
MX_ADC1_Init();
|
||||||
MX_USART1_UART_Init();
|
MX_USART1_UART_Init();
|
||||||
|
@ -113,10 +112,10 @@ int main(void)
|
||||||
|
|
||||||
/* Init scheduler */
|
/* Init scheduler */
|
||||||
osKernelInitialize(); /* Call init function for freertos objects (in freertos.c) */
|
osKernelInitialize(); /* Call init function for freertos objects (in freertos.c) */
|
||||||
MX_FREERTOS_Init();
|
MX_FREERTOS_Init();
|
||||||
/* Start scheduler */
|
/* Start scheduler */
|
||||||
osKernelStart();
|
osKernelStart();
|
||||||
|
|
||||||
/* We should never get here as control is now taken by the scheduler */
|
/* We should never get here as control is now taken by the scheduler */
|
||||||
/* Infinite loop */
|
/* Infinite loop */
|
||||||
/* USER CODE BEGIN WHILE */
|
/* USER CODE BEGIN WHILE */
|
||||||
|
@ -139,7 +138,8 @@ void SystemClock_Config(void)
|
||||||
RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
|
RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
|
||||||
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
||||||
|
|
||||||
/** Initializes the CPU, AHB and APB busses clocks
|
/** Initializes the RCC Oscillators according to the specified parameters
|
||||||
|
* in the RCC_OscInitTypeDef structure.
|
||||||
*/
|
*/
|
||||||
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSI|RCC_OSCILLATORTYPE_HSE;
|
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSI|RCC_OSCILLATORTYPE_HSE;
|
||||||
RCC_OscInitStruct.HSEState = RCC_HSE_ON;
|
RCC_OscInitStruct.HSEState = RCC_HSE_ON;
|
||||||
|
@ -155,7 +155,7 @@ void SystemClock_Config(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Initializes the CPU, AHB and APB busses clocks
|
/** Initializes the CPU, AHB and APB buses clocks
|
||||||
*/
|
*/
|
||||||
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|
||||||
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
|
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
|
||||||
|
@ -177,10 +177,10 @@ void SystemClock_Config(void)
|
||||||
{
|
{
|
||||||
Error_Handler();
|
Error_Handler();
|
||||||
}
|
}
|
||||||
/** Enables the Clock Security System
|
/** Enables the Clock Security System
|
||||||
*/
|
*/
|
||||||
HAL_RCC_EnableCSS();
|
HAL_RCC_EnableCSS();
|
||||||
/** Configure the Systick interrupt time
|
/** Configure the Systick interrupt time
|
||||||
*/
|
*/
|
||||||
__HAL_RCC_PLLI2S_ENABLE();
|
__HAL_RCC_PLLI2S_ENABLE();
|
||||||
}
|
}
|
||||||
|
@ -200,12 +200,12 @@ static void MX_NVIC_Init(void)
|
||||||
/* RCC_IRQn interrupt configuration */
|
/* RCC_IRQn interrupt configuration */
|
||||||
HAL_NVIC_SetPriority(RCC_IRQn, 5, 0);
|
HAL_NVIC_SetPriority(RCC_IRQn, 5, 0);
|
||||||
HAL_NVIC_EnableIRQ(RCC_IRQn);
|
HAL_NVIC_EnableIRQ(RCC_IRQn);
|
||||||
/* UART4_IRQn interrupt configuration */
|
|
||||||
HAL_NVIC_SetPriority(UART4_IRQn, 5, 0);
|
|
||||||
HAL_NVIC_EnableIRQ(UART4_IRQn);
|
|
||||||
/* OTG_FS_IRQn interrupt configuration */
|
/* OTG_FS_IRQn interrupt configuration */
|
||||||
HAL_NVIC_SetPriority(OTG_FS_IRQn, 5, 0);
|
HAL_NVIC_SetPriority(OTG_FS_IRQn, 5, 0);
|
||||||
HAL_NVIC_EnableIRQ(OTG_FS_IRQn);
|
HAL_NVIC_EnableIRQ(OTG_FS_IRQn);
|
||||||
|
/* UART4_IRQn interrupt configuration */
|
||||||
|
HAL_NVIC_SetPriority(UART4_IRQn, 5, 0);
|
||||||
|
HAL_NVIC_EnableIRQ(UART4_IRQn);
|
||||||
/* I2C1_EV_IRQn interrupt configuration */
|
/* I2C1_EV_IRQn interrupt configuration */
|
||||||
HAL_NVIC_SetPriority(I2C1_EV_IRQn, 5, 0);
|
HAL_NVIC_SetPriority(I2C1_EV_IRQn, 5, 0);
|
||||||
HAL_NVIC_EnableIRQ(I2C1_EV_IRQn);
|
HAL_NVIC_EnableIRQ(I2C1_EV_IRQn);
|
||||||
|
@ -218,6 +218,9 @@ static void MX_NVIC_Init(void)
|
||||||
/* DMA1_Channel1_IRQn interrupt configuration */
|
/* DMA1_Channel1_IRQn interrupt configuration */
|
||||||
HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 5, 0);
|
HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 5, 0);
|
||||||
HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
|
HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
|
||||||
|
/* USART1_IRQn interrupt configuration */
|
||||||
|
HAL_NVIC_SetPriority(USART1_IRQn, 5, 0);
|
||||||
|
HAL_NVIC_EnableIRQ(USART1_IRQn);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* USER CODE BEGIN 4 */
|
/* USER CODE BEGIN 4 */
|
||||||
|
@ -253,7 +256,7 @@ void ISP_Judge()
|
||||||
|
|
||||||
/* USER CODE END 4 */
|
/* USER CODE END 4 */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Period elapsed callback in non blocking mode
|
* @brief Period elapsed callback in non blocking mode
|
||||||
* @note This function is called when TIM1 interrupt took place, inside
|
* @note This function is called when TIM1 interrupt took place, inside
|
||||||
* HAL_TIM_IRQHandler(). It makes a direct call to HAL_IncTick() to increment
|
* HAL_TIM_IRQHandler(). It makes a direct call to HAL_IncTick() to increment
|
||||||
|
@ -295,7 +298,7 @@ void Error_Handler(void)
|
||||||
* @retval None
|
* @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 CODE BEGIN 6 */
|
||||||
/* User can add his own implementation to report the file name and line number,
|
/* User can add his own implementation to report the file name and line number,
|
||||||
tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
|
tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
|
||||||
|
|
|
@ -30,7 +30,7 @@ RTC_HandleTypeDef hrtc;
|
||||||
void MX_RTC_Init(void)
|
void MX_RTC_Init(void)
|
||||||
{
|
{
|
||||||
|
|
||||||
/** Initialize RTC Only
|
/** Initialize RTC Only
|
||||||
*/
|
*/
|
||||||
hrtc.Instance = RTC;
|
hrtc.Instance = RTC;
|
||||||
hrtc.Init.AsynchPrediv = RTC_AUTO_1_SECOND;
|
hrtc.Init.AsynchPrediv = RTC_AUTO_1_SECOND;
|
||||||
|
@ -82,7 +82,7 @@ void HAL_RTC_MspDeInit(RTC_HandleTypeDef* rtcHandle)
|
||||||
|
|
||||||
/* USER CODE END RTC_MspDeInit 1 */
|
/* USER CODE END RTC_MspDeInit 1 */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
/* USER CODE BEGIN 1 */
|
||||||
|
|
||||||
|
|
|
@ -84,7 +84,7 @@ void HAL_MspInit(void)
|
||||||
|
|
||||||
/* Peripheral interrupt init */
|
/* Peripheral interrupt init */
|
||||||
|
|
||||||
/** NOJTAG: JTAG-DP Disabled and SW-DP Enabled
|
/** NOJTAG: JTAG-DP Disabled and SW-DP Enabled
|
||||||
*/
|
*/
|
||||||
__HAL_AFIO_REMAP_SWJ_NOJTAG();
|
__HAL_AFIO_REMAP_SWJ_NOJTAG();
|
||||||
|
|
||||||
|
|
|
@ -21,21 +21,21 @@
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* Includes ------------------------------------------------------------------*/
|
||||||
#include "stm32f1xx_hal.h"
|
#include "stm32f1xx_hal.h"
|
||||||
#include "stm32f1xx_hal_tim.h"
|
#include "stm32f1xx_hal_tim.h"
|
||||||
|
|
||||||
/* Private typedef -----------------------------------------------------------*/
|
/* Private typedef -----------------------------------------------------------*/
|
||||||
/* Private define ------------------------------------------------------------*/
|
/* Private define ------------------------------------------------------------*/
|
||||||
/* Private macro -------------------------------------------------------------*/
|
/* Private macro -------------------------------------------------------------*/
|
||||||
/* Private variables ---------------------------------------------------------*/
|
/* Private variables ---------------------------------------------------------*/
|
||||||
TIM_HandleTypeDef htim1;
|
TIM_HandleTypeDef htim1;
|
||||||
/* Private function prototypes -----------------------------------------------*/
|
/* Private function prototypes -----------------------------------------------*/
|
||||||
/* Private functions ---------------------------------------------------------*/
|
/* Private functions ---------------------------------------------------------*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function configures the TIM1 as a time base source.
|
* @brief This function configures the TIM1 as a time base source.
|
||||||
* The time source is configured to have 1ms time base with a dedicated
|
* The time source is configured to have 1ms time base with a dedicated
|
||||||
* Tick interrupt priority.
|
* Tick interrupt priority.
|
||||||
* @note This function is called automatically at the beginning of program after
|
* @note This function is called automatically at the beginning of program after
|
||||||
* reset by HAL_Init() or at any time when clock is configured, by HAL_RCC_ClockConfig().
|
* reset by HAL_Init() or at any time when clock is configured, by HAL_RCC_ClockConfig().
|
||||||
* @param TickPriority: Tick interrupt priority.
|
* @param TickPriority: Tick interrupt priority.
|
||||||
* @retval HAL status
|
* @retval HAL status
|
||||||
*/
|
*/
|
||||||
|
@ -45,28 +45,26 @@ HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
|
||||||
uint32_t uwTimclock = 0;
|
uint32_t uwTimclock = 0;
|
||||||
uint32_t uwPrescalerValue = 0;
|
uint32_t uwPrescalerValue = 0;
|
||||||
uint32_t pFLatency;
|
uint32_t pFLatency;
|
||||||
|
|
||||||
/*Configure the TIM1 IRQ priority */
|
/*Configure the TIM1 IRQ priority */
|
||||||
HAL_NVIC_SetPriority(TIM1_UP_IRQn, TickPriority ,0);
|
HAL_NVIC_SetPriority(TIM1_UP_IRQn, TickPriority ,0);
|
||||||
|
|
||||||
/* Enable the TIM1 global Interrupt */
|
/* Enable the TIM1 global Interrupt */
|
||||||
HAL_NVIC_EnableIRQ(TIM1_UP_IRQn);
|
HAL_NVIC_EnableIRQ(TIM1_UP_IRQn);
|
||||||
|
|
||||||
/* Enable TIM1 clock */
|
/* Enable TIM1 clock */
|
||||||
__HAL_RCC_TIM1_CLK_ENABLE();
|
__HAL_RCC_TIM1_CLK_ENABLE();
|
||||||
|
|
||||||
/* Get clock configuration */
|
/* Get clock configuration */
|
||||||
HAL_RCC_GetClockConfig(&clkconfig, &pFLatency);
|
HAL_RCC_GetClockConfig(&clkconfig, &pFLatency);
|
||||||
|
|
||||||
/* Compute TIM1 clock */
|
/* Compute TIM1 clock */
|
||||||
uwTimclock = HAL_RCC_GetPCLK2Freq();
|
uwTimclock = HAL_RCC_GetPCLK2Freq();
|
||||||
|
|
||||||
/* Compute the prescaler value to have TIM1 counter clock equal to 1MHz */
|
/* Compute the prescaler value to have TIM1 counter clock equal to 1MHz */
|
||||||
uwPrescalerValue = (uint32_t) ((uwTimclock / 1000000) - 1);
|
uwPrescalerValue = (uint32_t) ((uwTimclock / 1000000) - 1);
|
||||||
|
|
||||||
/* Initialize TIM1 */
|
/* Initialize TIM1 */
|
||||||
htim1.Instance = TIM1;
|
htim1.Instance = TIM1;
|
||||||
|
|
||||||
/* Initialize TIMx peripheral as follow:
|
/* Initialize TIMx peripheral as follow:
|
||||||
+ Period = [(TIM1CLK/1000) - 1]. to have a (1/1000) s time base.
|
+ Period = [(TIM1CLK/1000) - 1]. to have a (1/1000) s time base.
|
||||||
+ Prescaler = (uwTimclock/1000000 - 1) to have a 1MHz counter clock.
|
+ Prescaler = (uwTimclock/1000000 - 1) to have a 1MHz counter clock.
|
||||||
|
@ -82,7 +80,7 @@ HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
|
||||||
/* Start the TIM time Base generation in interrupt mode */
|
/* Start the TIM time Base generation in interrupt mode */
|
||||||
return HAL_TIM_Base_Start_IT(&htim1);
|
return HAL_TIM_Base_Start_IT(&htim1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
|
@ -96,7 +94,7 @@ HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
|
||||||
void HAL_SuspendTick(void)
|
void HAL_SuspendTick(void)
|
||||||
{
|
{
|
||||||
/* Disable TIM1 update Interrupt */
|
/* Disable TIM1 update Interrupt */
|
||||||
__HAL_TIM_DISABLE_IT(&htim1, TIM_IT_UPDATE);
|
__HAL_TIM_DISABLE_IT(&htim1, TIM_IT_UPDATE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -21,8 +21,6 @@
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* Includes ------------------------------------------------------------------*/
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "stm32f1xx_it.h"
|
#include "stm32f1xx_it.h"
|
||||||
#include "FreeRTOS.h"
|
|
||||||
#include "task.h"
|
|
||||||
/* Private includes ----------------------------------------------------------*/
|
/* Private includes ----------------------------------------------------------*/
|
||||||
/* USER CODE BEGIN Includes */
|
/* USER CODE BEGIN Includes */
|
||||||
/* USER CODE END Includes */
|
/* USER CODE END Includes */
|
||||||
|
@ -72,7 +70,7 @@ extern TIM_HandleTypeDef htim1;
|
||||||
/* USER CODE END EV */
|
/* USER CODE END EV */
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
/* Cortex-M3 Processor Interruption and Exception Handlers */
|
/* Cortex-M3 Processor Interruption and Exception Handlers */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
/**
|
/**
|
||||||
* @brief This function handles Non maskable interrupt.
|
* @brief This function handles Non maskable interrupt.
|
||||||
|
|
|
@ -75,11 +75,11 @@ void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
|
||||||
/* USER CODE END UART4_MspInit 0 */
|
/* USER CODE END UART4_MspInit 0 */
|
||||||
/* UART4 clock enable */
|
/* UART4 clock enable */
|
||||||
__HAL_RCC_UART4_CLK_ENABLE();
|
__HAL_RCC_UART4_CLK_ENABLE();
|
||||||
|
|
||||||
__HAL_RCC_GPIOC_CLK_ENABLE();
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
||||||
/**UART4 GPIO Configuration
|
/**UART4 GPIO Configuration
|
||||||
PC10 ------> UART4_TX
|
PC10 ------> UART4_TX
|
||||||
PC11 ------> UART4_RX
|
PC11 ------> UART4_RX
|
||||||
*/
|
*/
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_10;
|
GPIO_InitStruct.Pin = GPIO_PIN_10;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
|
@ -102,11 +102,11 @@ void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
|
||||||
/* USER CODE END USART1_MspInit 0 */
|
/* USER CODE END USART1_MspInit 0 */
|
||||||
/* USART1 clock enable */
|
/* USART1 clock enable */
|
||||||
__HAL_RCC_USART1_CLK_ENABLE();
|
__HAL_RCC_USART1_CLK_ENABLE();
|
||||||
|
|
||||||
__HAL_RCC_GPIOA_CLK_ENABLE();
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
||||||
/**USART1 GPIO Configuration
|
/**USART1 GPIO Configuration
|
||||||
PA9 ------> USART1_TX
|
PA9 ------> USART1_TX
|
||||||
PA10 ------> USART1_RX
|
PA10 ------> USART1_RX
|
||||||
*/
|
*/
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_9;
|
GPIO_InitStruct.Pin = GPIO_PIN_9;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
|
@ -118,9 +118,6 @@ void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
||||||
|
|
||||||
/* USART1 interrupt Init */
|
|
||||||
HAL_NVIC_SetPriority(USART1_IRQn, 5, 0);
|
|
||||||
HAL_NVIC_EnableIRQ(USART1_IRQn);
|
|
||||||
/* USER CODE BEGIN USART1_MspInit 1 */
|
/* USER CODE BEGIN USART1_MspInit 1 */
|
||||||
|
|
||||||
/* USER CODE END USART1_MspInit 1 */
|
/* USER CODE END USART1_MspInit 1 */
|
||||||
|
@ -137,10 +134,10 @@ void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
|
||||||
/* USER CODE END UART4_MspDeInit 0 */
|
/* USER CODE END UART4_MspDeInit 0 */
|
||||||
/* Peripheral clock disable */
|
/* Peripheral clock disable */
|
||||||
__HAL_RCC_UART4_CLK_DISABLE();
|
__HAL_RCC_UART4_CLK_DISABLE();
|
||||||
|
|
||||||
/**UART4 GPIO Configuration
|
/**UART4 GPIO Configuration
|
||||||
PC10 ------> UART4_TX
|
PC10 ------> UART4_TX
|
||||||
PC11 ------> UART4_RX
|
PC11 ------> UART4_RX
|
||||||
*/
|
*/
|
||||||
HAL_GPIO_DeInit(GPIOC, GPIO_PIN_10|GPIO_PIN_11);
|
HAL_GPIO_DeInit(GPIOC, GPIO_PIN_10|GPIO_PIN_11);
|
||||||
|
|
||||||
|
@ -157,10 +154,10 @@ void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
|
||||||
/* USER CODE END USART1_MspDeInit 0 */
|
/* USER CODE END USART1_MspDeInit 0 */
|
||||||
/* Peripheral clock disable */
|
/* Peripheral clock disable */
|
||||||
__HAL_RCC_USART1_CLK_DISABLE();
|
__HAL_RCC_USART1_CLK_DISABLE();
|
||||||
|
|
||||||
/**USART1 GPIO Configuration
|
/**USART1 GPIO Configuration
|
||||||
PA9 ------> USART1_TX
|
PA9 ------> USART1_TX
|
||||||
PA10 ------> USART1_RX
|
PA10 ------> USART1_RX
|
||||||
*/
|
*/
|
||||||
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
|
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
|
||||||
|
|
||||||
|
@ -170,7 +167,7 @@ void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
|
||||||
|
|
||||||
/* USER CODE END USART1_MspDeInit 1 */
|
/* USER CODE END USART1_MspDeInit 1 */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* USER CODE BEGIN 1 */
|
/* USER CODE BEGIN 1 */
|
||||||
|
|
||||||
|
|
|
@ -1330,6 +1330,11 @@ typedef struct
|
||||||
/* Reset and Clock Control */
|
/* Reset and Clock Control */
|
||||||
/* */
|
/* */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
/*
|
||||||
|
* @brief Specific device feature definitions (not present on all devices in the STM32F1 serie)
|
||||||
|
*/
|
||||||
|
#define RCC_PLL2_SUPPORT /*!< Support PLL2 */
|
||||||
|
#define RCC_PLLI2S_SUPPORT
|
||||||
|
|
||||||
/******************** Bit definition for RCC_CR register ********************/
|
/******************** Bit definition for RCC_CR register ********************/
|
||||||
#define RCC_CR_HSION_Pos (0U)
|
#define RCC_CR_HSION_Pos (0U)
|
||||||
|
@ -1363,11 +1368,6 @@ typedef struct
|
||||||
#define RCC_CR_PLLRDY_Msk (0x1UL << RCC_CR_PLLRDY_Pos) /*!< 0x02000000 */
|
#define RCC_CR_PLLRDY_Msk (0x1UL << RCC_CR_PLLRDY_Pos) /*!< 0x02000000 */
|
||||||
#define RCC_CR_PLLRDY RCC_CR_PLLRDY_Msk /*!< PLL clock ready flag */
|
#define RCC_CR_PLLRDY RCC_CR_PLLRDY_Msk /*!< PLL clock ready flag */
|
||||||
|
|
||||||
/*
|
|
||||||
* @brief Specific device feature definitions (not present on all devices in the STM32F1 serie)
|
|
||||||
*/
|
|
||||||
#define RCC_PLL2_SUPPORT /*!< Support PLL2 */
|
|
||||||
|
|
||||||
#define RCC_CR_PLL2ON_Pos (26U)
|
#define RCC_CR_PLL2ON_Pos (26U)
|
||||||
#define RCC_CR_PLL2ON_Msk (0x1UL << RCC_CR_PLL2ON_Pos) /*!< 0x04000000 */
|
#define RCC_CR_PLL2ON_Msk (0x1UL << RCC_CR_PLL2ON_Pos) /*!< 0x04000000 */
|
||||||
#define RCC_CR_PLL2ON RCC_CR_PLL2ON_Msk /*!< PLL2 enable */
|
#define RCC_CR_PLL2ON RCC_CR_PLL2ON_Msk /*!< PLL2 enable */
|
||||||
|
@ -1375,11 +1375,6 @@ typedef struct
|
||||||
#define RCC_CR_PLL2RDY_Msk (0x1UL << RCC_CR_PLL2RDY_Pos) /*!< 0x08000000 */
|
#define RCC_CR_PLL2RDY_Msk (0x1UL << RCC_CR_PLL2RDY_Pos) /*!< 0x08000000 */
|
||||||
#define RCC_CR_PLL2RDY RCC_CR_PLL2RDY_Msk /*!< PLL2 clock ready flag */
|
#define RCC_CR_PLL2RDY RCC_CR_PLL2RDY_Msk /*!< PLL2 clock ready flag */
|
||||||
|
|
||||||
/*
|
|
||||||
* @brief Specific device feature definitions (not present on all devices in the STM32F1 serie)
|
|
||||||
*/
|
|
||||||
#define RCC_PLLI2S_SUPPORT /*!< Support PLL3 (PLLI2S)*/
|
|
||||||
|
|
||||||
#define RCC_CR_PLL3ON_Pos (28U)
|
#define RCC_CR_PLL3ON_Pos (28U)
|
||||||
#define RCC_CR_PLL3ON_Msk (0x1UL << RCC_CR_PLL3ON_Pos) /*!< 0x10000000 */
|
#define RCC_CR_PLL3ON_Msk (0x1UL << RCC_CR_PLL3ON_Pos) /*!< 0x10000000 */
|
||||||
#define RCC_CR_PLL3ON RCC_CR_PLL3ON_Msk /*!< PLL3 enable */
|
#define RCC_CR_PLL3ON RCC_CR_PLL3ON_Msk /*!< PLL3 enable */
|
||||||
|
@ -12006,7 +12001,6 @@ typedef struct
|
||||||
#define SPI_I2SCFGR_I2SMOD_Pos (11U)
|
#define SPI_I2SCFGR_I2SMOD_Pos (11U)
|
||||||
#define SPI_I2SCFGR_I2SMOD_Msk (0x1UL << SPI_I2SCFGR_I2SMOD_Pos) /*!< 0x00000800 */
|
#define SPI_I2SCFGR_I2SMOD_Msk (0x1UL << SPI_I2SCFGR_I2SMOD_Pos) /*!< 0x00000800 */
|
||||||
#define SPI_I2SCFGR_I2SMOD SPI_I2SCFGR_I2SMOD_Msk /*!< I2S mode selection */
|
#define SPI_I2SCFGR_I2SMOD SPI_I2SCFGR_I2SMOD_Msk /*!< I2S mode selection */
|
||||||
|
|
||||||
/****************** Bit definition for SPI_I2SPR register *******************/
|
/****************** Bit definition for SPI_I2SPR register *******************/
|
||||||
#define SPI_I2SPR_I2SDIV_Pos (0U)
|
#define SPI_I2SPR_I2SDIV_Pos (0U)
|
||||||
#define SPI_I2SPR_I2SDIV_Msk (0xFFUL << SPI_I2SPR_I2SDIV_Pos) /*!< 0x000000FF */
|
#define SPI_I2SPR_I2SDIV_Msk (0xFFUL << SPI_I2SPR_I2SDIV_Pos) /*!< 0x000000FF */
|
||||||
|
@ -15003,8 +14997,6 @@ typedef struct
|
||||||
((INSTANCE) == TIM4) || \
|
((INSTANCE) == TIM4) || \
|
||||||
((INSTANCE) == TIM5))
|
((INSTANCE) == TIM5))
|
||||||
|
|
||||||
#define IS_TIM_SYNCHRO_INSTANCE(INSTANCE) IS_TIM_MASTER_INSTANCE(INSTANCE)
|
|
||||||
|
|
||||||
#define IS_TIM_DMABURST_INSTANCE(INSTANCE)\
|
#define IS_TIM_DMABURST_INSTANCE(INSTANCE)\
|
||||||
(((INSTANCE) == TIM1) || \
|
(((INSTANCE) == TIM1) || \
|
||||||
((INSTANCE) == TIM2) || \
|
((INSTANCE) == TIM2) || \
|
||||||
|
@ -15195,42 +15187,42 @@ typedef struct
|
||||||
|
|
||||||
/* Aliases for __IRQn */
|
/* Aliases for __IRQn */
|
||||||
#define ADC1_IRQn ADC1_2_IRQn
|
#define ADC1_IRQn ADC1_2_IRQn
|
||||||
#define USB_LP_CAN1_RX0_IRQn CAN1_RX0_IRQn
|
|
||||||
#define USB_LP_IRQn CAN1_RX0_IRQn
|
#define USB_LP_IRQn CAN1_RX0_IRQn
|
||||||
#define USB_HP_CAN1_TX_IRQn CAN1_TX_IRQn
|
#define USB_LP_CAN1_RX0_IRQn CAN1_RX0_IRQn
|
||||||
#define USB_HP_IRQn CAN1_TX_IRQn
|
#define USB_HP_IRQn CAN1_TX_IRQn
|
||||||
|
#define USB_HP_CAN1_TX_IRQn CAN1_TX_IRQn
|
||||||
#define DMA2_Channel4_5_IRQn DMA2_Channel4_IRQn
|
#define DMA2_Channel4_5_IRQn DMA2_Channel4_IRQn
|
||||||
#define USBWakeUp_IRQn OTG_FS_WKUP_IRQn
|
#define USBWakeUp_IRQn OTG_FS_WKUP_IRQn
|
||||||
#define CEC_IRQn OTG_FS_WKUP_IRQn
|
#define CEC_IRQn OTG_FS_WKUP_IRQn
|
||||||
|
#define TIM1_BRK_TIM9_IRQn TIM1_BRK_IRQn
|
||||||
#define TIM1_BRK_TIM15_IRQn TIM1_BRK_IRQn
|
#define TIM1_BRK_TIM15_IRQn TIM1_BRK_IRQn
|
||||||
#define TIM9_IRQn TIM1_BRK_IRQn
|
#define TIM9_IRQn TIM1_BRK_IRQn
|
||||||
#define TIM1_BRK_TIM9_IRQn TIM1_BRK_IRQn
|
#define TIM11_IRQn TIM1_TRG_COM_IRQn
|
||||||
#define TIM1_TRG_COM_TIM17_IRQn TIM1_TRG_COM_IRQn
|
#define TIM1_TRG_COM_TIM17_IRQn TIM1_TRG_COM_IRQn
|
||||||
#define TIM1_TRG_COM_TIM11_IRQn TIM1_TRG_COM_IRQn
|
#define TIM1_TRG_COM_TIM11_IRQn TIM1_TRG_COM_IRQn
|
||||||
#define TIM11_IRQn TIM1_TRG_COM_IRQn
|
|
||||||
#define TIM1_UP_TIM10_IRQn TIM1_UP_IRQn
|
|
||||||
#define TIM1_UP_TIM16_IRQn TIM1_UP_IRQn
|
#define TIM1_UP_TIM16_IRQn TIM1_UP_IRQn
|
||||||
|
#define TIM1_UP_TIM10_IRQn TIM1_UP_IRQn
|
||||||
#define TIM10_IRQn TIM1_UP_IRQn
|
#define TIM10_IRQn TIM1_UP_IRQn
|
||||||
#define TIM6_DAC_IRQn TIM6_IRQn
|
#define TIM6_DAC_IRQn TIM6_IRQn
|
||||||
|
|
||||||
|
|
||||||
/* Aliases for __IRQHandler */
|
/* Aliases for __IRQHandler */
|
||||||
#define ADC1_IRQHandler ADC1_2_IRQHandler
|
#define ADC1_IRQHandler ADC1_2_IRQHandler
|
||||||
#define USB_LP_CAN1_RX0_IRQHandler CAN1_RX0_IRQHandler
|
|
||||||
#define USB_LP_IRQHandler CAN1_RX0_IRQHandler
|
#define USB_LP_IRQHandler CAN1_RX0_IRQHandler
|
||||||
#define USB_HP_CAN1_TX_IRQHandler CAN1_TX_IRQHandler
|
#define USB_LP_CAN1_RX0_IRQHandler CAN1_RX0_IRQHandler
|
||||||
#define USB_HP_IRQHandler CAN1_TX_IRQHandler
|
#define USB_HP_IRQHandler CAN1_TX_IRQHandler
|
||||||
|
#define USB_HP_CAN1_TX_IRQHandler CAN1_TX_IRQHandler
|
||||||
#define DMA2_Channel4_5_IRQHandler DMA2_Channel4_IRQHandler
|
#define DMA2_Channel4_5_IRQHandler DMA2_Channel4_IRQHandler
|
||||||
#define USBWakeUp_IRQHandler OTG_FS_WKUP_IRQHandler
|
#define USBWakeUp_IRQHandler OTG_FS_WKUP_IRQHandler
|
||||||
#define CEC_IRQHandler OTG_FS_WKUP_IRQHandler
|
#define CEC_IRQHandler OTG_FS_WKUP_IRQHandler
|
||||||
|
#define TIM1_BRK_TIM9_IRQHandler TIM1_BRK_IRQHandler
|
||||||
#define TIM1_BRK_TIM15_IRQHandler TIM1_BRK_IRQHandler
|
#define TIM1_BRK_TIM15_IRQHandler TIM1_BRK_IRQHandler
|
||||||
#define TIM9_IRQHandler TIM1_BRK_IRQHandler
|
#define TIM9_IRQHandler TIM1_BRK_IRQHandler
|
||||||
#define TIM1_BRK_TIM9_IRQHandler TIM1_BRK_IRQHandler
|
#define TIM11_IRQHandler TIM1_TRG_COM_IRQHandler
|
||||||
#define TIM1_TRG_COM_TIM17_IRQHandler TIM1_TRG_COM_IRQHandler
|
#define TIM1_TRG_COM_TIM17_IRQHandler TIM1_TRG_COM_IRQHandler
|
||||||
#define TIM1_TRG_COM_TIM11_IRQHandler TIM1_TRG_COM_IRQHandler
|
#define TIM1_TRG_COM_TIM11_IRQHandler TIM1_TRG_COM_IRQHandler
|
||||||
#define TIM11_IRQHandler TIM1_TRG_COM_IRQHandler
|
|
||||||
#define TIM1_UP_TIM10_IRQHandler TIM1_UP_IRQHandler
|
|
||||||
#define TIM1_UP_TIM16_IRQHandler TIM1_UP_IRQHandler
|
#define TIM1_UP_TIM16_IRQHandler TIM1_UP_IRQHandler
|
||||||
|
#define TIM1_UP_TIM10_IRQHandler TIM1_UP_IRQHandler
|
||||||
#define TIM10_IRQHandler TIM1_UP_IRQHandler
|
#define TIM10_IRQHandler TIM1_UP_IRQHandler
|
||||||
#define TIM6_DAC_IRQHandler TIM6_IRQHandler
|
#define TIM6_DAC_IRQHandler TIM6_IRQHandler
|
||||||
|
|
||||||
|
|
|
@ -90,11 +90,11 @@
|
||||||
#endif /* USE_HAL_DRIVER */
|
#endif /* USE_HAL_DRIVER */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief CMSIS Device version number V4.3.1
|
* @brief CMSIS Device version number V4.3.2
|
||||||
*/
|
*/
|
||||||
#define __STM32F1_CMSIS_VERSION_MAIN (0x04) /*!< [31:24] main version */
|
#define __STM32F1_CMSIS_VERSION_MAIN (0x04) /*!< [31:24] main version */
|
||||||
#define __STM32F1_CMSIS_VERSION_SUB1 (0x03) /*!< [23:16] sub1 version */
|
#define __STM32F1_CMSIS_VERSION_SUB1 (0x03) /*!< [23:16] sub1 version */
|
||||||
#define __STM32F1_CMSIS_VERSION_SUB2 (0x01) /*!< [15:8] sub2 version */
|
#define __STM32F1_CMSIS_VERSION_SUB2 (0x02) /*!< [15:8] sub2 version */
|
||||||
#define __STM32F1_CMSIS_VERSION_RC (0x00) /*!< [7:0] release candidate */
|
#define __STM32F1_CMSIS_VERSION_RC (0x00) /*!< [7:0] release candidate */
|
||||||
#define __STM32F1_CMSIS_VERSION ((__STM32F1_CMSIS_VERSION_MAIN << 24)\
|
#define __STM32F1_CMSIS_VERSION ((__STM32F1_CMSIS_VERSION_MAIN << 24)\
|
||||||
|(__STM32F1_CMSIS_VERSION_SUB1 << 16)\
|
|(__STM32F1_CMSIS_VERSION_SUB1 << 16)\
|
||||||
|
|
|
@ -38,7 +38,6 @@
|
||||||
#define AES_CLEARFLAG_CCF CRYP_CLEARFLAG_CCF
|
#define AES_CLEARFLAG_CCF CRYP_CLEARFLAG_CCF
|
||||||
#define AES_CLEARFLAG_RDERR CRYP_CLEARFLAG_RDERR
|
#define AES_CLEARFLAG_RDERR CRYP_CLEARFLAG_RDERR
|
||||||
#define AES_CLEARFLAG_WRERR CRYP_CLEARFLAG_WRERR
|
#define AES_CLEARFLAG_WRERR CRYP_CLEARFLAG_WRERR
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -236,12 +235,12 @@
|
||||||
#define DAC_WAVEGENERATION_NOISE DAC_WAVE_NOISE
|
#define DAC_WAVEGENERATION_NOISE DAC_WAVE_NOISE
|
||||||
#define DAC_WAVEGENERATION_TRIANGLE DAC_WAVE_TRIANGLE
|
#define DAC_WAVEGENERATION_TRIANGLE DAC_WAVE_TRIANGLE
|
||||||
|
|
||||||
#if defined(STM32G4)
|
#if defined(STM32G4) || defined(STM32H7)
|
||||||
#define DAC_CHIPCONNECT_DISABLE (DAC_CHIPCONNECT_EXTERNAL | DAC_CHIPCONNECT_BOTH)
|
#define DAC_CHIPCONNECT_DISABLE DAC_CHIPCONNECT_EXTERNAL
|
||||||
#define DAC_CHIPCONNECT_ENABLE (DAC_CHIPCONNECT_INTERNAL | DAC_CHIPCONNECT_BOTH)
|
#define DAC_CHIPCONNECT_ENABLE DAC_CHIPCONNECT_INTERNAL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(STM32L1) || defined(STM32L4) || defined(STM32G0)
|
#if defined(STM32L1) || defined(STM32L4) || defined(STM32G0) || defined(STM32L5) || defined(STM32H7) || defined(STM32F4) || defined(STM32G4)
|
||||||
#define HAL_DAC_MSP_INIT_CB_ID HAL_DAC_MSPINIT_CB_ID
|
#define HAL_DAC_MSP_INIT_CB_ID HAL_DAC_MSPINIT_CB_ID
|
||||||
#define HAL_DAC_MSP_DEINIT_CB_ID HAL_DAC_MSPDEINIT_CB_ID
|
#define HAL_DAC_MSP_DEINIT_CB_ID HAL_DAC_MSPDEINIT_CB_ID
|
||||||
#endif
|
#endif
|
||||||
|
@ -306,8 +305,22 @@
|
||||||
#define HAL_DMAMUX_REQUEST_GEN_FALLING HAL_DMAMUX_REQ_GEN_FALLING
|
#define HAL_DMAMUX_REQUEST_GEN_FALLING HAL_DMAMUX_REQ_GEN_FALLING
|
||||||
#define HAL_DMAMUX_REQUEST_GEN_RISING_FALLING HAL_DMAMUX_REQ_GEN_RISING_FALLING
|
#define HAL_DMAMUX_REQUEST_GEN_RISING_FALLING HAL_DMAMUX_REQ_GEN_RISING_FALLING
|
||||||
|
|
||||||
|
#if defined(STM32L4R5xx) || defined(STM32L4R9xx) || defined(STM32L4R9xx) || defined(STM32L4S5xx) || defined(STM32L4S7xx) || defined(STM32L4S9xx)
|
||||||
|
#define DMA_REQUEST_DCMI_PSSI DMA_REQUEST_DCMI
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* STM32L4 */
|
#endif /* STM32L4 */
|
||||||
|
|
||||||
|
#if defined(STM32G0)
|
||||||
|
#define DMA_REQUEST_DAC1_CHANNEL1 DMA_REQUEST_DAC1_CH1
|
||||||
|
#define DMA_REQUEST_DAC1_CHANNEL2 DMA_REQUEST_DAC1_CH2
|
||||||
|
#define DMA_REQUEST_TIM16_TRIG_COM DMA_REQUEST_TIM16_COM
|
||||||
|
#define DMA_REQUEST_TIM17_TRIG_COM DMA_REQUEST_TIM17_COM
|
||||||
|
|
||||||
|
#define LL_DMAMUX_REQ_TIM16_TRIG_COM LL_DMAMUX_REQ_TIM16_COM
|
||||||
|
#define LL_DMAMUX_REQ_TIM17_TRIG_COM LL_DMAMUX_REQ_TIM17_COM
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(STM32H7)
|
#if defined(STM32H7)
|
||||||
|
|
||||||
#define DMA_REQUEST_DAC1 DMA_REQUEST_DAC1_CH1
|
#define DMA_REQUEST_DAC1 DMA_REQUEST_DAC1_CH1
|
||||||
|
@ -365,6 +378,9 @@
|
||||||
#define DFSDM_FILTER_EXT_TRIG_LPTIM2 DFSDM_FILTER_EXT_TRIG_LPTIM2_OUT
|
#define DFSDM_FILTER_EXT_TRIG_LPTIM2 DFSDM_FILTER_EXT_TRIG_LPTIM2_OUT
|
||||||
#define DFSDM_FILTER_EXT_TRIG_LPTIM3 DFSDM_FILTER_EXT_TRIG_LPTIM3_OUT
|
#define DFSDM_FILTER_EXT_TRIG_LPTIM3 DFSDM_FILTER_EXT_TRIG_LPTIM3_OUT
|
||||||
|
|
||||||
|
#define DAC_TRIGGER_LP1_OUT DAC_TRIGGER_LPTIM1_OUT
|
||||||
|
#define DAC_TRIGGER_LP2_OUT DAC_TRIGGER_LPTIM2_OUT
|
||||||
|
|
||||||
#endif /* STM32H7 */
|
#endif /* STM32H7 */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -460,7 +476,9 @@
|
||||||
#define FLASH_FLAG_SNECCE_BANK2RR FLASH_FLAG_SNECCERR_BANK2
|
#define FLASH_FLAG_SNECCE_BANK2RR FLASH_FLAG_SNECCERR_BANK2
|
||||||
#define FLASH_FLAG_DBECCE_BANK2RR FLASH_FLAG_DBECCERR_BANK2
|
#define FLASH_FLAG_DBECCE_BANK2RR FLASH_FLAG_DBECCERR_BANK2
|
||||||
#define FLASH_FLAG_STRBER_BANK2R FLASH_FLAG_STRBERR_BANK2
|
#define FLASH_FLAG_STRBER_BANK2R FLASH_FLAG_STRBERR_BANK2
|
||||||
#endif
|
#define FLASH_FLAG_WDW FLASH_FLAG_WBNE
|
||||||
|
#define OB_WRP_SECTOR_All OB_WRP_SECTOR_ALL
|
||||||
|
#endif /* STM32H7 */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
|
@ -564,7 +582,14 @@
|
||||||
#define GPIO_AF9_SDIO2 GPIO_AF9_SDMMC2
|
#define GPIO_AF9_SDIO2 GPIO_AF9_SDMMC2
|
||||||
#define GPIO_AF10_SDIO2 GPIO_AF10_SDMMC2
|
#define GPIO_AF10_SDIO2 GPIO_AF10_SDMMC2
|
||||||
#define GPIO_AF11_SDIO2 GPIO_AF11_SDMMC2
|
#define GPIO_AF11_SDIO2 GPIO_AF11_SDMMC2
|
||||||
#endif
|
|
||||||
|
#if defined (STM32H743xx) || defined (STM32H753xx) || defined (STM32H750xx) || defined (STM32H742xx) || \
|
||||||
|
defined (STM32H745xx) || defined (STM32H755xx) || defined (STM32H747xx) || defined (STM32H757xx)
|
||||||
|
#define GPIO_AF10_OTG2_HS GPIO_AF10_OTG2_FS
|
||||||
|
#define GPIO_AF10_OTG1_FS GPIO_AF10_OTG1_HS
|
||||||
|
#define GPIO_AF12_OTG2_FS GPIO_AF12_OTG1_FS
|
||||||
|
#endif /*STM32H743xx || STM32H753xx || STM32H750xx || STM32H742xx || STM32H745xx || STM32H755xx || STM32H747xx || STM32H757xx */
|
||||||
|
#endif /* STM32H7 */
|
||||||
|
|
||||||
#define GPIO_AF0_LPTIM GPIO_AF0_LPTIM1
|
#define GPIO_AF0_LPTIM GPIO_AF0_LPTIM1
|
||||||
#define GPIO_AF1_LPTIM GPIO_AF1_LPTIM1
|
#define GPIO_AF1_LPTIM GPIO_AF1_LPTIM1
|
||||||
|
@ -622,6 +647,10 @@
|
||||||
#define HAL_HRTIM_ExternalEventCounterEnable HAL_HRTIM_ExtEventCounterEnable
|
#define HAL_HRTIM_ExternalEventCounterEnable HAL_HRTIM_ExtEventCounterEnable
|
||||||
#define HAL_HRTIM_ExternalEventCounterDisable HAL_HRTIM_ExtEventCounterDisable
|
#define HAL_HRTIM_ExternalEventCounterDisable HAL_HRTIM_ExtEventCounterDisable
|
||||||
#define HAL_HRTIM_ExternalEventCounterReset HAL_HRTIM_ExtEventCounterReset
|
#define HAL_HRTIM_ExternalEventCounterReset HAL_HRTIM_ExtEventCounterReset
|
||||||
|
#define HRTIM_TIMEEVENT_A HRTIM_EVENTCOUNTER_A
|
||||||
|
#define HRTIM_TIMEEVENT_B HRTIM_EVENTCOUNTER_B
|
||||||
|
#define HRTIM_TIMEEVENTRESETMODE_UNCONDITIONAL HRTIM_EVENTCOUNTER_RSTMODE_UNCONDITIONAL
|
||||||
|
#define HRTIM_TIMEEVENTRESETMODE_CONDITIONAL HRTIM_EVENTCOUNTER_RSTMODE_CONDITIONAL
|
||||||
#endif /* STM32G4 */
|
#endif /* STM32G4 */
|
||||||
|
|
||||||
#if defined(STM32H7)
|
#if defined(STM32H7)
|
||||||
|
@ -735,6 +764,66 @@
|
||||||
#define HRTIM_OUTPUTRESET_TIMFEV8_TIMECMP2 HRTIM_OUTPUTSET_TIMEV_8
|
#define HRTIM_OUTPUTRESET_TIMFEV8_TIMECMP2 HRTIM_OUTPUTSET_TIMEV_8
|
||||||
#define HRTIM_OUTPUTRESET_TIMFEV9_TIMECMP3 HRTIM_OUTPUTSET_TIMEV_9
|
#define HRTIM_OUTPUTRESET_TIMFEV9_TIMECMP3 HRTIM_OUTPUTSET_TIMEV_9
|
||||||
#endif /* STM32H7 */
|
#endif /* STM32H7 */
|
||||||
|
|
||||||
|
#if defined(STM32F3)
|
||||||
|
/** @brief Constants defining available sources associated to external events.
|
||||||
|
*/
|
||||||
|
#define HRTIM_EVENTSRC_1 (0x00000000U)
|
||||||
|
#define HRTIM_EVENTSRC_2 (HRTIM_EECR1_EE1SRC_0)
|
||||||
|
#define HRTIM_EVENTSRC_3 (HRTIM_EECR1_EE1SRC_1)
|
||||||
|
#define HRTIM_EVENTSRC_4 (HRTIM_EECR1_EE1SRC_1 | HRTIM_EECR1_EE1SRC_0)
|
||||||
|
|
||||||
|
/** @brief Constants defining the events that can be selected to configure the
|
||||||
|
* set/reset crossbar of a timer output
|
||||||
|
*/
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_1 (HRTIM_SET1R_TIMEVNT1)
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_2 (HRTIM_SET1R_TIMEVNT2)
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_3 (HRTIM_SET1R_TIMEVNT3)
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_4 (HRTIM_SET1R_TIMEVNT4)
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_5 (HRTIM_SET1R_TIMEVNT5)
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_6 (HRTIM_SET1R_TIMEVNT6)
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_7 (HRTIM_SET1R_TIMEVNT7)
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_8 (HRTIM_SET1R_TIMEVNT8)
|
||||||
|
#define HRTIM_OUTPUTSET_TIMEV_9 (HRTIM_SET1R_TIMEVNT9)
|
||||||
|
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_1 (HRTIM_RST1R_TIMEVNT1)
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_2 (HRTIM_RST1R_TIMEVNT2)
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_3 (HRTIM_RST1R_TIMEVNT3)
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_4 (HRTIM_RST1R_TIMEVNT4)
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_5 (HRTIM_RST1R_TIMEVNT5)
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_6 (HRTIM_RST1R_TIMEVNT6)
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_7 (HRTIM_RST1R_TIMEVNT7)
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_8 (HRTIM_RST1R_TIMEVNT8)
|
||||||
|
#define HRTIM_OUTPUTRESET_TIMEV_9 (HRTIM_RST1R_TIMEVNT9)
|
||||||
|
|
||||||
|
/** @brief Constants defining the event filtering applied to external events
|
||||||
|
* by a timer
|
||||||
|
*/
|
||||||
|
#define HRTIM_TIMEVENTFILTER_NONE (0x00000000U)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGCMP1 (HRTIM_EEFR1_EE1FLTR_0)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGCMP2 (HRTIM_EEFR1_EE1FLTR_1)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGCMP3 (HRTIM_EEFR1_EE1FLTR_1 | HRTIM_EEFR1_EE1FLTR_0)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGCMP4 (HRTIM_EEFR1_EE1FLTR_2)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGFLTR1 (HRTIM_EEFR1_EE1FLTR_2 | HRTIM_EEFR1_EE1FLTR_0)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGFLTR2 (HRTIM_EEFR1_EE1FLTR_2 | HRTIM_EEFR1_EE1FLTR_1)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGFLTR3 (HRTIM_EEFR1_EE1FLTR_2 | HRTIM_EEFR1_EE1FLTR_1 | HRTIM_EEFR1_EE1FLTR_0)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGFLTR4 (HRTIM_EEFR1_EE1FLTR_3)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGFLTR5 (HRTIM_EEFR1_EE1FLTR_3 | HRTIM_EEFR1_EE1FLTR_0)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGFLTR6 (HRTIM_EEFR1_EE1FLTR_3 | HRTIM_EEFR1_EE1FLTR_1)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGFLTR7 (HRTIM_EEFR1_EE1FLTR_3 | HRTIM_EEFR1_EE1FLTR_1 | HRTIM_EEFR1_EE1FLTR_0)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_BLANKINGFLTR8 (HRTIM_EEFR1_EE1FLTR_3 | HRTIM_EEFR1_EE1FLTR_2)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_WINDOWINGCMP2 (HRTIM_EEFR1_EE1FLTR_3 | HRTIM_EEFR1_EE1FLTR_2 | HRTIM_EEFR1_EE1FLTR_0)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_WINDOWINGCMP3 (HRTIM_EEFR1_EE1FLTR_3 | HRTIM_EEFR1_EE1FLTR_2 | HRTIM_EEFR1_EE1FLTR_1)
|
||||||
|
#define HRTIM_TIMEVENTFILTER_WINDOWINGTIM (HRTIM_EEFR1_EE1FLTR_3 | HRTIM_EEFR1_EE1FLTR_2 | HRTIM_EEFR1_EE1FLTR_1 | HRTIM_EEFR1_EE1FLTR_0)
|
||||||
|
|
||||||
|
/** @brief Constants defining the DLL calibration periods (in micro seconds)
|
||||||
|
*/
|
||||||
|
#define HRTIM_CALIBRATIONRATE_7300 0x00000000U
|
||||||
|
#define HRTIM_CALIBRATIONRATE_910 (HRTIM_DLLCR_CALRTE_0)
|
||||||
|
#define HRTIM_CALIBRATIONRATE_114 (HRTIM_DLLCR_CALRTE_1)
|
||||||
|
#define HRTIM_CALIBRATIONRATE_14 (HRTIM_DLLCR_CALRTE_1 | HRTIM_DLLCR_CALRTE_0)
|
||||||
|
|
||||||
|
#endif /* STM32F3 */
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -874,7 +963,7 @@
|
||||||
#define OPAMP_PGACONNECT_VM0 OPAMP_PGA_CONNECT_INVERTINGINPUT_IO0
|
#define OPAMP_PGACONNECT_VM0 OPAMP_PGA_CONNECT_INVERTINGINPUT_IO0
|
||||||
#define OPAMP_PGACONNECT_VM1 OPAMP_PGA_CONNECT_INVERTINGINPUT_IO1
|
#define OPAMP_PGACONNECT_VM1 OPAMP_PGA_CONNECT_INVERTINGINPUT_IO1
|
||||||
|
|
||||||
#if defined(STM32L1) || defined(STM32L4)
|
#if defined(STM32L1) || defined(STM32L4) || defined(STM32L5) || defined(STM32H7) || defined(STM32G4)
|
||||||
#define HAL_OPAMP_MSP_INIT_CB_ID HAL_OPAMP_MSPINIT_CB_ID
|
#define HAL_OPAMP_MSP_INIT_CB_ID HAL_OPAMP_MSPINIT_CB_ID
|
||||||
#define HAL_OPAMP_MSP_DEINIT_CB_ID HAL_OPAMP_MSPDEINIT_CB_ID
|
#define HAL_OPAMP_MSP_DEINIT_CB_ID HAL_OPAMP_MSPDEINIT_CB_ID
|
||||||
#endif
|
#endif
|
||||||
|
@ -933,7 +1022,7 @@
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** @defgroup HAL_RTC_Aliased_Defines HAL RTC Aliased Defines maintained for legacy purpose
|
/** @defgroup HAL_RTC_Aliased_Defines HAL RTC Aliased Defines maintained for legacy purpose
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
@ -965,6 +1054,16 @@
|
||||||
#define RTC_TAMPERPIN_PA0 RTC_TAMPERPIN_POS1
|
#define RTC_TAMPERPIN_PA0 RTC_TAMPERPIN_POS1
|
||||||
#define RTC_TAMPERPIN_PI8 RTC_TAMPERPIN_POS1
|
#define RTC_TAMPERPIN_PI8 RTC_TAMPERPIN_POS1
|
||||||
|
|
||||||
|
#if defined(STM32H7)
|
||||||
|
#define RTC_TAMPCR_TAMPXE RTC_TAMPER_X
|
||||||
|
#define RTC_TAMPCR_TAMPXIE RTC_TAMPER_X_INTERRUPT
|
||||||
|
|
||||||
|
#define RTC_TAMPER1_INTERRUPT RTC_IT_TAMP1
|
||||||
|
#define RTC_TAMPER2_INTERRUPT RTC_IT_TAMP2
|
||||||
|
#define RTC_TAMPER3_INTERRUPT RTC_IT_TAMP3
|
||||||
|
#define RTC_ALL_TAMPER_INTERRUPT RTC_IT_TAMPALL
|
||||||
|
#endif /* STM32H7 */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -1358,6 +1457,30 @@
|
||||||
|
|
||||||
#define HASH_HMACKeyType_ShortKey HASH_HMAC_KEYTYPE_SHORTKEY
|
#define HASH_HMACKeyType_ShortKey HASH_HMAC_KEYTYPE_SHORTKEY
|
||||||
#define HASH_HMACKeyType_LongKey HASH_HMAC_KEYTYPE_LONGKEY
|
#define HASH_HMACKeyType_LongKey HASH_HMAC_KEYTYPE_LONGKEY
|
||||||
|
|
||||||
|
#if defined(STM32L4) || defined(STM32L5) || defined(STM32F2) || defined(STM32F4) || defined(STM32F7) || defined(STM32H7)
|
||||||
|
|
||||||
|
#define HAL_HASH_MD5_Accumulate HAL_HASH_MD5_Accmlt
|
||||||
|
#define HAL_HASH_MD5_Accumulate_End HAL_HASH_MD5_Accmlt_End
|
||||||
|
#define HAL_HASH_MD5_Accumulate_IT HAL_HASH_MD5_Accmlt_IT
|
||||||
|
#define HAL_HASH_MD5_Accumulate_End_IT HAL_HASH_MD5_Accmlt_End_IT
|
||||||
|
|
||||||
|
#define HAL_HASH_SHA1_Accumulate HAL_HASH_SHA1_Accmlt
|
||||||
|
#define HAL_HASH_SHA1_Accumulate_End HAL_HASH_SHA1_Accmlt_End
|
||||||
|
#define HAL_HASH_SHA1_Accumulate_IT HAL_HASH_SHA1_Accmlt_IT
|
||||||
|
#define HAL_HASH_SHA1_Accumulate_End_IT HAL_HASH_SHA1_Accmlt_End_IT
|
||||||
|
|
||||||
|
#define HAL_HASHEx_SHA224_Accumulate HAL_HASHEx_SHA224_Accmlt
|
||||||
|
#define HAL_HASHEx_SHA224_Accumulate_End HAL_HASHEx_SHA224_Accmlt_End
|
||||||
|
#define HAL_HASHEx_SHA224_Accumulate_IT HAL_HASHEx_SHA224_Accmlt_IT
|
||||||
|
#define HAL_HASHEx_SHA224_Accumulate_End_IT HAL_HASHEx_SHA224_Accmlt_End_IT
|
||||||
|
|
||||||
|
#define HAL_HASHEx_SHA256_Accumulate HAL_HASHEx_SHA256_Accmlt
|
||||||
|
#define HAL_HASHEx_SHA256_Accumulate_End HAL_HASHEx_SHA256_Accmlt_End
|
||||||
|
#define HAL_HASHEx_SHA256_Accumulate_IT HAL_HASHEx_SHA256_Accmlt_IT
|
||||||
|
#define HAL_HASHEx_SHA256_Accumulate_End_IT HAL_HASHEx_SHA256_Accmlt_End_IT
|
||||||
|
|
||||||
|
#endif /* STM32L4 || STM32L5 || STM32F2 || STM32F4 || STM32F7 || STM32H7 */
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -1380,6 +1503,13 @@
|
||||||
#endif
|
#endif
|
||||||
#define HAL_ADC_EnableBuffer_Cmd(cmd) (((cmd)==ENABLE) ? HAL_ADCEx_EnableVREFINT() : HAL_ADCEx_DisableVREFINT())
|
#define HAL_ADC_EnableBuffer_Cmd(cmd) (((cmd)==ENABLE) ? HAL_ADCEx_EnableVREFINT() : HAL_ADCEx_DisableVREFINT())
|
||||||
#define HAL_ADC_EnableBufferSensor_Cmd(cmd) (((cmd)==ENABLE) ? HAL_ADCEx_EnableVREFINTTempSensor() : HAL_ADCEx_DisableVREFINTTempSensor())
|
#define HAL_ADC_EnableBufferSensor_Cmd(cmd) (((cmd)==ENABLE) ? HAL_ADCEx_EnableVREFINTTempSensor() : HAL_ADCEx_DisableVREFINTTempSensor())
|
||||||
|
#if defined(STM32H7A3xx) || defined(STM32H7B3xx) || defined(STM32H7B0xx) || defined(STM32H7A3xxQ) || defined(STM32H7B3xxQ) || defined(STM32H7B0xxQ)
|
||||||
|
#define HAL_EnableSRDomainDBGStopMode HAL_EnableDomain3DBGStopMode
|
||||||
|
#define HAL_DisableSRDomainDBGStopMode HAL_DisableDomain3DBGStopMode
|
||||||
|
#define HAL_EnableSRDomainDBGStandbyMode HAL_EnableDomain3DBGStandbyMode
|
||||||
|
#define HAL_DisableSRDomainDBGStandbyMode HAL_DisableDomain3DBGStandbyMode
|
||||||
|
#endif /* STM32H7A3xx || STM32H7B3xx || STM32H7B0xx || STM32H7A3xxQ || STM32H7B3xxQ || STM32H7B0xxQ */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -1409,16 +1539,18 @@
|
||||||
|
|
||||||
#define HAL_I2CFastModePlusConfig(SYSCFG_I2CFastModePlus, cmd) (((cmd)==ENABLE)? HAL_I2CEx_EnableFastModePlus(SYSCFG_I2CFastModePlus): HAL_I2CEx_DisableFastModePlus(SYSCFG_I2CFastModePlus))
|
#define HAL_I2CFastModePlusConfig(SYSCFG_I2CFastModePlus, cmd) (((cmd)==ENABLE)? HAL_I2CEx_EnableFastModePlus(SYSCFG_I2CFastModePlus): HAL_I2CEx_DisableFastModePlus(SYSCFG_I2CFastModePlus))
|
||||||
|
|
||||||
#if defined(STM32H7) || defined(STM32WB) || defined(STM32G0) || defined(STM32F4) || defined(STM32F7) || defined(STM32L0) || defined(STM32L4) || defined(STM32G4)
|
#if defined(STM32H7) || defined(STM32WB) || defined(STM32G0) || defined(STM32F0) || defined(STM32F1) || defined(STM32F2) || defined(STM32F3) || defined(STM32F4) || defined(STM32F7) || defined(STM32L0) || defined(STM32L4) || defined(STM32L5) || defined(STM32G4) || defined(STM32L1)
|
||||||
#define HAL_I2C_Master_Sequential_Transmit_IT HAL_I2C_Master_Seq_Transmit_IT
|
#define HAL_I2C_Master_Sequential_Transmit_IT HAL_I2C_Master_Seq_Transmit_IT
|
||||||
#define HAL_I2C_Master_Sequential_Receive_IT HAL_I2C_Master_Seq_Receive_IT
|
#define HAL_I2C_Master_Sequential_Receive_IT HAL_I2C_Master_Seq_Receive_IT
|
||||||
#define HAL_I2C_Slave_Sequential_Transmit_IT HAL_I2C_Slave_Seq_Transmit_IT
|
#define HAL_I2C_Slave_Sequential_Transmit_IT HAL_I2C_Slave_Seq_Transmit_IT
|
||||||
#define HAL_I2C_Slave_Sequential_Receive_IT HAL_I2C_Slave_Seq_Receive_IT
|
#define HAL_I2C_Slave_Sequential_Receive_IT HAL_I2C_Slave_Seq_Receive_IT
|
||||||
|
#endif /* STM32H7 || STM32WB || STM32G0 || STM32F0 || STM32F1 || STM32F2 || STM32F3 || STM32F4 || STM32F7 || STM32L0 || STM32L4 || STM32L5 || STM32G4 || STM32L1 */
|
||||||
|
#if defined(STM32H7) || defined(STM32WB) || defined(STM32G0) || defined(STM32F4) || defined(STM32F7) || defined(STM32L0) || defined(STM32L4) || defined(STM32L5) || defined(STM32G4)|| defined(STM32L1)
|
||||||
#define HAL_I2C_Master_Sequential_Transmit_DMA HAL_I2C_Master_Seq_Transmit_DMA
|
#define HAL_I2C_Master_Sequential_Transmit_DMA HAL_I2C_Master_Seq_Transmit_DMA
|
||||||
#define HAL_I2C_Master_Sequential_Receive_DMA HAL_I2C_Master_Seq_Receive_DMA
|
#define HAL_I2C_Master_Sequential_Receive_DMA HAL_I2C_Master_Seq_Receive_DMA
|
||||||
#define HAL_I2C_Slave_Sequential_Transmit_DMA HAL_I2C_Slave_Seq_Transmit_DMA
|
#define HAL_I2C_Slave_Sequential_Transmit_DMA HAL_I2C_Slave_Seq_Transmit_DMA
|
||||||
#define HAL_I2C_Slave_Sequential_Receive_DMA HAL_I2C_Slave_Seq_Receive_DMA
|
#define HAL_I2C_Slave_Sequential_Receive_DMA HAL_I2C_Slave_Seq_Receive_DMA
|
||||||
#endif /* STM32H7 || STM32WB || STM32G0 || STM32F4 || STM32F7 || STM32L0 || STM32L4 */
|
#endif /* STM32H7 || STM32WB || STM32G0 || STM32F4 || STM32F7 || STM32L0 || STM32L4 || STM32L5 || STM32G4 || STM32L1 */
|
||||||
|
|
||||||
#if defined(STM32F4)
|
#if defined(STM32F4)
|
||||||
#define HAL_FMPI2C_Master_Sequential_Transmit_IT HAL_FMPI2C_Master_Seq_Transmit_IT
|
#define HAL_FMPI2C_Master_Sequential_Transmit_IT HAL_FMPI2C_Master_Seq_Transmit_IT
|
||||||
|
@ -1437,6 +1569,13 @@
|
||||||
/** @defgroup HAL_PWR_Aliased HAL PWR Aliased maintained for legacy purpose
|
/** @defgroup HAL_PWR_Aliased HAL PWR Aliased maintained for legacy purpose
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#if defined(STM32G0)
|
||||||
|
#define HAL_PWR_ConfigPVD HAL_PWREx_ConfigPVD
|
||||||
|
#define HAL_PWR_EnablePVD HAL_PWREx_EnablePVD
|
||||||
|
#define HAL_PWR_DisablePVD HAL_PWREx_DisablePVD
|
||||||
|
#define HAL_PWR_PVD_IRQHandler HAL_PWREx_PVD_IRQHandler
|
||||||
|
#endif
|
||||||
#define HAL_PWR_PVDConfig HAL_PWR_ConfigPVD
|
#define HAL_PWR_PVDConfig HAL_PWR_ConfigPVD
|
||||||
#define HAL_PWR_DisableBkUpReg HAL_PWREx_DisableBkUpReg
|
#define HAL_PWR_DisableBkUpReg HAL_PWREx_DisableBkUpReg
|
||||||
#define HAL_PWR_DisableFlashPowerDown HAL_PWREx_DisableFlashPowerDown
|
#define HAL_PWR_DisableFlashPowerDown HAL_PWREx_DisableFlashPowerDown
|
||||||
|
@ -1509,14 +1648,14 @@
|
||||||
#define HAL_TIM_DMAError TIM_DMAError
|
#define HAL_TIM_DMAError TIM_DMAError
|
||||||
#define HAL_TIM_DMACaptureCplt TIM_DMACaptureCplt
|
#define HAL_TIM_DMACaptureCplt TIM_DMACaptureCplt
|
||||||
#define HAL_TIMEx_DMACommutationCplt TIMEx_DMACommutationCplt
|
#define HAL_TIMEx_DMACommutationCplt TIMEx_DMACommutationCplt
|
||||||
#if defined(STM32H7) || defined(STM32G0) || defined(STM32F7) || defined(STM32F4) || defined(STM32L0) || defined(STM32L4)
|
#if defined(STM32H7) || defined(STM32G0) || defined(STM32F0) || defined(STM32F1) || defined(STM32F2) || defined(STM32F3) || defined(STM32F4) || defined(STM32F7) || defined(STM32L0) || defined(STM32L4)
|
||||||
#define HAL_TIM_SlaveConfigSynchronization HAL_TIM_SlaveConfigSynchro
|
#define HAL_TIM_SlaveConfigSynchronization HAL_TIM_SlaveConfigSynchro
|
||||||
#define HAL_TIM_SlaveConfigSynchronization_IT HAL_TIM_SlaveConfigSynchro_IT
|
#define HAL_TIM_SlaveConfigSynchronization_IT HAL_TIM_SlaveConfigSynchro_IT
|
||||||
#define HAL_TIMEx_CommutationCallback HAL_TIMEx_CommutCallback
|
#define HAL_TIMEx_CommutationCallback HAL_TIMEx_CommutCallback
|
||||||
#define HAL_TIMEx_ConfigCommutationEvent HAL_TIMEx_ConfigCommutEvent
|
#define HAL_TIMEx_ConfigCommutationEvent HAL_TIMEx_ConfigCommutEvent
|
||||||
#define HAL_TIMEx_ConfigCommutationEvent_IT HAL_TIMEx_ConfigCommutEvent_IT
|
#define HAL_TIMEx_ConfigCommutationEvent_IT HAL_TIMEx_ConfigCommutEvent_IT
|
||||||
#define HAL_TIMEx_ConfigCommutationEvent_DMA HAL_TIMEx_ConfigCommutEvent_DMA
|
#define HAL_TIMEx_ConfigCommutationEvent_DMA HAL_TIMEx_ConfigCommutEvent_DMA
|
||||||
#endif /* STM32H7 || STM32G0 || STM32F7 || STM32F4 || STM32L0 */
|
#endif /* STM32H7 || STM32G0 || STM32F0 || STM32F1 || STM32F2 || STM32F3 || STM32F4 || STM32F7 || STM32L0 */
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -3112,9 +3251,8 @@
|
||||||
#define RCC_MCOSOURCE_PLLCLK_NODIV RCC_MCO1SOURCE_PLLCLK
|
#define RCC_MCOSOURCE_PLLCLK_NODIV RCC_MCO1SOURCE_PLLCLK
|
||||||
#define RCC_MCOSOURCE_PLLCLK_DIV2 RCC_MCO1SOURCE_PLLCLK_DIV2
|
#define RCC_MCOSOURCE_PLLCLK_DIV2 RCC_MCO1SOURCE_PLLCLK_DIV2
|
||||||
|
|
||||||
#if defined(STM32L4)
|
#if defined(STM32L4) || defined(STM32WB) || defined(STM32G0) || defined(STM32G4) || defined(STM32L5)
|
||||||
#define RCC_RTCCLKSOURCE_NO_CLK RCC_RTCCLKSOURCE_NONE
|
#define RCC_RTCCLKSOURCE_NO_CLK RCC_RTCCLKSOURCE_NONE
|
||||||
#elif defined(STM32WB) || defined(STM32G0) || defined(STM32G4)
|
|
||||||
#else
|
#else
|
||||||
#define RCC_RTCCLKSOURCE_NONE RCC_RTCCLKSOURCE_NO_CLK
|
#define RCC_RTCCLKSOURCE_NONE RCC_RTCCLKSOURCE_NO_CLK
|
||||||
#endif
|
#endif
|
||||||
|
@ -3242,7 +3380,7 @@
|
||||||
/** @defgroup HAL_RTC_Aliased_Macros HAL RTC Aliased Macros maintained for legacy purpose
|
/** @defgroup HAL_RTC_Aliased_Macros HAL RTC Aliased Macros maintained for legacy purpose
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#if defined (STM32G0) || defined (STM32L412xx) || defined (STM32L422xx) || defined (STM32G4)
|
#if defined (STM32G0) || defined (STM32L5) || defined (STM32L412xx) || defined (STM32L422xx) || defined (STM32L4P5xx) || defined (STM32L4Q5xx) || defined (STM32G4)
|
||||||
#else
|
#else
|
||||||
#define __HAL_RTC_CLEAR_FLAG __HAL_RTC_EXTI_CLEAR_FLAG
|
#define __HAL_RTC_CLEAR_FLAG __HAL_RTC_EXTI_CLEAR_FLAG
|
||||||
#endif
|
#endif
|
||||||
|
@ -3350,9 +3488,9 @@
|
||||||
#define __HAL_SD_SDIO_CLEAR_FLAG __HAL_SD_SDMMC_CLEAR_FLAG
|
#define __HAL_SD_SDIO_CLEAR_FLAG __HAL_SD_SDMMC_CLEAR_FLAG
|
||||||
#define __HAL_SD_SDIO_GET_IT __HAL_SD_SDMMC_GET_IT
|
#define __HAL_SD_SDIO_GET_IT __HAL_SD_SDMMC_GET_IT
|
||||||
#define __HAL_SD_SDIO_CLEAR_IT __HAL_SD_SDMMC_CLEAR_IT
|
#define __HAL_SD_SDIO_CLEAR_IT __HAL_SD_SDMMC_CLEAR_IT
|
||||||
#define SDIO_STATIC_FLAGS SDMMC_STATIC_FLAGS
|
#define SDIO_STATIC_FLAGS SDMMC_STATIC_FLAGS
|
||||||
#define SDIO_CMD0TIMEOUT SDMMC_CMD0TIMEOUT
|
#define SDIO_CMD0TIMEOUT SDMMC_CMD0TIMEOUT
|
||||||
#define SD_SDIO_SEND_IF_COND SD_SDMMC_SEND_IF_COND
|
#define SD_SDIO_SEND_IF_COND SD_SDMMC_SEND_IF_COND
|
||||||
/* alias CMSIS for compatibilities */
|
/* alias CMSIS for compatibilities */
|
||||||
#define SDIO_IRQn SDMMC1_IRQn
|
#define SDIO_IRQn SDMMC1_IRQn
|
||||||
#define SDIO_IRQHandler SDMMC1_IRQHandler
|
#define SDIO_IRQHandler SDMMC1_IRQHandler
|
||||||
|
@ -3365,7 +3503,7 @@
|
||||||
#define HAL_SD_CardStateTypedef HAL_SD_CardStateTypeDef
|
#define HAL_SD_CardStateTypedef HAL_SD_CardStateTypeDef
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(STM32H7)
|
#if defined(STM32H7) || defined(STM32L5)
|
||||||
#define HAL_MMCEx_Read_DMADoubleBuffer0CpltCallback HAL_MMCEx_Read_DMADoubleBuf0CpltCallback
|
#define HAL_MMCEx_Read_DMADoubleBuffer0CpltCallback HAL_MMCEx_Read_DMADoubleBuf0CpltCallback
|
||||||
#define HAL_MMCEx_Read_DMADoubleBuffer1CpltCallback HAL_MMCEx_Read_DMADoubleBuf1CpltCallback
|
#define HAL_MMCEx_Read_DMADoubleBuffer1CpltCallback HAL_MMCEx_Read_DMADoubleBuf1CpltCallback
|
||||||
#define HAL_MMCEx_Write_DMADoubleBuffer0CpltCallback HAL_MMCEx_Write_DMADoubleBuf0CpltCallback
|
#define HAL_MMCEx_Write_DMADoubleBuffer0CpltCallback HAL_MMCEx_Write_DMADoubleBuf0CpltCallback
|
||||||
|
@ -3606,12 +3744,12 @@
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#if defined (STM32H7) || defined (STM32G4) || defined (STM32F3)
|
#if defined (STM32H7) || defined (STM32G4) || defined (STM32F3)
|
||||||
#define HAL_HRTIM_WaveformCounterStart_IT HAL_HRTIM_WaveformCountStart_IT
|
#define HAL_HRTIM_WaveformCounterStart_IT HAL_HRTIM_WaveformCountStart_IT
|
||||||
#define HAL_HRTIM_WaveformCounterStart_DMA HAL_HRTIM_WaveformCountStart_DMA
|
#define HAL_HRTIM_WaveformCounterStart_DMA HAL_HRTIM_WaveformCountStart_DMA
|
||||||
#define HAL_HRTIM_WaveformCounterStart HAL_HRTIM_WaveformCountStart
|
#define HAL_HRTIM_WaveformCounterStart HAL_HRTIM_WaveformCountStart
|
||||||
#define HAL_HRTIM_WaveformCounterStop_IT HAL_HRTIM_WaveformCountStop_IT
|
#define HAL_HRTIM_WaveformCounterStop_IT HAL_HRTIM_WaveformCountStop_IT
|
||||||
#define HAL_HRTIM_WaveformCounterStop_DMA HAL_HRTIM_WaveformCountStop_DMA
|
#define HAL_HRTIM_WaveformCounterStop_DMA HAL_HRTIM_WaveformCountStop_DMA
|
||||||
#define HAL_HRTIM_WaveformCounterStop HAL_HRTIM_WaveformCountStop
|
#define HAL_HRTIM_WaveformCounterStop HAL_HRTIM_WaveformCountStop
|
||||||
#endif
|
#endif
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
|
@ -3620,9 +3758,9 @@
|
||||||
/** @defgroup HAL_QSPI_Aliased_Macros HAL QSPI Aliased Macros maintained for legacy purpose
|
/** @defgroup HAL_QSPI_Aliased_Macros HAL QSPI Aliased Macros maintained for legacy purpose
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#if defined (STM32L4)
|
#if defined (STM32L4) || defined (STM32F4) || defined (STM32F7) || defined(STM32H7)
|
||||||
#define HAL_QPSI_TIMEOUT_DEFAULT_VALUE HAL_QSPI_TIMEOUT_DEFAULT_VALUE
|
#define HAL_QPSI_TIMEOUT_DEFAULT_VALUE HAL_QSPI_TIMEOUT_DEFAULT_VALUE
|
||||||
#endif
|
#endif /* STM32L4 || STM32F4 || STM32F7 */
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -57,6 +57,7 @@ typedef enum
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
/* Exported types ------------------------------------------------------------*/
|
/* Exported types ------------------------------------------------------------*/
|
||||||
|
extern __IO uint32_t uwTick;
|
||||||
extern uint32_t uwTickPrio;
|
extern uint32_t uwTickPrio;
|
||||||
extern HAL_TickFreqTypeDef uwTickFreq;
|
extern HAL_TickFreqTypeDef uwTickFreq;
|
||||||
|
|
||||||
|
|
|
@ -28,9 +28,7 @@ extern "C" {
|
||||||
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* Includes ------------------------------------------------------------------*/
|
||||||
#include "stm32f1xx.h"
|
#include "stm32f1xx.h"
|
||||||
#if defined(USE_HAL_LEGACY)
|
|
||||||
#include "Legacy/stm32_hal_legacy.h"
|
#include "Legacy/stm32_hal_legacy.h"
|
||||||
#endif
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
/* Exported types ------------------------------------------------------------*/
|
/* Exported types ------------------------------------------------------------*/
|
||||||
|
@ -108,7 +106,14 @@ typedef enum
|
||||||
}while (0U)
|
}while (0U)
|
||||||
#endif /* USE_RTOS */
|
#endif /* USE_RTOS */
|
||||||
|
|
||||||
#if defined ( __GNUC__ ) && !defined (__CC_ARM) /* GNU Compiler */
|
#if defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) /* ARM Compiler V6 */
|
||||||
|
#ifndef __weak
|
||||||
|
#define __weak __attribute__((weak))
|
||||||
|
#endif
|
||||||
|
#ifndef __packed
|
||||||
|
#define __packed __attribute__((packed))
|
||||||
|
#endif
|
||||||
|
#elif defined ( __GNUC__ ) && !defined (__CC_ARM) /* GNU Compiler */
|
||||||
#ifndef __weak
|
#ifndef __weak
|
||||||
#define __weak __attribute__((weak))
|
#define __weak __attribute__((weak))
|
||||||
#endif /* __weak */
|
#endif /* __weak */
|
||||||
|
@ -119,7 +124,14 @@ typedef enum
|
||||||
|
|
||||||
|
|
||||||
/* Macro to get variable aligned on 4-bytes, for __ICCARM__ the directive "#pragma data_alignment=4" must be used instead */
|
/* Macro to get variable aligned on 4-bytes, for __ICCARM__ the directive "#pragma data_alignment=4" must be used instead */
|
||||||
#if defined ( __GNUC__ ) && !defined (__CC_ARM) /* GNU Compiler */
|
#if defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) /* ARM Compiler V6 */
|
||||||
|
#ifndef __ALIGN_BEGIN
|
||||||
|
#define __ALIGN_BEGIN
|
||||||
|
#endif
|
||||||
|
#ifndef __ALIGN_END
|
||||||
|
#define __ALIGN_END __attribute__ ((aligned (4)))
|
||||||
|
#endif
|
||||||
|
#elif defined ( __GNUC__ ) && !defined (__CC_ARM) /* GNU Compiler */
|
||||||
#ifndef __ALIGN_END
|
#ifndef __ALIGN_END
|
||||||
#define __ALIGN_END __attribute__ ((aligned (4)))
|
#define __ALIGN_END __attribute__ ((aligned (4)))
|
||||||
#endif /* __ALIGN_END */
|
#endif /* __ALIGN_END */
|
||||||
|
@ -131,7 +143,7 @@ typedef enum
|
||||||
#define __ALIGN_END
|
#define __ALIGN_END
|
||||||
#endif /* __ALIGN_END */
|
#endif /* __ALIGN_END */
|
||||||
#ifndef __ALIGN_BEGIN
|
#ifndef __ALIGN_BEGIN
|
||||||
#if defined (__CC_ARM) /* ARM Compiler */
|
#if defined (__CC_ARM) /* ARM Compiler V5*/
|
||||||
#define __ALIGN_BEGIN __align(4)
|
#define __ALIGN_BEGIN __align(4)
|
||||||
#elif defined (__ICCARM__) /* IAR Compiler */
|
#elif defined (__ICCARM__) /* IAR Compiler */
|
||||||
#define __ALIGN_BEGIN
|
#define __ALIGN_BEGIN
|
||||||
|
@ -143,9 +155,9 @@ typedef enum
|
||||||
/**
|
/**
|
||||||
* @brief __RAM_FUNC definition
|
* @brief __RAM_FUNC definition
|
||||||
*/
|
*/
|
||||||
#if defined ( __CC_ARM )
|
#if defined ( __CC_ARM ) || (defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050))
|
||||||
/* ARM Compiler
|
/* ARM Compiler V4/V5 and V6
|
||||||
------------
|
--------------------------
|
||||||
RAM functions are defined using the toolchain options.
|
RAM functions are defined using the toolchain options.
|
||||||
Functions that are executed in RAM should reside in a separate source module.
|
Functions that are executed in RAM should reside in a separate source module.
|
||||||
Using the 'Options for File' dialog you can simply change the 'Code / Const'
|
Using the 'Options for File' dialog you can simply change the 'Code / Const'
|
||||||
|
@ -175,9 +187,9 @@ typedef enum
|
||||||
/**
|
/**
|
||||||
* @brief __NOINLINE definition
|
* @brief __NOINLINE definition
|
||||||
*/
|
*/
|
||||||
#if defined ( __CC_ARM ) || defined ( __GNUC__ )
|
#if defined ( __CC_ARM ) || (defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)) || defined ( __GNUC__ )
|
||||||
/* ARM & GNUCompiler
|
/* ARM V4/V5 and V6 & GNU Compiler
|
||||||
----------------
|
-------------------------------
|
||||||
*/
|
*/
|
||||||
#define __NOINLINE __attribute__ ( (noinline) )
|
#define __NOINLINE __attribute__ ( (noinline) )
|
||||||
|
|
||||||
|
|
|
@ -170,6 +170,7 @@ typedef enum
|
||||||
#define HAL_I2C_ERROR_TIMEOUT 0x00000020U /*!< Timeout Error */
|
#define HAL_I2C_ERROR_TIMEOUT 0x00000020U /*!< Timeout Error */
|
||||||
#define HAL_I2C_ERROR_SIZE 0x00000040U /*!< Size Management error */
|
#define HAL_I2C_ERROR_SIZE 0x00000040U /*!< Size Management error */
|
||||||
#define HAL_I2C_ERROR_DMA_PARAM 0x00000080U /*!< DMA Parameter Error */
|
#define HAL_I2C_ERROR_DMA_PARAM 0x00000080U /*!< DMA Parameter Error */
|
||||||
|
#define HAL_I2C_WRONG_START 0x00000200U /*!< Wrong start Error */
|
||||||
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
||||||
#define HAL_I2C_ERROR_INVALID_CALLBACK 0x00000100U /*!< Invalid Callback error */
|
#define HAL_I2C_ERROR_INVALID_CALLBACK 0x00000100U /*!< Invalid Callback error */
|
||||||
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
||||||
|
@ -181,7 +182,11 @@ typedef enum
|
||||||
* @brief I2C handle Structure definition
|
* @brief I2C handle Structure definition
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
||||||
typedef struct __I2C_HandleTypeDef
|
typedef struct __I2C_HandleTypeDef
|
||||||
|
#else
|
||||||
|
typedef struct
|
||||||
|
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
||||||
{
|
{
|
||||||
I2C_TypeDef *Instance; /*!< I2C registers base address */
|
I2C_TypeDef *Instance; /*!< I2C registers base address */
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@ extern "C" {
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** @addtogroup IWDG
|
/** @defgroup IWDG IWDG
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -62,9 +62,9 @@ typedef struct
|
||||||
IWDG_TypeDef *Instance; /*!< Register base address */
|
IWDG_TypeDef *Instance; /*!< Register base address */
|
||||||
|
|
||||||
IWDG_InitTypeDef Init; /*!< IWDG required parameters */
|
IWDG_InitTypeDef Init; /*!< IWDG required parameters */
|
||||||
|
|
||||||
} IWDG_HandleTypeDef;
|
} IWDG_HandleTypeDef;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -77,22 +77,24 @@ typedef struct
|
||||||
/** @defgroup IWDG_Prescaler IWDG Prescaler
|
/** @defgroup IWDG_Prescaler IWDG Prescaler
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define IWDG_PRESCALER_4 0x00000000U /*!< IWDG prescaler set to 4 */
|
#define IWDG_PRESCALER_4 0x00000000U /*!< IWDG prescaler set to 4 */
|
||||||
#define IWDG_PRESCALER_8 IWDG_PR_PR_0 /*!< IWDG prescaler set to 8 */
|
#define IWDG_PRESCALER_8 IWDG_PR_PR_0 /*!< IWDG prescaler set to 8 */
|
||||||
#define IWDG_PRESCALER_16 IWDG_PR_PR_1 /*!< IWDG prescaler set to 16 */
|
#define IWDG_PRESCALER_16 IWDG_PR_PR_1 /*!< IWDG prescaler set to 16 */
|
||||||
#define IWDG_PRESCALER_32 (IWDG_PR_PR_1 | IWDG_PR_PR_0) /*!< IWDG prescaler set to 32 */
|
#define IWDG_PRESCALER_32 (IWDG_PR_PR_1 | IWDG_PR_PR_0) /*!< IWDG prescaler set to 32 */
|
||||||
#define IWDG_PRESCALER_64 IWDG_PR_PR_2 /*!< IWDG prescaler set to 64 */
|
#define IWDG_PRESCALER_64 IWDG_PR_PR_2 /*!< IWDG prescaler set to 64 */
|
||||||
#define IWDG_PRESCALER_128 (IWDG_PR_PR_2 | IWDG_PR_PR_0) /*!< IWDG prescaler set to 128 */
|
#define IWDG_PRESCALER_128 (IWDG_PR_PR_2 | IWDG_PR_PR_0) /*!< IWDG prescaler set to 128 */
|
||||||
#define IWDG_PRESCALER_256 (IWDG_PR_PR_2 | IWDG_PR_PR_1) /*!< IWDG prescaler set to 256 */
|
#define IWDG_PRESCALER_256 (IWDG_PR_PR_2 | IWDG_PR_PR_1) /*!< IWDG prescaler set to 256 */
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
/* Exported macros -----------------------------------------------------------*/
|
/* Exported macros -----------------------------------------------------------*/
|
||||||
/** @defgroup IWDG_Exported_Macros IWDG Exported Macros
|
/** @defgroup IWDG_Exported_Macros IWDG Exported Macros
|
||||||
* @{
|
* @{
|
||||||
|
@ -107,7 +109,7 @@ typedef struct
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Reload IWDG counter with value defined in the reload register
|
* @brief Reload IWDG counter with value defined in the reload register
|
||||||
* (write access to IWDG_PR & IWDG_RLR registers disabled).
|
* (write access to IWDG_PR and IWDG_RLR registers disabled).
|
||||||
* @param __HANDLE__ IWDG handle
|
* @param __HANDLE__ IWDG handle
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
|
@ -200,6 +202,8 @@ HAL_StatusTypeDef HAL_IWDG_Refresh(IWDG_HandleTypeDef *hiwdg);
|
||||||
*/
|
*/
|
||||||
#define IS_IWDG_RELOAD(__RELOAD__) ((__RELOAD__) <= IWDG_RLR_RL)
|
#define IS_IWDG_RELOAD(__RELOAD__) ((__RELOAD__) <= IWDG_RLR_RL)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -104,22 +104,22 @@ typedef struct __PCD_HandleTypeDef
|
||||||
typedef struct
|
typedef struct
|
||||||
#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */
|
||||||
{
|
{
|
||||||
PCD_TypeDef *Instance; /*!< Register base address */
|
PCD_TypeDef *Instance; /*!< Register base address */
|
||||||
PCD_InitTypeDef Init; /*!< PCD required parameters */
|
PCD_InitTypeDef Init; /*!< PCD required parameters */
|
||||||
__IO uint8_t USB_Address; /*!< USB Address */
|
__IO uint8_t USB_Address; /*!< USB Address */
|
||||||
#if defined (USB_OTG_FS)
|
#if defined (USB_OTG_FS)
|
||||||
PCD_EPTypeDef IN_ep[16]; /*!< IN endpoint parameters */
|
PCD_EPTypeDef IN_ep[16]; /*!< IN endpoint parameters */
|
||||||
PCD_EPTypeDef OUT_ep[16]; /*!< OUT endpoint parameters */
|
PCD_EPTypeDef OUT_ep[16]; /*!< OUT endpoint parameters */
|
||||||
#endif /* defined (USB_OTG_FS) */
|
#endif /* defined (USB_OTG_FS) */
|
||||||
#if defined (USB)
|
#if defined (USB)
|
||||||
PCD_EPTypeDef IN_ep[8]; /*!< IN endpoint parameters */
|
PCD_EPTypeDef IN_ep[8]; /*!< IN endpoint parameters */
|
||||||
PCD_EPTypeDef OUT_ep[8]; /*!< OUT endpoint parameters */
|
PCD_EPTypeDef OUT_ep[8]; /*!< OUT endpoint parameters */
|
||||||
#endif /* defined (USB) */
|
#endif /* defined (USB) */
|
||||||
HAL_LockTypeDef Lock; /*!< PCD peripheral status */
|
HAL_LockTypeDef Lock; /*!< PCD peripheral status */
|
||||||
__IO PCD_StateTypeDef State; /*!< PCD communication state */
|
__IO PCD_StateTypeDef State; /*!< PCD communication state */
|
||||||
__IO uint32_t ErrorCode; /*!< PCD Error code */
|
__IO uint32_t ErrorCode; /*!< PCD Error code */
|
||||||
uint32_t Setup[12]; /*!< Setup packet buffer */
|
uint32_t Setup[12]; /*!< Setup packet buffer */
|
||||||
PCD_LPM_StateTypeDef LPM_State; /*!< LPM State */
|
PCD_LPM_StateTypeDef LPM_State; /*!< LPM State */
|
||||||
uint32_t BESL;
|
uint32_t BESL;
|
||||||
|
|
||||||
void *pData; /*!< Pointer to upper stack Handler */
|
void *pData; /*!< Pointer to upper stack Handler */
|
||||||
|
@ -191,9 +191,9 @@ typedef struct
|
||||||
|
|
||||||
/* Exported macros -----------------------------------------------------------*/
|
/* Exported macros -----------------------------------------------------------*/
|
||||||
/** @defgroup PCD_Exported_Macros PCD Exported Macros
|
/** @defgroup PCD_Exported_Macros PCD Exported Macros
|
||||||
* @brief macros to handle interrupts and specific clock configurations
|
* @brief macros to handle interrupts and specific clock configurations
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#if defined (USB_OTG_FS)
|
#if defined (USB_OTG_FS)
|
||||||
#define __HAL_PCD_ENABLE(__HANDLE__) (void)USB_EnableGlobalInt ((__HANDLE__)->Instance)
|
#define __HAL_PCD_ENABLE(__HANDLE__) (void)USB_EnableGlobalInt ((__HANDLE__)->Instance)
|
||||||
#define __HAL_PCD_DISABLE(__HANDLE__) (void)USB_DisableGlobalInt ((__HANDLE__)->Instance)
|
#define __HAL_PCD_DISABLE(__HANDLE__) (void)USB_DisableGlobalInt ((__HANDLE__)->Instance)
|
||||||
|
@ -203,12 +203,11 @@ typedef struct
|
||||||
#define __HAL_PCD_IS_INVALID_INTERRUPT(__HANDLE__) (USB_ReadInterrupts((__HANDLE__)->Instance) == 0U)
|
#define __HAL_PCD_IS_INVALID_INTERRUPT(__HANDLE__) (USB_ReadInterrupts((__HANDLE__)->Instance) == 0U)
|
||||||
|
|
||||||
|
|
||||||
#define __HAL_PCD_UNGATE_PHYCLOCK(__HANDLE__) *(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE) &= \
|
#define __HAL_PCD_UNGATE_PHYCLOCK(__HANDLE__) *(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE) &= ~(USB_OTG_PCGCCTL_STOPCLK)
|
||||||
~(USB_OTG_PCGCCTL_STOPCLK)
|
|
||||||
|
|
||||||
#define __HAL_PCD_GATE_PHYCLOCK(__HANDLE__) *(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE) |= USB_OTG_PCGCCTL_STOPCLK
|
#define __HAL_PCD_GATE_PHYCLOCK(__HANDLE__) *(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE) |= USB_OTG_PCGCCTL_STOPCLK
|
||||||
|
|
||||||
#define __HAL_PCD_IS_PHY_SUSPENDED(__HANDLE__) ((*(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE)) & 0x10U)
|
#define __HAL_PCD_IS_PHY_SUSPENDED(__HANDLE__) ((*(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE)) & 0x10U)
|
||||||
|
|
||||||
#define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= USB_OTG_FS_WAKEUP_EXTI_LINE
|
#define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= USB_OTG_FS_WAKEUP_EXTI_LINE
|
||||||
#define __HAL_USB_OTG_FS_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE)
|
#define __HAL_USB_OTG_FS_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE)
|
||||||
|
@ -216,28 +215,28 @@ typedef struct
|
||||||
#define __HAL_USB_OTG_FS_WAKEUP_EXTI_CLEAR_FLAG() EXTI->PR = USB_OTG_FS_WAKEUP_EXTI_LINE
|
#define __HAL_USB_OTG_FS_WAKEUP_EXTI_CLEAR_FLAG() EXTI->PR = USB_OTG_FS_WAKEUP_EXTI_LINE
|
||||||
|
|
||||||
#define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_RISING_EDGE() \
|
#define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_RISING_EDGE() \
|
||||||
do { \
|
do { \
|
||||||
EXTI->FTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE); \
|
EXTI->FTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE); \
|
||||||
EXTI->RTSR |= USB_OTG_FS_WAKEUP_EXTI_LINE; \
|
EXTI->RTSR |= USB_OTG_FS_WAKEUP_EXTI_LINE; \
|
||||||
} while(0U)
|
} while(0U)
|
||||||
#endif /* defined (USB_OTG_FS) */
|
#endif /* defined (USB_OTG_FS) */
|
||||||
|
|
||||||
#if defined (USB)
|
#if defined (USB)
|
||||||
#define __HAL_PCD_ENABLE(__HANDLE__) (void)USB_EnableGlobalInt ((__HANDLE__)->Instance)
|
#define __HAL_PCD_ENABLE(__HANDLE__) (void)USB_EnableGlobalInt ((__HANDLE__)->Instance)
|
||||||
#define __HAL_PCD_DISABLE(__HANDLE__) (void)USB_DisableGlobalInt ((__HANDLE__)->Instance)
|
#define __HAL_PCD_DISABLE(__HANDLE__) (void)USB_DisableGlobalInt ((__HANDLE__)->Instance)
|
||||||
#define __HAL_PCD_GET_FLAG(__HANDLE__, __INTERRUPT__) ((USB_ReadInterrupts((__HANDLE__)->Instance) & (__INTERRUPT__)) == (__INTERRUPT__))
|
#define __HAL_PCD_GET_FLAG(__HANDLE__, __INTERRUPT__) ((USB_ReadInterrupts((__HANDLE__)->Instance) & (__INTERRUPT__)) == (__INTERRUPT__))
|
||||||
#define __HAL_PCD_CLEAR_FLAG(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->ISTR) &= ~(__INTERRUPT__))
|
#define __HAL_PCD_CLEAR_FLAG(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->ISTR) &= (uint16_t)(~(__INTERRUPT__)))
|
||||||
|
|
||||||
#define __HAL_USB_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= USB_WAKEUP_EXTI_LINE
|
#define __HAL_USB_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= USB_WAKEUP_EXTI_LINE
|
||||||
#define __HAL_USB_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_WAKEUP_EXTI_LINE)
|
#define __HAL_USB_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_WAKEUP_EXTI_LINE)
|
||||||
#define __HAL_USB_WAKEUP_EXTI_GET_FLAG() EXTI->PR & (USB_WAKEUP_EXTI_LINE)
|
#define __HAL_USB_WAKEUP_EXTI_GET_FLAG() EXTI->PR & (USB_WAKEUP_EXTI_LINE)
|
||||||
#define __HAL_USB_WAKEUP_EXTI_CLEAR_FLAG() EXTI->PR = USB_WAKEUP_EXTI_LINE
|
#define __HAL_USB_WAKEUP_EXTI_CLEAR_FLAG() EXTI->PR = USB_WAKEUP_EXTI_LINE
|
||||||
|
|
||||||
#define __HAL_USB_WAKEUP_EXTI_ENABLE_RISING_EDGE() \
|
#define __HAL_USB_WAKEUP_EXTI_ENABLE_RISING_EDGE() \
|
||||||
do { \
|
do { \
|
||||||
EXTI->FTSR &= ~(USB_WAKEUP_EXTI_LINE); \
|
EXTI->FTSR &= ~(USB_WAKEUP_EXTI_LINE); \
|
||||||
EXTI->RTSR |= USB_WAKEUP_EXTI_LINE; \
|
EXTI->RTSR |= USB_WAKEUP_EXTI_LINE; \
|
||||||
} while(0U)
|
} while(0U)
|
||||||
|
|
||||||
#endif /* defined (USB) */
|
#endif /* defined (USB) */
|
||||||
|
|
||||||
|
@ -272,7 +271,7 @@ typedef enum
|
||||||
HAL_PCD_SUSPEND_CB_ID = 0x04, /*!< USB PCD Suspend callback ID */
|
HAL_PCD_SUSPEND_CB_ID = 0x04, /*!< USB PCD Suspend callback ID */
|
||||||
HAL_PCD_RESUME_CB_ID = 0x05, /*!< USB PCD Resume callback ID */
|
HAL_PCD_RESUME_CB_ID = 0x05, /*!< USB PCD Resume callback ID */
|
||||||
HAL_PCD_CONNECT_CB_ID = 0x06, /*!< USB PCD Connect callback ID */
|
HAL_PCD_CONNECT_CB_ID = 0x06, /*!< USB PCD Connect callback ID */
|
||||||
HAL_PCD_DISCONNECT_CB_ID = 0x07, /*!< USB PCD Disconnect callback ID */
|
HAL_PCD_DISCONNECT_CB_ID = 0x07, /*!< USB PCD Disconnect callback ID */
|
||||||
|
|
||||||
HAL_PCD_MSPINIT_CB_ID = 0x08, /*!< USB PCD MspInit callback ID */
|
HAL_PCD_MSPINIT_CB_ID = 0x08, /*!< USB PCD MspInit callback ID */
|
||||||
HAL_PCD_MSPDEINIT_CB_ID = 0x09 /*!< USB PCD MspDeInit callback ID */
|
HAL_PCD_MSPDEINIT_CB_ID = 0x09 /*!< USB PCD MspDeInit callback ID */
|
||||||
|
@ -297,19 +296,31 @@ typedef void (*pPCD_IsoInIncpltCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_RegisterCallback(PCD_HandleTypeDef *hpcd, HAL_PCD_CallbackIDTypeDef CallbackID, pPCD_CallbackTypeDef pCallback);
|
HAL_StatusTypeDef HAL_PCD_RegisterCallback(PCD_HandleTypeDef *hpcd,
|
||||||
HAL_StatusTypeDef HAL_PCD_UnRegisterCallback(PCD_HandleTypeDef *hpcd, HAL_PCD_CallbackIDTypeDef CallbackID);
|
HAL_PCD_CallbackIDTypeDef CallbackID,
|
||||||
|
pPCD_CallbackTypeDef pCallback);
|
||||||
|
|
||||||
|
HAL_StatusTypeDef HAL_PCD_UnRegisterCallback(PCD_HandleTypeDef *hpcd,
|
||||||
|
HAL_PCD_CallbackIDTypeDef CallbackID);
|
||||||
|
|
||||||
|
HAL_StatusTypeDef HAL_PCD_RegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd,
|
||||||
|
pPCD_DataOutStageCallbackTypeDef pCallback);
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_RegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd, pPCD_DataOutStageCallbackTypeDef pCallback);
|
|
||||||
HAL_StatusTypeDef HAL_PCD_UnRegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_UnRegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd);
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_RegisterDataInStageCallback(PCD_HandleTypeDef *hpcd, pPCD_DataInStageCallbackTypeDef pCallback);
|
HAL_StatusTypeDef HAL_PCD_RegisterDataInStageCallback(PCD_HandleTypeDef *hpcd,
|
||||||
|
pPCD_DataInStageCallbackTypeDef pCallback);
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_UnRegisterDataInStageCallback(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_UnRegisterDataInStageCallback(PCD_HandleTypeDef *hpcd);
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_RegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd, pPCD_IsoOutIncpltCallbackTypeDef pCallback);
|
HAL_StatusTypeDef HAL_PCD_RegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd,
|
||||||
|
pPCD_IsoOutIncpltCallbackTypeDef pCallback);
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_UnRegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_UnRegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd);
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_RegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd, pPCD_IsoInIncpltCallbackTypeDef pCallback);
|
HAL_StatusTypeDef HAL_PCD_RegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd,
|
||||||
|
pPCD_IsoInIncpltCallbackTypeDef pCallback);
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_UnRegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_UnRegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd);
|
||||||
|
|
||||||
#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */
|
||||||
|
@ -325,6 +336,7 @@ HAL_StatusTypeDef HAL_PCD_UnRegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd)
|
||||||
HAL_StatusTypeDef HAL_PCD_Start(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_Start(PCD_HandleTypeDef *hpcd);
|
||||||
HAL_StatusTypeDef HAL_PCD_Stop(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_Stop(PCD_HandleTypeDef *hpcd);
|
||||||
void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd);
|
void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd);
|
||||||
|
void HAL_PCD_WKUP_IRQHandler(PCD_HandleTypeDef *hpcd);
|
||||||
|
|
||||||
void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd);
|
void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd);
|
||||||
void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd);
|
void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd);
|
||||||
|
@ -349,16 +361,24 @@ void HAL_PCD_ISOINIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
|
||||||
HAL_StatusTypeDef HAL_PCD_DevConnect(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_DevConnect(PCD_HandleTypeDef *hpcd);
|
||||||
HAL_StatusTypeDef HAL_PCD_DevDisconnect(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_DevDisconnect(PCD_HandleTypeDef *hpcd);
|
||||||
HAL_StatusTypeDef HAL_PCD_SetAddress(PCD_HandleTypeDef *hpcd, uint8_t address);
|
HAL_StatusTypeDef HAL_PCD_SetAddress(PCD_HandleTypeDef *hpcd, uint8_t address);
|
||||||
HAL_StatusTypeDef HAL_PCD_EP_Open(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint16_t ep_mps, uint8_t ep_type);
|
HAL_StatusTypeDef HAL_PCD_EP_Open(PCD_HandleTypeDef *hpcd, uint8_t ep_addr,
|
||||||
|
uint16_t ep_mps, uint8_t ep_type);
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_EP_Close(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
HAL_StatusTypeDef HAL_PCD_EP_Close(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
||||||
HAL_StatusTypeDef HAL_PCD_EP_Receive(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len);
|
HAL_StatusTypeDef HAL_PCD_EP_Receive(PCD_HandleTypeDef *hpcd, uint8_t ep_addr,
|
||||||
HAL_StatusTypeDef HAL_PCD_EP_Transmit(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len);
|
uint8_t *pBuf, uint32_t len);
|
||||||
uint32_t HAL_PCD_EP_GetRxCount(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
|
||||||
|
HAL_StatusTypeDef HAL_PCD_EP_Transmit(PCD_HandleTypeDef *hpcd, uint8_t ep_addr,
|
||||||
|
uint8_t *pBuf, uint32_t len);
|
||||||
|
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCD_EP_SetStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
HAL_StatusTypeDef HAL_PCD_EP_SetStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
||||||
HAL_StatusTypeDef HAL_PCD_EP_ClrStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
HAL_StatusTypeDef HAL_PCD_EP_ClrStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
||||||
HAL_StatusTypeDef HAL_PCD_EP_Flush(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
HAL_StatusTypeDef HAL_PCD_EP_Flush(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
||||||
HAL_StatusTypeDef HAL_PCD_ActivateRemoteWakeup(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_ActivateRemoteWakeup(PCD_HandleTypeDef *hpcd);
|
||||||
HAL_StatusTypeDef HAL_PCD_DeActivateRemoteWakeup(PCD_HandleTypeDef *hpcd);
|
HAL_StatusTypeDef HAL_PCD_DeActivateRemoteWakeup(PCD_HandleTypeDef *hpcd);
|
||||||
|
|
||||||
|
uint32_t HAL_PCD_EP_GetRxCount(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -384,15 +404,11 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#if defined (USB_OTG_FS)
|
#if defined (USB_OTG_FS)
|
||||||
#define USB_OTG_FS_WAKEUP_EXTI_RISING_EDGE 0x08U
|
|
||||||
#define USB_OTG_FS_WAKEUP_EXTI_FALLING_EDGE 0x0CU
|
|
||||||
#define USB_OTG_FS_WAKEUP_EXTI_RISING_FALLING_EDGE 0x10U
|
|
||||||
|
|
||||||
#define USB_OTG_FS_WAKEUP_EXTI_LINE (0x1U << 18) /*!< USB FS EXTI Line WakeUp Interrupt */
|
#define USB_OTG_FS_WAKEUP_EXTI_LINE (0x1U << 18) /*!< USB FS EXTI Line WakeUp Interrupt */
|
||||||
#endif /* defined (USB_OTG_FS) */
|
#endif /* defined (USB_OTG_FS) */
|
||||||
|
|
||||||
#if defined (USB)
|
#if defined (USB)
|
||||||
#define USB_WAKEUP_EXTI_LINE (0x1U << 18) /*!< USB FS EXTI Line WakeUp Interrupt */
|
#define USB_WAKEUP_EXTI_LINE (0x1U << 18) /*!< USB FS EXTI Line WakeUp Interrupt */
|
||||||
#endif /* defined (USB) */
|
#endif /* defined (USB) */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -402,10 +418,10 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
/** @defgroup PCD_EP0_MPS PCD EP0 MPS
|
/** @defgroup PCD_EP0_MPS PCD EP0 MPS
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define PCD_EP0MPS_64 DEP0CTL_MPS_64
|
#define PCD_EP0MPS_64 EP_MPS_64
|
||||||
#define PCD_EP0MPS_32 DEP0CTL_MPS_32
|
#define PCD_EP0MPS_32 EP_MPS_32
|
||||||
#define PCD_EP0MPS_16 DEP0CTL_MPS_16
|
#define PCD_EP0MPS_16 EP_MPS_16
|
||||||
#define PCD_EP0MPS_08 DEP0CTL_MPS_8
|
#define PCD_EP0MPS_08 EP_MPS_8
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -466,8 +482,8 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
|
|
||||||
/* Private macros ------------------------------------------------------------*/
|
/* Private macros ------------------------------------------------------------*/
|
||||||
/** @defgroup PCD_Private_Macros PCD Private Macros
|
/** @defgroup PCD_Private_Macros PCD Private Macros
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#if defined (USB)
|
#if defined (USB)
|
||||||
/******************** Bit definition for USB_COUNTn_RX register *************/
|
/******************** Bit definition for USB_COUNTn_RX register *************/
|
||||||
#define USB_CNTRX_NBLK_MSK (0x1FU << 10)
|
#define USB_CNTRX_NBLK_MSK (0x1FU << 10)
|
||||||
|
@ -477,10 +493,10 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
#define PCD_SET_ENDPOINT(USBx, bEpNum, wRegValue) (*(__IO uint16_t *)(&(USBx)->EP0R + ((bEpNum) * 2U)) = (uint16_t)(wRegValue))
|
#define PCD_SET_ENDPOINT(USBx, bEpNum, wRegValue) (*(__IO uint16_t *)(&(USBx)->EP0R + ((bEpNum) * 2U)) = (uint16_t)(wRegValue))
|
||||||
|
|
||||||
/* GetENDPOINT */
|
/* GetENDPOINT */
|
||||||
#define PCD_GET_ENDPOINT(USBx, bEpNum) (*(__IO uint16_t *)(&(USBx)->EP0R + ((bEpNum) * 2U)))
|
#define PCD_GET_ENDPOINT(USBx, bEpNum) (*(__IO uint16_t *)(&(USBx)->EP0R + ((bEpNum) * 2U)))
|
||||||
|
|
||||||
/* ENDPOINT transfer */
|
/* ENDPOINT transfer */
|
||||||
#define USB_EP0StartXfer USB_EPStartXfer
|
#define USB_EP0StartXfer USB_EPStartXfer
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief sets the type in the endpoint register(bits EP_TYPE[1:0])
|
* @brief sets the type in the endpoint register(bits EP_TYPE[1:0])
|
||||||
|
@ -489,8 +505,7 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wType Endpoint Type.
|
* @param wType Endpoint Type.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EPTYPE(USBx, bEpNum, wType) (PCD_SET_ENDPOINT((USBx), (bEpNum), \
|
#define PCD_SET_EPTYPE(USBx, bEpNum, wType) (PCD_SET_ENDPOINT((USBx), (bEpNum), ((PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EP_T_MASK) | (wType) | USB_EP_CTR_TX | USB_EP_CTR_RX)))
|
||||||
((PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EP_T_MASK) | (wType) | USB_EP_CTR_TX | USB_EP_CTR_RX)))
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief gets the type in the endpoint register(bits EP_TYPE[1:0])
|
* @brief gets the type in the endpoint register(bits EP_TYPE[1:0])
|
||||||
|
@ -507,18 +522,19 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param bEpNum, bDir
|
* @param bEpNum, bDir
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_FreeUserBuffer(USBx, bEpNum, bDir) do { \
|
#define PCD_FreeUserBuffer(USBx, bEpNum, bDir) \
|
||||||
if ((bDir) == 0U) \
|
do { \
|
||||||
{ \
|
if ((bDir) == 0U) \
|
||||||
/* OUT double buffered endpoint */ \
|
{ \
|
||||||
PCD_TX_DTOG((USBx), (bEpNum)); \
|
/* OUT double buffered endpoint */ \
|
||||||
} \
|
PCD_TX_DTOG((USBx), (bEpNum)); \
|
||||||
else if ((bDir) == 1U) \
|
} \
|
||||||
{ \
|
else if ((bDir) == 1U) \
|
||||||
/* IN double buffered endpoint */ \
|
{ \
|
||||||
PCD_RX_DTOG((USBx), (bEpNum)); \
|
/* IN double buffered endpoint */ \
|
||||||
} \
|
PCD_RX_DTOG((USBx), (bEpNum)); \
|
||||||
} while(0)
|
} \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief sets the status for tx transfer (bits STAT_TX[1:0]).
|
* @brief sets the status for tx transfer (bits STAT_TX[1:0]).
|
||||||
|
@ -527,21 +543,22 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wState new state
|
* @param wState new state
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_TX_STATUS(USBx, bEpNum, wState) do { \
|
#define PCD_SET_EP_TX_STATUS(USBx, bEpNum, wState) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
\
|
uint16_t _wRegVal; \
|
||||||
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPTX_DTOGMASK; \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPTX_DTOGMASK; \
|
||||||
/* toggle first bit ? */ \
|
/* toggle first bit ? */ \
|
||||||
if ((USB_EPTX_DTOG1 & (wState))!= 0U) \
|
if ((USB_EPTX_DTOG1 & (wState))!= 0U) \
|
||||||
{ \
|
{ \
|
||||||
_wRegVal ^= USB_EPTX_DTOG1; \
|
_wRegVal ^= USB_EPTX_DTOG1; \
|
||||||
} \
|
} \
|
||||||
/* toggle second bit ? */ \
|
/* toggle second bit ? */ \
|
||||||
if ((USB_EPTX_DTOG2 & (wState))!= 0U) \
|
if ((USB_EPTX_DTOG2 & (wState))!= 0U) \
|
||||||
{ \
|
{ \
|
||||||
_wRegVal ^= USB_EPTX_DTOG2; \
|
_wRegVal ^= USB_EPTX_DTOG2; \
|
||||||
} \
|
} \
|
||||||
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \
|
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \
|
||||||
} while(0) /* PCD_SET_EP_TX_STATUS */
|
} while(0) /* PCD_SET_EP_TX_STATUS */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -551,19 +568,20 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wState new state
|
* @param wState new state
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_RX_STATUS(USBx, bEpNum,wState) do { \
|
#define PCD_SET_EP_RX_STATUS(USBx, bEpNum,wState) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPRX_DTOGMASK; \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPRX_DTOGMASK; \
|
||||||
/* toggle first bit ? */ \
|
/* toggle first bit ? */ \
|
||||||
if ((USB_EPRX_DTOG1 & (wState))!= 0U) \
|
if ((USB_EPRX_DTOG1 & (wState))!= 0U) \
|
||||||
{ \
|
{ \
|
||||||
_wRegVal ^= USB_EPRX_DTOG1; \
|
_wRegVal ^= USB_EPRX_DTOG1; \
|
||||||
} \
|
} \
|
||||||
/* toggle second bit ? */ \
|
/* toggle second bit ? */ \
|
||||||
if ((USB_EPRX_DTOG2 & (wState))!= 0U) \
|
if ((USB_EPRX_DTOG2 & (wState))!= 0U) \
|
||||||
{ \
|
{ \
|
||||||
_wRegVal ^= USB_EPRX_DTOG2; \
|
_wRegVal ^= USB_EPRX_DTOG2; \
|
||||||
} \
|
} \
|
||||||
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \
|
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \
|
||||||
} while(0) /* PCD_SET_EP_RX_STATUS */
|
} while(0) /* PCD_SET_EP_RX_STATUS */
|
||||||
|
@ -576,8 +594,9 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wStatetx new state.
|
* @param wStatetx new state.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_TXRX_STATUS(USBx, bEpNum, wStaterx, wStatetx) do { \
|
#define PCD_SET_EP_TXRX_STATUS(USBx, bEpNum, wStaterx, wStatetx) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (USB_EPRX_DTOGMASK | USB_EPTX_STAT); \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (USB_EPRX_DTOGMASK | USB_EPTX_STAT); \
|
||||||
/* toggle first bit ? */ \
|
/* toggle first bit ? */ \
|
||||||
|
@ -629,10 +648,8 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param bEpNum Endpoint Number.
|
* @param bEpNum Endpoint Number.
|
||||||
* @retval TRUE = endpoint in stall condition.
|
* @retval TRUE = endpoint in stall condition.
|
||||||
*/
|
*/
|
||||||
#define PCD_GET_EP_TX_STALL_STATUS(USBx, bEpNum) (PCD_GET_EP_TX_STATUS((USBx), (bEpNum)) \
|
#define PCD_GET_EP_TX_STALL_STATUS(USBx, bEpNum) (PCD_GET_EP_TX_STATUS((USBx), (bEpNum)) == USB_EP_TX_STALL)
|
||||||
== USB_EP_TX_STALL)
|
#define PCD_GET_EP_RX_STALL_STATUS(USBx, bEpNum) (PCD_GET_EP_RX_STATUS((USBx), (bEpNum)) == USB_EP_RX_STALL)
|
||||||
#define PCD_GET_EP_RX_STALL_STATUS(USBx, bEpNum) (PCD_GET_EP_RX_STATUS((USBx), (bEpNum)) \
|
|
||||||
== USB_EP_RX_STALL)
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief set & clear EP_KIND bit.
|
* @brief set & clear EP_KIND bit.
|
||||||
|
@ -640,16 +657,18 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param bEpNum Endpoint Number.
|
* @param bEpNum Endpoint Number.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_KIND(USBx, bEpNum) do { \
|
#define PCD_SET_EP_KIND(USBx, bEpNum) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \
|
||||||
\
|
\
|
||||||
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX | USB_EP_KIND)); \
|
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX | USB_EP_KIND)); \
|
||||||
} while(0) /* PCD_SET_EP_KIND */
|
} while(0) /* PCD_SET_EP_KIND */
|
||||||
|
|
||||||
#define PCD_CLEAR_EP_KIND(USBx, bEpNum) do { \
|
#define PCD_CLEAR_EP_KIND(USBx, bEpNum) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPKIND_MASK; \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPKIND_MASK; \
|
||||||
\
|
\
|
||||||
|
@ -680,16 +699,18 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param bEpNum Endpoint Number.
|
* @param bEpNum Endpoint Number.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_CLEAR_RX_EP_CTR(USBx, bEpNum) do { \
|
#define PCD_CLEAR_RX_EP_CTR(USBx, bEpNum) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (0x7FFFU & USB_EPREG_MASK); \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (0x7FFFU & USB_EPREG_MASK); \
|
||||||
\
|
\
|
||||||
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_TX)); \
|
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_TX)); \
|
||||||
} while(0) /* PCD_CLEAR_RX_EP_CTR */
|
} while(0) /* PCD_CLEAR_RX_EP_CTR */
|
||||||
|
|
||||||
#define PCD_CLEAR_TX_EP_CTR(USBx, bEpNum) do { \
|
#define PCD_CLEAR_TX_EP_CTR(USBx, bEpNum) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (0xFF7FU & USB_EPREG_MASK); \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (0xFF7FU & USB_EPREG_MASK); \
|
||||||
\
|
\
|
||||||
|
@ -702,16 +723,18 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param bEpNum Endpoint Number.
|
* @param bEpNum Endpoint Number.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_RX_DTOG(USBx, bEpNum) do { \
|
#define PCD_RX_DTOG(USBx, bEpNum) \
|
||||||
register uint16_t _wEPVal; \
|
do { \
|
||||||
|
uint16_t _wEPVal; \
|
||||||
\
|
\
|
||||||
_wEPVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \
|
_wEPVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \
|
||||||
\
|
\
|
||||||
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wEPVal | USB_EP_CTR_RX | USB_EP_CTR_TX | USB_EP_DTOG_RX)); \
|
PCD_SET_ENDPOINT((USBx), (bEpNum), (_wEPVal | USB_EP_CTR_RX | USB_EP_CTR_TX | USB_EP_DTOG_RX)); \
|
||||||
} while(0) /* PCD_RX_DTOG */
|
} while(0) /* PCD_RX_DTOG */
|
||||||
|
|
||||||
#define PCD_TX_DTOG(USBx, bEpNum) do { \
|
#define PCD_TX_DTOG(USBx, bEpNum) \
|
||||||
register uint16_t _wEPVal; \
|
do { \
|
||||||
|
uint16_t _wEPVal; \
|
||||||
\
|
\
|
||||||
_wEPVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \
|
_wEPVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \
|
||||||
\
|
\
|
||||||
|
@ -723,8 +746,9 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param bEpNum Endpoint Number.
|
* @param bEpNum Endpoint Number.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_CLEAR_RX_DTOG(USBx, bEpNum) do { \
|
#define PCD_CLEAR_RX_DTOG(USBx, bEpNum) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)); \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)); \
|
||||||
\
|
\
|
||||||
|
@ -734,8 +758,9 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
} \
|
} \
|
||||||
} while(0) /* PCD_CLEAR_RX_DTOG */
|
} while(0) /* PCD_CLEAR_RX_DTOG */
|
||||||
|
|
||||||
#define PCD_CLEAR_TX_DTOG(USBx, bEpNum) do { \
|
#define PCD_CLEAR_TX_DTOG(USBx, bEpNum) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)); \
|
_wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)); \
|
||||||
\
|
\
|
||||||
|
@ -752,8 +777,9 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param bAddr Address.
|
* @param bAddr Address.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_ADDRESS(USBx, bEpNum, bAddr) do { \
|
#define PCD_SET_EP_ADDRESS(USBx, bEpNum, bAddr) \
|
||||||
register uint16_t _wRegVal; \
|
do { \
|
||||||
|
uint16_t _wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegVal = (PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK) | (bAddr); \
|
_wRegVal = (PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK) | (bAddr); \
|
||||||
\
|
\
|
||||||
|
@ -778,23 +804,25 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wAddr address to be set (must be word aligned).
|
* @param wAddr address to be set (must be word aligned).
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_TX_ADDRESS(USBx, bEpNum, wAddr) do { \
|
#define PCD_SET_EP_TX_ADDRESS(USBx, bEpNum, wAddr) \
|
||||||
register __IO uint16_t *_wRegVal; \
|
do { \
|
||||||
register uint32_t _wRegBase = (uint32_t)USBx; \
|
__IO uint16_t *_wRegVal; \
|
||||||
\
|
uint32_t _wRegBase = (uint32_t)USBx; \
|
||||||
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
\
|
||||||
_wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + (((uint32_t)(bEpNum) * 8U) * PMA_ACCESS)); \
|
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
||||||
*_wRegVal = ((wAddr) >> 1) << 1; \
|
_wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + (((uint32_t)(bEpNum) * 8U) * PMA_ACCESS)); \
|
||||||
} while(0) /* PCD_SET_EP_TX_ADDRESS */
|
*_wRegVal = ((wAddr) >> 1) << 1; \
|
||||||
|
} while(0) /* PCD_SET_EP_TX_ADDRESS */
|
||||||
|
|
||||||
#define PCD_SET_EP_RX_ADDRESS(USBx, bEpNum, wAddr) do { \
|
#define PCD_SET_EP_RX_ADDRESS(USBx, bEpNum, wAddr) \
|
||||||
register __IO uint16_t *_wRegVal; \
|
do { \
|
||||||
register uint32_t _wRegBase = (uint32_t)USBx; \
|
__IO uint16_t *_wRegVal; \
|
||||||
\
|
uint32_t _wRegBase = (uint32_t)USBx; \
|
||||||
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
\
|
||||||
_wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 4U) * PMA_ACCESS)); \
|
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
||||||
*_wRegVal = ((wAddr) >> 1) << 1; \
|
_wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 4U) * PMA_ACCESS)); \
|
||||||
} while(0) /* PCD_SET_EP_RX_ADDRESS */
|
*_wRegVal = ((wAddr) >> 1) << 1; \
|
||||||
|
} while(0) /* PCD_SET_EP_RX_ADDRESS */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Gets address of the tx/rx buffer.
|
* @brief Gets address of the tx/rx buffer.
|
||||||
|
@ -812,7 +840,8 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wNBlocks no. of Blocks.
|
* @param wNBlocks no. of Blocks.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_CALC_BLK32(pdwReg, wCount, wNBlocks) do { \
|
#define PCD_CALC_BLK32(pdwReg, wCount, wNBlocks) \
|
||||||
|
do { \
|
||||||
(wNBlocks) = (wCount) >> 5; \
|
(wNBlocks) = (wCount) >> 5; \
|
||||||
if (((wCount) & 0x1fU) == 0U) \
|
if (((wCount) & 0x1fU) == 0U) \
|
||||||
{ \
|
{ \
|
||||||
|
@ -821,7 +850,8 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
*(pdwReg) = (uint16_t)(((wNBlocks) << 10) | USB_CNTRX_BLSIZE); \
|
*(pdwReg) = (uint16_t)(((wNBlocks) << 10) | USB_CNTRX_BLSIZE); \
|
||||||
} while(0) /* PCD_CALC_BLK32 */
|
} while(0) /* PCD_CALC_BLK32 */
|
||||||
|
|
||||||
#define PCD_CALC_BLK2(pdwReg, wCount, wNBlocks) do { \
|
#define PCD_CALC_BLK2(pdwReg, wCount, wNBlocks) \
|
||||||
|
do { \
|
||||||
(wNBlocks) = (wCount) >> 1; \
|
(wNBlocks) = (wCount) >> 1; \
|
||||||
if (((wCount) & 0x1U) != 0U) \
|
if (((wCount) & 0x1U) != 0U) \
|
||||||
{ \
|
{ \
|
||||||
|
@ -830,7 +860,8 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
*(pdwReg) = (uint16_t)((wNBlocks) << 10); \
|
*(pdwReg) = (uint16_t)((wNBlocks) << 10); \
|
||||||
} while(0) /* PCD_CALC_BLK2 */
|
} while(0) /* PCD_CALC_BLK2 */
|
||||||
|
|
||||||
#define PCD_SET_EP_CNT_RX_REG(pdwReg, wCount) do { \
|
#define PCD_SET_EP_CNT_RX_REG(pdwReg, wCount) \
|
||||||
|
do { \
|
||||||
uint32_t wNBlocks; \
|
uint32_t wNBlocks; \
|
||||||
if ((wCount) == 0U) \
|
if ((wCount) == 0U) \
|
||||||
{ \
|
{ \
|
||||||
|
@ -847,10 +878,11 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
} \
|
} \
|
||||||
} while(0) /* PCD_SET_EP_CNT_RX_REG */
|
} while(0) /* PCD_SET_EP_CNT_RX_REG */
|
||||||
|
|
||||||
#define PCD_SET_EP_RX_DBUF0_CNT(USBx, bEpNum, wCount) do { \
|
#define PCD_SET_EP_RX_DBUF0_CNT(USBx, bEpNum, wCount) \
|
||||||
register uint32_t _wRegBase = (uint32_t)(USBx); \
|
do { \
|
||||||
register __IO uint16_t *pdwReg; \
|
uint32_t _wRegBase = (uint32_t)(USBx); \
|
||||||
\
|
__IO uint16_t *pdwReg; \
|
||||||
|
\
|
||||||
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
||||||
pdwReg = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 2U) * PMA_ACCESS)); \
|
pdwReg = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 2U) * PMA_ACCESS)); \
|
||||||
PCD_SET_EP_CNT_RX_REG(pdwReg, (wCount)); \
|
PCD_SET_EP_CNT_RX_REG(pdwReg, (wCount)); \
|
||||||
|
@ -863,23 +895,25 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wCount Counter value.
|
* @param wCount Counter value.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_TX_CNT(USBx, bEpNum, wCount) do { \
|
#define PCD_SET_EP_TX_CNT(USBx, bEpNum, wCount) \
|
||||||
register uint32_t _wRegBase = (uint32_t)(USBx); \
|
do { \
|
||||||
register __IO uint16_t *_wRegVal; \
|
uint32_t _wRegBase = (uint32_t)(USBx); \
|
||||||
|
__IO uint16_t *_wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
||||||
_wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 2U) * PMA_ACCESS)); \
|
_wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 2U) * PMA_ACCESS)); \
|
||||||
*_wRegVal = (uint16_t)(wCount); \
|
*_wRegVal = (uint16_t)(wCount); \
|
||||||
} while(0)
|
} while(0)
|
||||||
|
|
||||||
#define PCD_SET_EP_RX_CNT(USBx, bEpNum, wCount) do { \
|
#define PCD_SET_EP_RX_CNT(USBx, bEpNum, wCount) \
|
||||||
register uint32_t _wRegBase = (uint32_t)(USBx); \
|
do { \
|
||||||
register __IO uint16_t *_wRegVal; \
|
uint32_t _wRegBase = (uint32_t)(USBx); \
|
||||||
|
__IO uint16_t *_wRegVal; \
|
||||||
\
|
\
|
||||||
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
_wRegBase += (uint32_t)(USBx)->BTABLE; \
|
||||||
_wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 6U) * PMA_ACCESS)); \
|
_wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 6U) * PMA_ACCESS)); \
|
||||||
PCD_SET_EP_CNT_RX_REG(_wRegVal, (wCount)); \
|
PCD_SET_EP_CNT_RX_REG(_wRegVal, (wCount)); \
|
||||||
} while(0)
|
} while(0)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief gets counter of the tx buffer.
|
* @brief gets counter of the tx buffer.
|
||||||
|
@ -897,10 +931,13 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wBuf0Addr buffer 0 address.
|
* @param wBuf0Addr buffer 0 address.
|
||||||
* @retval Counter value
|
* @retval Counter value
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_DBUF0_ADDR(USBx, bEpNum, wBuf0Addr) do { \
|
#define PCD_SET_EP_DBUF0_ADDR(USBx, bEpNum, wBuf0Addr) \
|
||||||
|
do { \
|
||||||
PCD_SET_EP_TX_ADDRESS((USBx), (bEpNum), (wBuf0Addr)); \
|
PCD_SET_EP_TX_ADDRESS((USBx), (bEpNum), (wBuf0Addr)); \
|
||||||
} while(0) /* PCD_SET_EP_DBUF0_ADDR */
|
} while(0) /* PCD_SET_EP_DBUF0_ADDR */
|
||||||
#define PCD_SET_EP_DBUF1_ADDR(USBx, bEpNum, wBuf1Addr) do { \
|
|
||||||
|
#define PCD_SET_EP_DBUF1_ADDR(USBx, bEpNum, wBuf1Addr) \
|
||||||
|
do { \
|
||||||
PCD_SET_EP_RX_ADDRESS((USBx), (bEpNum), (wBuf1Addr)); \
|
PCD_SET_EP_RX_ADDRESS((USBx), (bEpNum), (wBuf1Addr)); \
|
||||||
} while(0) /* PCD_SET_EP_DBUF1_ADDR */
|
} while(0) /* PCD_SET_EP_DBUF1_ADDR */
|
||||||
|
|
||||||
|
@ -912,7 +949,8 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wBuf1Addr = buffer 1 address.
|
* @param wBuf1Addr = buffer 1 address.
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_DBUF_ADDR(USBx, bEpNum, wBuf0Addr, wBuf1Addr) do { \
|
#define PCD_SET_EP_DBUF_ADDR(USBx, bEpNum, wBuf0Addr, wBuf1Addr) \
|
||||||
|
do { \
|
||||||
PCD_SET_EP_DBUF0_ADDR((USBx), (bEpNum), (wBuf0Addr)); \
|
PCD_SET_EP_DBUF0_ADDR((USBx), (bEpNum), (wBuf0Addr)); \
|
||||||
PCD_SET_EP_DBUF1_ADDR((USBx), (bEpNum), (wBuf1Addr)); \
|
PCD_SET_EP_DBUF1_ADDR((USBx), (bEpNum), (wBuf1Addr)); \
|
||||||
} while(0) /* PCD_SET_EP_DBUF_ADDR */
|
} while(0) /* PCD_SET_EP_DBUF_ADDR */
|
||||||
|
@ -935,7 +973,8 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
* @param wCount: Counter value
|
* @param wCount: Counter value
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#define PCD_SET_EP_DBUF0_CNT(USBx, bEpNum, bDir, wCount) do { \
|
#define PCD_SET_EP_DBUF0_CNT(USBx, bEpNum, bDir, wCount) \
|
||||||
|
do { \
|
||||||
if ((bDir) == 0U) \
|
if ((bDir) == 0U) \
|
||||||
/* OUT endpoint */ \
|
/* OUT endpoint */ \
|
||||||
{ \
|
{ \
|
||||||
|
@ -951,8 +990,9 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
} \
|
} \
|
||||||
} while(0) /* SetEPDblBuf0Count*/
|
} while(0) /* SetEPDblBuf0Count*/
|
||||||
|
|
||||||
#define PCD_SET_EP_DBUF1_CNT(USBx, bEpNum, bDir, wCount) do { \
|
#define PCD_SET_EP_DBUF1_CNT(USBx, bEpNum, bDir, wCount) \
|
||||||
register uint32_t _wBase = (uint32_t)(USBx); \
|
do { \
|
||||||
|
uint32_t _wBase = (uint32_t)(USBx); \
|
||||||
__IO uint16_t *_wEPRegVal; \
|
__IO uint16_t *_wEPRegVal; \
|
||||||
\
|
\
|
||||||
if ((bDir) == 0U) \
|
if ((bDir) == 0U) \
|
||||||
|
@ -972,10 +1012,11 @@ PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
|
||||||
} \
|
} \
|
||||||
} while(0) /* SetEPDblBuf1Count */
|
} while(0) /* SetEPDblBuf1Count */
|
||||||
|
|
||||||
#define PCD_SET_EP_DBUF_CNT(USBx, bEpNum, bDir, wCount) do { \
|
#define PCD_SET_EP_DBUF_CNT(USBx, bEpNum, bDir, wCount) \
|
||||||
|
do { \
|
||||||
PCD_SET_EP_DBUF0_CNT((USBx), (bEpNum), (bDir), (wCount)); \
|
PCD_SET_EP_DBUF0_CNT((USBx), (bEpNum), (bDir), (wCount)); \
|
||||||
PCD_SET_EP_DBUF1_CNT((USBx), (bEpNum), (bDir), (wCount)); \
|
PCD_SET_EP_DBUF1_CNT((USBx), (bEpNum), (bDir), (wCount)); \
|
||||||
} while(0) /* PCD_SET_EP_DBUF_CNT */
|
} while(0) /* PCD_SET_EP_DBUF_CNT */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Gets buffer 0/1 rx/tx counter for double buffering.
|
* @brief Gets buffer 0/1 rx/tx counter for double buffering.
|
||||||
|
|
|
@ -53,10 +53,8 @@ HAL_StatusTypeDef HAL_PCDEx_SetRxFiFo(PCD_HandleTypeDef *hpcd, uint16_t size);
|
||||||
#endif /* defined (USB_OTG_FS) */
|
#endif /* defined (USB_OTG_FS) */
|
||||||
|
|
||||||
#if defined (USB)
|
#if defined (USB)
|
||||||
HAL_StatusTypeDef HAL_PCDEx_PMAConfig(PCD_HandleTypeDef *hpcd,
|
HAL_StatusTypeDef HAL_PCDEx_PMAConfig(PCD_HandleTypeDef *hpcd, uint16_t ep_addr,
|
||||||
uint16_t ep_addr,
|
uint16_t ep_kind, uint32_t pmaadress);
|
||||||
uint16_t ep_kind,
|
|
||||||
uint32_t pmaadress);
|
|
||||||
|
|
||||||
void HAL_PCDEx_SetConnectionState(PCD_HandleTypeDef *hpcd, uint8_t state);
|
void HAL_PCDEx_SetConnectionState(PCD_HandleTypeDef *hpcd, uint8_t state);
|
||||||
#endif /* defined (USB) */
|
#endif /* defined (USB) */
|
||||||
|
|
|
@ -330,11 +330,11 @@ typedef struct
|
||||||
*/
|
*/
|
||||||
#define RCC_PERIPHCLK_RTC 0x00000001U
|
#define RCC_PERIPHCLK_RTC 0x00000001U
|
||||||
#define RCC_PERIPHCLK_ADC 0x00000002U
|
#define RCC_PERIPHCLK_ADC 0x00000002U
|
||||||
#if defined(STM32F103xE) || defined(STM32F103xG) || defined(STM32F105xC)\
|
#if defined(STM32F101xE) || defined(STM32F101xG) || defined(STM32F103xE)\
|
||||||
|| defined(STM32F107xC)
|
|| defined(STM32F103xG) || defined(STM32F105xC) || defined(STM32F107xC)
|
||||||
#define RCC_PERIPHCLK_I2S2 0x00000004U
|
#define RCC_PERIPHCLK_I2S2 0x00000004U
|
||||||
#define RCC_PERIPHCLK_I2S3 0x00000008U
|
#define RCC_PERIPHCLK_I2S3 0x00000008U
|
||||||
#endif /* STM32F103xE || STM32F103xG || STM32F105xC || STM32F107xC */
|
#endif /* STM32F101xE || STM32F101xG || STM32F103xE || STM32F103xG || STM32F105xC || STM32F107xC */
|
||||||
#if defined(STM32F102x6) || defined(STM32F102xB) || defined(STM32F103x6)\
|
#if defined(STM32F102x6) || defined(STM32F102xB) || defined(STM32F103x6)\
|
||||||
|| defined(STM32F103xB) || defined(STM32F103xE) || defined(STM32F103xG)\
|
|| defined(STM32F103xB) || defined(STM32F103xE) || defined(STM32F103xG)\
|
||||||
|| defined(STM32F105xC) || defined(STM32F107xC)
|
|| defined(STM32F105xC) || defined(STM32F107xC)
|
||||||
|
|
|
@ -167,7 +167,7 @@ typedef struct
|
||||||
This parameter can be a value of @ref TIM_Encoder_Mode */
|
This parameter can be a value of @ref TIM_Encoder_Mode */
|
||||||
|
|
||||||
uint32_t IC1Polarity; /*!< Specifies the active edge of the input signal.
|
uint32_t IC1Polarity; /*!< Specifies the active edge of the input signal.
|
||||||
This parameter can be a value of @ref TIM_Input_Capture_Polarity */
|
This parameter can be a value of @ref TIM_Encoder_Input_Polarity */
|
||||||
|
|
||||||
uint32_t IC1Selection; /*!< Specifies the input.
|
uint32_t IC1Selection; /*!< Specifies the input.
|
||||||
This parameter can be a value of @ref TIM_Input_Capture_Selection */
|
This parameter can be a value of @ref TIM_Input_Capture_Selection */
|
||||||
|
@ -179,7 +179,7 @@ typedef struct
|
||||||
This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */
|
This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */
|
||||||
|
|
||||||
uint32_t IC2Polarity; /*!< Specifies the active edge of the input signal.
|
uint32_t IC2Polarity; /*!< Specifies the active edge of the input signal.
|
||||||
This parameter can be a value of @ref TIM_Input_Capture_Polarity */
|
This parameter can be a value of @ref TIM_Encoder_Input_Polarity */
|
||||||
|
|
||||||
uint32_t IC2Selection; /*!< Specifies the input.
|
uint32_t IC2Selection; /*!< Specifies the input.
|
||||||
This parameter can be a value of @ref TIM_Input_Capture_Selection */
|
This parameter can be a value of @ref TIM_Input_Capture_Selection */
|
||||||
|
@ -294,6 +294,26 @@ typedef enum
|
||||||
HAL_TIM_STATE_ERROR = 0x04U /*!< Reception process is ongoing */
|
HAL_TIM_STATE_ERROR = 0x04U /*!< Reception process is ongoing */
|
||||||
} HAL_TIM_StateTypeDef;
|
} HAL_TIM_StateTypeDef;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief TIM Channel States definition
|
||||||
|
*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
HAL_TIM_CHANNEL_STATE_RESET = 0x00U, /*!< TIM Channel initial state */
|
||||||
|
HAL_TIM_CHANNEL_STATE_READY = 0x01U, /*!< TIM Channel ready for use */
|
||||||
|
HAL_TIM_CHANNEL_STATE_BUSY = 0x02U, /*!< An internal process is ongoing on the TIM channel */
|
||||||
|
} HAL_TIM_ChannelStateTypeDef;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DMA Burst States definition
|
||||||
|
*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
HAL_DMA_BURST_STATE_RESET = 0x00U, /*!< DMA Burst initial state */
|
||||||
|
HAL_DMA_BURST_STATE_READY = 0x01U, /*!< DMA Burst ready for use */
|
||||||
|
HAL_DMA_BURST_STATE_BUSY = 0x02U, /*!< Ongoing DMA Burst */
|
||||||
|
} HAL_TIM_DMABurstStateTypeDef;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief HAL Active channel structures definition
|
* @brief HAL Active channel structures definition
|
||||||
*/
|
*/
|
||||||
|
@ -315,13 +335,16 @@ typedef struct __TIM_HandleTypeDef
|
||||||
typedef struct
|
typedef struct
|
||||||
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
||||||
{
|
{
|
||||||
TIM_TypeDef *Instance; /*!< Register base address */
|
TIM_TypeDef *Instance; /*!< Register base address */
|
||||||
TIM_Base_InitTypeDef Init; /*!< TIM Time Base required parameters */
|
TIM_Base_InitTypeDef Init; /*!< TIM Time Base required parameters */
|
||||||
HAL_TIM_ActiveChannel Channel; /*!< Active channel */
|
HAL_TIM_ActiveChannel Channel; /*!< Active channel */
|
||||||
DMA_HandleTypeDef *hdma[7]; /*!< DMA Handlers array
|
DMA_HandleTypeDef *hdma[7]; /*!< DMA Handlers array
|
||||||
This array is accessed by a @ref DMA_Handle_index */
|
This array is accessed by a @ref DMA_Handle_index */
|
||||||
HAL_LockTypeDef Lock; /*!< Locking object */
|
HAL_LockTypeDef Lock; /*!< Locking object */
|
||||||
__IO HAL_TIM_StateTypeDef State; /*!< TIM operation state */
|
__IO HAL_TIM_StateTypeDef State; /*!< TIM operation state */
|
||||||
|
__IO HAL_TIM_ChannelStateTypeDef ChannelState[4]; /*!< TIM channel operation state */
|
||||||
|
__IO HAL_TIM_ChannelStateTypeDef ChannelNState[4]; /*!< TIM complementary channel operation state */
|
||||||
|
__IO HAL_TIM_DMABurstStateTypeDef DMABurstState; /*!< DMA burst operation state */
|
||||||
|
|
||||||
#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1)
|
#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1)
|
||||||
void (* Base_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Base Msp Init Callback */
|
void (* Base_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Base Msp Init Callback */
|
||||||
|
@ -360,34 +383,34 @@ typedef struct
|
||||||
*/
|
*/
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
HAL_TIM_BASE_MSPINIT_CB_ID = 0x00U /*!< TIM Base MspInit Callback ID */
|
HAL_TIM_BASE_MSPINIT_CB_ID = 0x00U /*!< TIM Base MspInit Callback ID */
|
||||||
,HAL_TIM_BASE_MSPDEINIT_CB_ID = 0x01U /*!< TIM Base MspDeInit Callback ID */
|
, HAL_TIM_BASE_MSPDEINIT_CB_ID = 0x01U /*!< TIM Base MspDeInit Callback ID */
|
||||||
,HAL_TIM_IC_MSPINIT_CB_ID = 0x02U /*!< TIM IC MspInit Callback ID */
|
, HAL_TIM_IC_MSPINIT_CB_ID = 0x02U /*!< TIM IC MspInit Callback ID */
|
||||||
,HAL_TIM_IC_MSPDEINIT_CB_ID = 0x03U /*!< TIM IC MspDeInit Callback ID */
|
, HAL_TIM_IC_MSPDEINIT_CB_ID = 0x03U /*!< TIM IC MspDeInit Callback ID */
|
||||||
,HAL_TIM_OC_MSPINIT_CB_ID = 0x04U /*!< TIM OC MspInit Callback ID */
|
, HAL_TIM_OC_MSPINIT_CB_ID = 0x04U /*!< TIM OC MspInit Callback ID */
|
||||||
,HAL_TIM_OC_MSPDEINIT_CB_ID = 0x05U /*!< TIM OC MspDeInit Callback ID */
|
, HAL_TIM_OC_MSPDEINIT_CB_ID = 0x05U /*!< TIM OC MspDeInit Callback ID */
|
||||||
,HAL_TIM_PWM_MSPINIT_CB_ID = 0x06U /*!< TIM PWM MspInit Callback ID */
|
, HAL_TIM_PWM_MSPINIT_CB_ID = 0x06U /*!< TIM PWM MspInit Callback ID */
|
||||||
,HAL_TIM_PWM_MSPDEINIT_CB_ID = 0x07U /*!< TIM PWM MspDeInit Callback ID */
|
, HAL_TIM_PWM_MSPDEINIT_CB_ID = 0x07U /*!< TIM PWM MspDeInit Callback ID */
|
||||||
,HAL_TIM_ONE_PULSE_MSPINIT_CB_ID = 0x08U /*!< TIM One Pulse MspInit Callback ID */
|
, HAL_TIM_ONE_PULSE_MSPINIT_CB_ID = 0x08U /*!< TIM One Pulse MspInit Callback ID */
|
||||||
,HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID = 0x09U /*!< TIM One Pulse MspDeInit Callback ID */
|
, HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID = 0x09U /*!< TIM One Pulse MspDeInit Callback ID */
|
||||||
,HAL_TIM_ENCODER_MSPINIT_CB_ID = 0x0AU /*!< TIM Encoder MspInit Callback ID */
|
, HAL_TIM_ENCODER_MSPINIT_CB_ID = 0x0AU /*!< TIM Encoder MspInit Callback ID */
|
||||||
,HAL_TIM_ENCODER_MSPDEINIT_CB_ID = 0x0BU /*!< TIM Encoder MspDeInit Callback ID */
|
, HAL_TIM_ENCODER_MSPDEINIT_CB_ID = 0x0BU /*!< TIM Encoder MspDeInit Callback ID */
|
||||||
,HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID = 0x0CU /*!< TIM Hall Sensor MspDeInit Callback ID */
|
, HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID = 0x0CU /*!< TIM Hall Sensor MspDeInit Callback ID */
|
||||||
,HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID = 0x0DU /*!< TIM Hall Sensor MspDeInit Callback ID */
|
, HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID = 0x0DU /*!< TIM Hall Sensor MspDeInit Callback ID */
|
||||||
,HAL_TIM_PERIOD_ELAPSED_CB_ID = 0x0EU /*!< TIM Period Elapsed Callback ID */
|
, HAL_TIM_PERIOD_ELAPSED_CB_ID = 0x0EU /*!< TIM Period Elapsed Callback ID */
|
||||||
,HAL_TIM_PERIOD_ELAPSED_HALF_CB_ID = 0x0FU /*!< TIM Period Elapsed half complete Callback ID */
|
, HAL_TIM_PERIOD_ELAPSED_HALF_CB_ID = 0x0FU /*!< TIM Period Elapsed half complete Callback ID */
|
||||||
,HAL_TIM_TRIGGER_CB_ID = 0x10U /*!< TIM Trigger Callback ID */
|
, HAL_TIM_TRIGGER_CB_ID = 0x10U /*!< TIM Trigger Callback ID */
|
||||||
,HAL_TIM_TRIGGER_HALF_CB_ID = 0x11U /*!< TIM Trigger half complete Callback ID */
|
, HAL_TIM_TRIGGER_HALF_CB_ID = 0x11U /*!< TIM Trigger half complete Callback ID */
|
||||||
|
|
||||||
,HAL_TIM_IC_CAPTURE_CB_ID = 0x12U /*!< TIM Input Capture Callback ID */
|
, HAL_TIM_IC_CAPTURE_CB_ID = 0x12U /*!< TIM Input Capture Callback ID */
|
||||||
,HAL_TIM_IC_CAPTURE_HALF_CB_ID = 0x13U /*!< TIM Input Capture half complete Callback ID */
|
, HAL_TIM_IC_CAPTURE_HALF_CB_ID = 0x13U /*!< TIM Input Capture half complete Callback ID */
|
||||||
,HAL_TIM_OC_DELAY_ELAPSED_CB_ID = 0x14U /*!< TIM Output Compare Delay Elapsed Callback ID */
|
, HAL_TIM_OC_DELAY_ELAPSED_CB_ID = 0x14U /*!< TIM Output Compare Delay Elapsed Callback ID */
|
||||||
,HAL_TIM_PWM_PULSE_FINISHED_CB_ID = 0x15U /*!< TIM PWM Pulse Finished Callback ID */
|
, HAL_TIM_PWM_PULSE_FINISHED_CB_ID = 0x15U /*!< TIM PWM Pulse Finished Callback ID */
|
||||||
,HAL_TIM_PWM_PULSE_FINISHED_HALF_CB_ID = 0x16U /*!< TIM PWM Pulse Finished half complete Callback ID */
|
, HAL_TIM_PWM_PULSE_FINISHED_HALF_CB_ID = 0x16U /*!< TIM PWM Pulse Finished half complete Callback ID */
|
||||||
,HAL_TIM_ERROR_CB_ID = 0x17U /*!< TIM Error Callback ID */
|
, HAL_TIM_ERROR_CB_ID = 0x17U /*!< TIM Error Callback ID */
|
||||||
,HAL_TIM_COMMUTATION_CB_ID = 0x18U /*!< TIM Commutation Callback ID */
|
, HAL_TIM_COMMUTATION_CB_ID = 0x18U /*!< TIM Commutation Callback ID */
|
||||||
,HAL_TIM_COMMUTATION_HALF_CB_ID = 0x19U /*!< TIM Commutation half complete Callback ID */
|
, HAL_TIM_COMMUTATION_HALF_CB_ID = 0x19U /*!< TIM Commutation half complete Callback ID */
|
||||||
,HAL_TIM_BREAK_CB_ID = 0x1AU /*!< TIM Break Callback ID */
|
, HAL_TIM_BREAK_CB_ID = 0x1AU /*!< TIM Break Callback ID */
|
||||||
} HAL_TIM_CallbackIDTypeDef;
|
} HAL_TIM_CallbackIDTypeDef;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -593,6 +616,15 @@ typedef void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim); /*!< pointer to
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/** @defgroup TIM_Encoder_Input_Polarity TIM Encoder Input Polarity
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define TIM_ENCODERINPUTPOLARITY_RISING TIM_INPUTCHANNELPOLARITY_RISING /*!< Encoder input with rising edge polarity */
|
||||||
|
#define TIM_ENCODERINPUTPOLARITY_FALLING TIM_INPUTCHANNELPOLARITY_FALLING /*!< Encoder input with falling edge polarity */
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
/** @defgroup TIM_Input_Capture_Selection TIM Input Capture Selection
|
/** @defgroup TIM_Input_Capture_Selection TIM Input Capture Selection
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
@ -814,7 +846,7 @@ typedef void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim); /*!< pointer to
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define TIM_AUTOMATICOUTPUT_DISABLE 0x00000000U /*!< MOE can be set only by software */
|
#define TIM_AUTOMATICOUTPUT_DISABLE 0x00000000U /*!< MOE can be set only by software */
|
||||||
#define TIM_AUTOMATICOUTPUT_ENABLE TIM_BDTR_AOE /*!< MOE can be set by software or automatically at the next update event
|
#define TIM_AUTOMATICOUTPUT_ENABLE TIM_BDTR_AOE /*!< MOE can be set by software or automatically at the next update event
|
||||||
(if none of the break inputs BRK and BRK2 is active) */
|
(if none of the break inputs BRK and BRK2 is active) */
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
|
@ -984,25 +1016,45 @@ typedef void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim); /*!< pointer to
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1)
|
#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1)
|
||||||
#define __HAL_TIM_RESET_HANDLE_STATE(__HANDLE__) do { \
|
#define __HAL_TIM_RESET_HANDLE_STATE(__HANDLE__) do { \
|
||||||
(__HANDLE__)->State = HAL_TIM_STATE_RESET; \
|
(__HANDLE__)->State = HAL_TIM_STATE_RESET; \
|
||||||
(__HANDLE__)->Base_MspInitCallback = NULL; \
|
(__HANDLE__)->ChannelState[0] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
(__HANDLE__)->Base_MspDeInitCallback = NULL; \
|
(__HANDLE__)->ChannelState[1] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
(__HANDLE__)->IC_MspInitCallback = NULL; \
|
(__HANDLE__)->ChannelState[2] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
(__HANDLE__)->IC_MspDeInitCallback = NULL; \
|
(__HANDLE__)->ChannelState[3] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
(__HANDLE__)->OC_MspInitCallback = NULL; \
|
(__HANDLE__)->ChannelNState[0] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
(__HANDLE__)->OC_MspDeInitCallback = NULL; \
|
(__HANDLE__)->ChannelNState[1] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
(__HANDLE__)->PWM_MspInitCallback = NULL; \
|
(__HANDLE__)->ChannelNState[2] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
(__HANDLE__)->PWM_MspDeInitCallback = NULL; \
|
(__HANDLE__)->ChannelNState[3] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
(__HANDLE__)->OnePulse_MspInitCallback = NULL; \
|
(__HANDLE__)->DMABurstState = HAL_DMA_BURST_STATE_RESET; \
|
||||||
(__HANDLE__)->OnePulse_MspDeInitCallback = NULL; \
|
(__HANDLE__)->Base_MspInitCallback = NULL; \
|
||||||
(__HANDLE__)->Encoder_MspInitCallback = NULL; \
|
(__HANDLE__)->Base_MspDeInitCallback = NULL; \
|
||||||
(__HANDLE__)->Encoder_MspDeInitCallback = NULL; \
|
(__HANDLE__)->IC_MspInitCallback = NULL; \
|
||||||
(__HANDLE__)->HallSensor_MspInitCallback = NULL; \
|
(__HANDLE__)->IC_MspDeInitCallback = NULL; \
|
||||||
(__HANDLE__)->HallSensor_MspDeInitCallback = NULL; \
|
(__HANDLE__)->OC_MspInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->OC_MspDeInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->PWM_MspInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->PWM_MspDeInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->OnePulse_MspInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->OnePulse_MspDeInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->Encoder_MspInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->Encoder_MspDeInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->HallSensor_MspInitCallback = NULL; \
|
||||||
|
(__HANDLE__)->HallSensor_MspDeInitCallback = NULL; \
|
||||||
} while(0)
|
} while(0)
|
||||||
#else
|
#else
|
||||||
#define __HAL_TIM_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_TIM_STATE_RESET)
|
#define __HAL_TIM_RESET_HANDLE_STATE(__HANDLE__) do { \
|
||||||
|
(__HANDLE__)->State = HAL_TIM_STATE_RESET; \
|
||||||
|
(__HANDLE__)->ChannelState[0] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
|
(__HANDLE__)->ChannelState[1] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
|
(__HANDLE__)->ChannelState[2] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
|
(__HANDLE__)->ChannelState[3] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
|
(__HANDLE__)->ChannelNState[0] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
|
(__HANDLE__)->ChannelNState[1] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
|
(__HANDLE__)->ChannelNState[2] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
|
(__HANDLE__)->ChannelNState[3] = HAL_TIM_CHANNEL_STATE_RESET; \
|
||||||
|
(__HANDLE__)->DMABurstState = HAL_DMA_BURST_STATE_RESET; \
|
||||||
|
} while(0)
|
||||||
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1547,6 +1599,9 @@ mode.
|
||||||
#define IS_TIM_OCNIDLE_STATE(__STATE__) (((__STATE__) == TIM_OCNIDLESTATE_SET) || \
|
#define IS_TIM_OCNIDLE_STATE(__STATE__) (((__STATE__) == TIM_OCNIDLESTATE_SET) || \
|
||||||
((__STATE__) == TIM_OCNIDLESTATE_RESET))
|
((__STATE__) == TIM_OCNIDLESTATE_RESET))
|
||||||
|
|
||||||
|
#define IS_TIM_ENCODERINPUT_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_ENCODERINPUTPOLARITY_RISING) || \
|
||||||
|
((__POLARITY__) == TIM_ENCODERINPUTPOLARITY_FALLING))
|
||||||
|
|
||||||
#define IS_TIM_IC_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_ICPOLARITY_RISING) || \
|
#define IS_TIM_IC_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_ICPOLARITY_RISING) || \
|
||||||
((__POLARITY__) == TIM_ICPOLARITY_FALLING) || \
|
((__POLARITY__) == TIM_ICPOLARITY_FALLING) || \
|
||||||
((__POLARITY__) == TIM_ICPOLARITY_BOTHEDGE))
|
((__POLARITY__) == TIM_ICPOLARITY_BOTHEDGE))
|
||||||
|
@ -1698,15 +1753,15 @@ mode.
|
||||||
#define IS_TIM_TI1SELECTION(__TI1SELECTION__) (((__TI1SELECTION__) == TIM_TI1SELECTION_CH1) || \
|
#define IS_TIM_TI1SELECTION(__TI1SELECTION__) (((__TI1SELECTION__) == TIM_TI1SELECTION_CH1) || \
|
||||||
((__TI1SELECTION__) == TIM_TI1SELECTION_XORCOMBINATION))
|
((__TI1SELECTION__) == TIM_TI1SELECTION_XORCOMBINATION))
|
||||||
|
|
||||||
#define IS_TIM_DMA_LENGTH(__LENGTH__) (((__LENGTH__) == TIM_DMABURSTLENGTH_1TRANSFER) || \
|
#define IS_TIM_DMA_LENGTH(__LENGTH__) (((__LENGTH__) == TIM_DMABURSTLENGTH_1TRANSFER) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_2TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_2TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_3TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_3TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_4TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_4TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_5TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_5TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_6TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_6TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_7TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_7TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_8TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_8TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_9TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_9TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_10TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_10TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_11TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_11TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_12TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_12TRANSFERS) || \
|
||||||
|
@ -1717,6 +1772,8 @@ mode.
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_17TRANSFERS) || \
|
((__LENGTH__) == TIM_DMABURSTLENGTH_17TRANSFERS) || \
|
||||||
((__LENGTH__) == TIM_DMABURSTLENGTH_18TRANSFERS))
|
((__LENGTH__) == TIM_DMABURSTLENGTH_18TRANSFERS))
|
||||||
|
|
||||||
|
#define IS_TIM_DMA_DATA_LENGTH(LENGTH) (((LENGTH) >= 0x1U) && ((LENGTH) < 0x10000U))
|
||||||
|
|
||||||
#define IS_TIM_IC_FILTER(__ICFILTER__) ((__ICFILTER__) <= 0xFU)
|
#define IS_TIM_IC_FILTER(__ICFILTER__) ((__ICFILTER__) <= 0xFU)
|
||||||
|
|
||||||
#define IS_TIM_DEADTIME(__DEADTIME__) ((__DEADTIME__) <= 0xFFU)
|
#define IS_TIM_DEADTIME(__DEADTIME__) ((__DEADTIME__) <= 0xFFU)
|
||||||
|
@ -1742,11 +1799,49 @@ mode.
|
||||||
((__HANDLE__)->Instance->CCER |= (((__POLARITY__) << 12U))))
|
((__HANDLE__)->Instance->CCER |= (((__POLARITY__) << 12U))))
|
||||||
|
|
||||||
#define TIM_RESET_CAPTUREPOLARITY(__HANDLE__, __CHANNEL__) \
|
#define TIM_RESET_CAPTUREPOLARITY(__HANDLE__, __CHANNEL__) \
|
||||||
(((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC1P | TIM_CCER_CC1NP))) :\
|
(((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC1P | TIM_CCER_CC1NP)) :\
|
||||||
((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC2P | TIM_CCER_CC2NP)) :\
|
((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC2P | TIM_CCER_CC2NP)) :\
|
||||||
((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC3P)) :\
|
((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC3P)) :\
|
||||||
((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC4P)))
|
((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC4P)))
|
||||||
|
|
||||||
|
#define TIM_CHANNEL_STATE_GET(__HANDLE__, __CHANNEL__)\
|
||||||
|
(((__CHANNEL__) == TIM_CHANNEL_1) ? (__HANDLE__)->ChannelState[0] :\
|
||||||
|
((__CHANNEL__) == TIM_CHANNEL_2) ? (__HANDLE__)->ChannelState[1] :\
|
||||||
|
((__CHANNEL__) == TIM_CHANNEL_3) ? (__HANDLE__)->ChannelState[2] :\
|
||||||
|
(__HANDLE__)->ChannelState[3])
|
||||||
|
|
||||||
|
#define TIM_CHANNEL_STATE_SET(__HANDLE__, __CHANNEL__, __CHANNEL_STATE__) \
|
||||||
|
(((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->ChannelState[0] = (__CHANNEL_STATE__)) :\
|
||||||
|
((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->ChannelState[1] = (__CHANNEL_STATE__)) :\
|
||||||
|
((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->ChannelState[2] = (__CHANNEL_STATE__)) :\
|
||||||
|
((__HANDLE__)->ChannelState[3] = (__CHANNEL_STATE__)))
|
||||||
|
|
||||||
|
#define TIM_CHANNEL_STATE_SET_ALL(__HANDLE__, __CHANNEL_STATE__) do { \
|
||||||
|
(__HANDLE__)->ChannelState[0] = (__CHANNEL_STATE__); \
|
||||||
|
(__HANDLE__)->ChannelState[1] = (__CHANNEL_STATE__); \
|
||||||
|
(__HANDLE__)->ChannelState[2] = (__CHANNEL_STATE__); \
|
||||||
|
(__HANDLE__)->ChannelState[3] = (__CHANNEL_STATE__); \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#define TIM_CHANNEL_N_STATE_GET(__HANDLE__, __CHANNEL__)\
|
||||||
|
(((__CHANNEL__) == TIM_CHANNEL_1) ? (__HANDLE__)->ChannelNState[0] :\
|
||||||
|
((__CHANNEL__) == TIM_CHANNEL_2) ? (__HANDLE__)->ChannelNState[1] :\
|
||||||
|
((__CHANNEL__) == TIM_CHANNEL_3) ? (__HANDLE__)->ChannelNState[2] :\
|
||||||
|
(__HANDLE__)->ChannelNState[3])
|
||||||
|
|
||||||
|
#define TIM_CHANNEL_N_STATE_SET(__HANDLE__, __CHANNEL__, __CHANNEL_STATE__) \
|
||||||
|
(((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->ChannelNState[0] = (__CHANNEL_STATE__)) :\
|
||||||
|
((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->ChannelNState[1] = (__CHANNEL_STATE__)) :\
|
||||||
|
((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->ChannelNState[2] = (__CHANNEL_STATE__)) :\
|
||||||
|
((__HANDLE__)->ChannelNState[3] = (__CHANNEL_STATE__)))
|
||||||
|
|
||||||
|
#define TIM_CHANNEL_N_STATE_SET_ALL(__HANDLE__, __CHANNEL_STATE__) do { \
|
||||||
|
(__HANDLE__)->ChannelNState[0] = (__CHANNEL_STATE__); \
|
||||||
|
(__HANDLE__)->ChannelNState[1] = (__CHANNEL_STATE__); \
|
||||||
|
(__HANDLE__)->ChannelNState[2] = (__CHANNEL_STATE__); \
|
||||||
|
(__HANDLE__)->ChannelNState[3] = (__CHANNEL_STATE__); \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -1918,9 +2013,15 @@ HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro(TIM_HandleTypeDef *htim, TIM_SlaveC
|
||||||
HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro_IT(TIM_HandleTypeDef *htim, TIM_SlaveConfigTypeDef *sSlaveConfig);
|
HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro_IT(TIM_HandleTypeDef *htim, TIM_SlaveConfigTypeDef *sSlaveConfig);
|
||||||
HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress,
|
HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress,
|
||||||
uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength);
|
uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength);
|
||||||
|
HAL_StatusTypeDef HAL_TIM_DMABurst_MultiWriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress,
|
||||||
|
uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength,
|
||||||
|
uint32_t DataLength);
|
||||||
HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc);
|
HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc);
|
||||||
HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress,
|
HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress,
|
||||||
uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength);
|
uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength);
|
||||||
|
HAL_StatusTypeDef HAL_TIM_DMABurst_MultiReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress,
|
||||||
|
uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength,
|
||||||
|
uint32_t DataLength);
|
||||||
HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc);
|
HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc);
|
||||||
HAL_StatusTypeDef HAL_TIM_GenerateEvent(TIM_HandleTypeDef *htim, uint32_t EventSource);
|
HAL_StatusTypeDef HAL_TIM_GenerateEvent(TIM_HandleTypeDef *htim, uint32_t EventSource);
|
||||||
uint32_t HAL_TIM_ReadCapturedValue(TIM_HandleTypeDef *htim, uint32_t Channel);
|
uint32_t HAL_TIM_ReadCapturedValue(TIM_HandleTypeDef *htim, uint32_t Channel);
|
||||||
|
@ -1966,6 +2067,11 @@ HAL_TIM_StateTypeDef HAL_TIM_PWM_GetState(TIM_HandleTypeDef *htim);
|
||||||
HAL_TIM_StateTypeDef HAL_TIM_IC_GetState(TIM_HandleTypeDef *htim);
|
HAL_TIM_StateTypeDef HAL_TIM_IC_GetState(TIM_HandleTypeDef *htim);
|
||||||
HAL_TIM_StateTypeDef HAL_TIM_OnePulse_GetState(TIM_HandleTypeDef *htim);
|
HAL_TIM_StateTypeDef HAL_TIM_OnePulse_GetState(TIM_HandleTypeDef *htim);
|
||||||
HAL_TIM_StateTypeDef HAL_TIM_Encoder_GetState(TIM_HandleTypeDef *htim);
|
HAL_TIM_StateTypeDef HAL_TIM_Encoder_GetState(TIM_HandleTypeDef *htim);
|
||||||
|
|
||||||
|
/* Peripheral Channel state functions ************************************************/
|
||||||
|
HAL_TIM_ActiveChannel HAL_TIM_GetActiveChannel(TIM_HandleTypeDef *htim);
|
||||||
|
HAL_TIM_ChannelStateTypeDef HAL_TIM_GetChannelState(TIM_HandleTypeDef *htim, uint32_t Channel);
|
||||||
|
HAL_TIM_DMABurstStateTypeDef HAL_TIM_DMABurstState(TIM_HandleTypeDef *htim);
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -1985,7 +2091,6 @@ void TIM_OC2_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config);
|
||||||
void TIM_ETR_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ExtTRGPrescaler,
|
void TIM_ETR_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ExtTRGPrescaler,
|
||||||
uint32_t TIM_ExtTRGPolarity, uint32_t ExtTRGFilter);
|
uint32_t TIM_ExtTRGPolarity, uint32_t ExtTRGFilter);
|
||||||
|
|
||||||
void TIM_DMADelayPulseCplt(DMA_HandleTypeDef *hdma);
|
|
||||||
void TIM_DMADelayPulseHalfCplt(DMA_HandleTypeDef *hdma);
|
void TIM_DMADelayPulseHalfCplt(DMA_HandleTypeDef *hdma);
|
||||||
void TIM_DMAError(DMA_HandleTypeDef *hdma);
|
void TIM_DMAError(DMA_HandleTypeDef *hdma);
|
||||||
void TIM_DMACaptureCplt(DMA_HandleTypeDef *hdma);
|
void TIM_DMACaptureCplt(DMA_HandleTypeDef *hdma);
|
||||||
|
|
|
@ -223,6 +223,7 @@ void HAL_TIMEx_BreakCallback(TIM_HandleTypeDef *htim);
|
||||||
*/
|
*/
|
||||||
/* Extended Peripheral State functions ***************************************/
|
/* Extended Peripheral State functions ***************************************/
|
||||||
HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(TIM_HandleTypeDef *htim);
|
HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(TIM_HandleTypeDef *htim);
|
||||||
|
HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(TIM_HandleTypeDef *htim, uint32_t ChannelN);
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -537,7 +537,7 @@ typedef void (*pUART_CallbackTypeDef)(UART_HandleTypeDef *huart); /*!< pointer
|
||||||
(((__INTERRUPT__) >> 28U) == UART_CR2_REG_INDEX)? ((__HANDLE__)->Instance->CR2 &= ~((__INTERRUPT__) & UART_IT_MASK)): \
|
(((__INTERRUPT__) >> 28U) == UART_CR2_REG_INDEX)? ((__HANDLE__)->Instance->CR2 &= ~((__INTERRUPT__) & UART_IT_MASK)): \
|
||||||
((__HANDLE__)->Instance->CR3 &= ~ ((__INTERRUPT__) & UART_IT_MASK)))
|
((__HANDLE__)->Instance->CR3 &= ~ ((__INTERRUPT__) & UART_IT_MASK)))
|
||||||
|
|
||||||
/** @brief Checks whether the specified UART interrupt has occurred or not.
|
/** @brief Checks whether the specified UART interrupt source is enabled or not.
|
||||||
* @param __HANDLE__ specifies the UART Handle.
|
* @param __HANDLE__ specifies the UART Handle.
|
||||||
* UART Handle selects the USARTx or UARTy peripheral
|
* UART Handle selects the USARTx or UARTy peripheral
|
||||||
* (USART,UART availability and x,y values depending on device).
|
* (USART,UART availability and x,y values depending on device).
|
||||||
|
@ -806,7 +806,7 @@ uint32_t HAL_UART_GetError(UART_HandleTypeDef *huart);
|
||||||
|
|
||||||
#define UART_DIV_SAMPLING16(_PCLK_, _BAUD_) (((_PCLK_)*25U)/(4U*(_BAUD_)))
|
#define UART_DIV_SAMPLING16(_PCLK_, _BAUD_) (((_PCLK_)*25U)/(4U*(_BAUD_)))
|
||||||
#define UART_DIVMANT_SAMPLING16(_PCLK_, _BAUD_) (UART_DIV_SAMPLING16((_PCLK_), (_BAUD_))/100U)
|
#define UART_DIVMANT_SAMPLING16(_PCLK_, _BAUD_) (UART_DIV_SAMPLING16((_PCLK_), (_BAUD_))/100U)
|
||||||
#define UART_DIVFRAQ_SAMPLING16(_PCLK_, _BAUD_) (((UART_DIV_SAMPLING16((_PCLK_), (_BAUD_)) - (UART_DIVMANT_SAMPLING16((_PCLK_), (_BAUD_)) * 100U)) * 16U + 50U) / 100U)
|
#define UART_DIVFRAQ_SAMPLING16(_PCLK_, _BAUD_) ((((UART_DIV_SAMPLING16((_PCLK_), (_BAUD_)) - (UART_DIVMANT_SAMPLING16((_PCLK_), (_BAUD_)) * 100U)) * 16U) + 50U) / 100U)
|
||||||
/* UART BRR = mantissa + overflow + fraction
|
/* UART BRR = mantissa + overflow + fraction
|
||||||
= (UART DIVMANT << 4) + (UART DIVFRAQ & 0xF0) + (UART DIVFRAQ & 0x0FU) */
|
= (UART DIVMANT << 4) + (UART DIVFRAQ & 0xF0) + (UART DIVFRAQ & 0x0FU) */
|
||||||
#define UART_BRR_SAMPLING16(_PCLK_, _BAUD_) (((UART_DIVMANT_SAMPLING16((_PCLK_), (_BAUD_)) << 4U) + \
|
#define UART_BRR_SAMPLING16(_PCLK_, _BAUD_) (((UART_DIVMANT_SAMPLING16((_PCLK_), (_BAUD_)) << 4U) + \
|
||||||
|
@ -815,7 +815,7 @@ uint32_t HAL_UART_GetError(UART_HandleTypeDef *huart);
|
||||||
|
|
||||||
#define UART_DIV_SAMPLING8(_PCLK_, _BAUD_) (((_PCLK_)*25U)/(2U*(_BAUD_)))
|
#define UART_DIV_SAMPLING8(_PCLK_, _BAUD_) (((_PCLK_)*25U)/(2U*(_BAUD_)))
|
||||||
#define UART_DIVMANT_SAMPLING8(_PCLK_, _BAUD_) (UART_DIV_SAMPLING8((_PCLK_), (_BAUD_))/100U)
|
#define UART_DIVMANT_SAMPLING8(_PCLK_, _BAUD_) (UART_DIV_SAMPLING8((_PCLK_), (_BAUD_))/100U)
|
||||||
#define UART_DIVFRAQ_SAMPLING8(_PCLK_, _BAUD_) (((UART_DIV_SAMPLING8((_PCLK_), (_BAUD_)) - (UART_DIVMANT_SAMPLING8((_PCLK_), (_BAUD_)) * 100U)) * 8U + 50U) / 100U)
|
#define UART_DIVFRAQ_SAMPLING8(_PCLK_, _BAUD_) ((((UART_DIV_SAMPLING8((_PCLK_), (_BAUD_)) - (UART_DIVMANT_SAMPLING8((_PCLK_), (_BAUD_)) * 100U)) * 8U) + 50U) / 100U)
|
||||||
/* UART BRR = mantissa + overflow + fraction
|
/* UART BRR = mantissa + overflow + fraction
|
||||||
= (UART DIVMANT << 4) + ((UART DIVFRAQ & 0xF8) << 1) + (UART DIVFRAQ & 0x07U) */
|
= (UART DIVMANT << 4) + ((UART DIVFRAQ & 0xF8) << 1) + (UART DIVFRAQ & 0x07U) */
|
||||||
#define UART_BRR_SAMPLING8(_PCLK_, _BAUD_) (((UART_DIVMANT_SAMPLING8((_PCLK_), (_BAUD_)) << 4U) + \
|
#define UART_BRR_SAMPLING8(_PCLK_, _BAUD_) (((UART_DIVMANT_SAMPLING8((_PCLK_), (_BAUD_)) << 4U) + \
|
||||||
|
|
|
@ -81,7 +81,7 @@ typedef enum
|
||||||
} USB_OTG_HCStateTypeDef;
|
} USB_OTG_HCStateTypeDef;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief USB OTG Initialization Structure definition
|
* @brief USB Instance Initialization Structure definition
|
||||||
*/
|
*/
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
|
@ -94,14 +94,14 @@ typedef struct
|
||||||
This parameter must be a number between Min_Data = 1 and Max_Data = 15 */
|
This parameter must be a number between Min_Data = 1 and Max_Data = 15 */
|
||||||
|
|
||||||
uint32_t speed; /*!< USB Core speed.
|
uint32_t speed; /*!< USB Core speed.
|
||||||
This parameter can be any value of @ref USB_Core_Speed_ */
|
This parameter can be any value of @ref USB_Core_Speed */
|
||||||
|
|
||||||
uint32_t dma_enable; /*!< Enable or disable of the USB embedded DMA used only for OTG HS. */
|
uint32_t dma_enable; /*!< Enable or disable of the USB embedded DMA used only for OTG HS. */
|
||||||
|
|
||||||
uint32_t ep0_mps; /*!< Set the Endpoint 0 Max Packet size. */
|
uint32_t ep0_mps; /*!< Set the Endpoint 0 Max Packet size. */
|
||||||
|
|
||||||
uint32_t phy_itface; /*!< Select the used PHY interface.
|
uint32_t phy_itface; /*!< Select the used PHY interface.
|
||||||
This parameter can be any value of @ref USB_Core_PHY_ */
|
This parameter can be any value of @ref USB_Core_PHY */
|
||||||
|
|
||||||
uint32_t Sof_enable; /*!< Enable or disable the output of the SOF signal. */
|
uint32_t Sof_enable; /*!< Enable or disable the output of the SOF signal. */
|
||||||
|
|
||||||
|
@ -116,6 +116,7 @@ typedef struct
|
||||||
uint32_t use_dedicated_ep1; /*!< Enable or disable the use of the dedicated EP1 interrupt. */
|
uint32_t use_dedicated_ep1; /*!< Enable or disable the use of the dedicated EP1 interrupt. */
|
||||||
|
|
||||||
uint32_t use_external_vbus; /*!< Enable or disable the use of the external VBUS. */
|
uint32_t use_external_vbus; /*!< Enable or disable the use of the external VBUS. */
|
||||||
|
|
||||||
} USB_OTG_CfgTypeDef;
|
} USB_OTG_CfgTypeDef;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
|
@ -155,7 +156,7 @@ typedef struct
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
uint8_t dev_addr ; /*!< USB device address.
|
uint8_t dev_addr; /*!< USB device address.
|
||||||
This parameter must be a number between Min_Data = 1 and Max_Data = 255 */
|
This parameter must be a number between Min_Data = 1 and Max_Data = 255 */
|
||||||
|
|
||||||
uint8_t ch_num; /*!< Host channel number.
|
uint8_t ch_num; /*!< Host channel number.
|
||||||
|
@ -197,13 +198,13 @@ typedef struct
|
||||||
|
|
||||||
uint32_t dma_addr; /*!< 32 bits aligned transfer buffer address. */
|
uint32_t dma_addr; /*!< 32 bits aligned transfer buffer address. */
|
||||||
|
|
||||||
uint32_t ErrCnt; /*!< Host channel error count.*/
|
uint32_t ErrCnt; /*!< Host channel error count. */
|
||||||
|
|
||||||
USB_OTG_URBStateTypeDef urb_state; /*!< URB state.
|
USB_OTG_URBStateTypeDef urb_state; /*!< URB state.
|
||||||
This parameter can be any value of @ref USB_OTG_URBStateTypeDef */
|
This parameter can be any value of @ref USB_OTG_URBStateTypeDef */
|
||||||
|
|
||||||
USB_OTG_HCStateTypeDef state; /*!< Host Channel state.
|
USB_OTG_HCStateTypeDef state; /*!< Host Channel state.
|
||||||
This parameter can be any value of @ref USB_OTG_HCStateTypeDef */
|
This parameter can be any value of @ref USB_OTG_HCStateTypeDef */
|
||||||
} USB_OTG_HCTypeDef;
|
} USB_OTG_HCTypeDef;
|
||||||
#endif /* defined (USB_OTG_FS) */
|
#endif /* defined (USB_OTG_FS) */
|
||||||
|
|
||||||
|
@ -282,6 +283,10 @@ typedef struct
|
||||||
|
|
||||||
uint32_t xfer_count; /*!< Partial transfer length in case of multi packet transfer */
|
uint32_t xfer_count; /*!< Partial transfer length in case of multi packet transfer */
|
||||||
|
|
||||||
|
uint32_t xfer_len_db; /*!< double buffer transfer length used with bulk double buffer in */
|
||||||
|
|
||||||
|
uint8_t xfer_fill_db; /*!< double buffer Need to Fill new buffer used with bulk_in */
|
||||||
|
|
||||||
} USB_EPTypeDef;
|
} USB_EPTypeDef;
|
||||||
#endif /* defined (USB) */
|
#endif /* defined (USB) */
|
||||||
|
|
||||||
|
@ -314,8 +319,8 @@ typedef struct
|
||||||
/** @defgroup USB_LL Device Speed
|
/** @defgroup USB_LL Device Speed
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define USBD_FS_SPEED 2U
|
#define USBD_FS_SPEED 2U
|
||||||
#define USBH_FS_SPEED 1U
|
#define USBH_FSLS_SPEED 1U
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -341,8 +346,8 @@ typedef struct
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#ifndef USBD_FS_TRDT_VALUE
|
#ifndef USBD_FS_TRDT_VALUE
|
||||||
#define USBD_FS_TRDT_VALUE 5U
|
#define USBD_FS_TRDT_VALUE 5U
|
||||||
#define USBD_DEFAULT_TRDT_VALUE 9U
|
#define USBD_DEFAULT_TRDT_VALUE 9U
|
||||||
#endif /* USBD_HS_TRDT_VALUE */
|
#endif /* USBD_HS_TRDT_VALUE */
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
|
@ -351,8 +356,8 @@ typedef struct
|
||||||
/** @defgroup USB_LL_Core_MPS USB Low Layer Core MPS
|
/** @defgroup USB_LL_Core_MPS USB Low Layer Core MPS
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define USB_OTG_FS_MAX_PACKET_SIZE 64U
|
#define USB_OTG_FS_MAX_PACKET_SIZE 64U
|
||||||
#define USB_OTG_MAX_EP0_SIZE 64U
|
#define USB_OTG_MAX_EP0_SIZE 64U
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -381,10 +386,10 @@ typedef struct
|
||||||
/** @defgroup USB_LL_EP0_MPS USB Low Layer EP0 MPS
|
/** @defgroup USB_LL_EP0_MPS USB Low Layer EP0 MPS
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define DEP0CTL_MPS_64 0U
|
#define EP_MPS_64 0U
|
||||||
#define DEP0CTL_MPS_32 1U
|
#define EP_MPS_32 1U
|
||||||
#define DEP0CTL_MPS_16 2U
|
#define EP_MPS_16 2U
|
||||||
#define DEP0CTL_MPS_8 3U
|
#define EP_MPS_8 3U
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -474,10 +479,10 @@ typedef struct
|
||||||
/** @defgroup USB_LL_EP0_MPS USB Low Layer EP0 MPS
|
/** @defgroup USB_LL_EP0_MPS USB Low Layer EP0 MPS
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define DEP0CTL_MPS_64 0U
|
#define EP_MPS_64 0U
|
||||||
#define DEP0CTL_MPS_32 1U
|
#define EP_MPS_32 1U
|
||||||
#define DEP0CTL_MPS_16 2U
|
#define EP_MPS_16 2U
|
||||||
#define DEP0CTL_MPS_8 3U
|
#define EP_MPS_8 3U
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -550,7 +555,9 @@ HAL_StatusTypeDef USB_ActivateDedicatedEndpoint(USB_OTG_GlobalTypeDef *USBx, USB
|
||||||
HAL_StatusTypeDef USB_DeactivateDedicatedEndpoint(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_DeactivateDedicatedEndpoint(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_EPStartXfer(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_EPStartXfer(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_EP0StartXfer(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_EP0StartXfer(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_WritePacket(USB_OTG_GlobalTypeDef *USBx, uint8_t *src, uint8_t ch_ep_num, uint16_t len);
|
HAL_StatusTypeDef USB_WritePacket(USB_OTG_GlobalTypeDef *USBx, uint8_t *src,
|
||||||
|
uint8_t ch_ep_num, uint16_t len);
|
||||||
|
|
||||||
void *USB_ReadPacket(USB_OTG_GlobalTypeDef *USBx, uint8_t *dest, uint16_t len);
|
void *USB_ReadPacket(USB_OTG_GlobalTypeDef *USBx, uint8_t *dest, uint16_t len);
|
||||||
HAL_StatusTypeDef USB_EPSetStall(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_EPSetStall(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_EPClearStall(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_EPClearStall(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep);
|
||||||
|
@ -575,14 +582,12 @@ HAL_StatusTypeDef USB_ResetPort(USB_OTG_GlobalTypeDef *USBx);
|
||||||
HAL_StatusTypeDef USB_DriveVbus(USB_OTG_GlobalTypeDef *USBx, uint8_t state);
|
HAL_StatusTypeDef USB_DriveVbus(USB_OTG_GlobalTypeDef *USBx, uint8_t state);
|
||||||
uint32_t USB_GetHostSpeed(USB_OTG_GlobalTypeDef *USBx);
|
uint32_t USB_GetHostSpeed(USB_OTG_GlobalTypeDef *USBx);
|
||||||
uint32_t USB_GetCurrentFrame(USB_OTG_GlobalTypeDef *USBx);
|
uint32_t USB_GetCurrentFrame(USB_OTG_GlobalTypeDef *USBx);
|
||||||
HAL_StatusTypeDef USB_HC_Init(USB_OTG_GlobalTypeDef *USBx,
|
HAL_StatusTypeDef USB_HC_Init(USB_OTG_GlobalTypeDef *USBx, uint8_t ch_num,
|
||||||
uint8_t ch_num,
|
uint8_t epnum, uint8_t dev_address, uint8_t speed,
|
||||||
uint8_t epnum,
|
uint8_t ep_type, uint16_t mps);
|
||||||
uint8_t dev_address,
|
HAL_StatusTypeDef USB_HC_StartXfer(USB_OTG_GlobalTypeDef *USBx,
|
||||||
uint8_t speed,
|
USB_OTG_HCTypeDef *hc);
|
||||||
uint8_t ep_type,
|
|
||||||
uint16_t mps);
|
|
||||||
HAL_StatusTypeDef USB_HC_StartXfer(USB_OTG_GlobalTypeDef *USBx, USB_OTG_HCTypeDef *hc);
|
|
||||||
uint32_t USB_HC_ReadInterrupt(USB_OTG_GlobalTypeDef *USBx);
|
uint32_t USB_HC_ReadInterrupt(USB_OTG_GlobalTypeDef *USBx);
|
||||||
HAL_StatusTypeDef USB_HC_Halt(USB_OTG_GlobalTypeDef *USBx, uint8_t hc_num);
|
HAL_StatusTypeDef USB_HC_Halt(USB_OTG_GlobalTypeDef *USBx, uint8_t hc_num);
|
||||||
HAL_StatusTypeDef USB_DoPing(USB_OTG_GlobalTypeDef *USBx, uint8_t ch_num);
|
HAL_StatusTypeDef USB_DoPing(USB_OTG_GlobalTypeDef *USBx, uint8_t ch_num);
|
||||||
|
@ -603,8 +608,6 @@ HAL_StatusTypeDef USB_FlushTxFifo(USB_TypeDef *USBx, uint32_t num);
|
||||||
HAL_StatusTypeDef USB_ActivateEndpoint(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_ActivateEndpoint(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_DeactivateEndpoint(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_DeactivateEndpoint(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_EPStartXfer(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_EPStartXfer(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_WritePacket(USB_TypeDef *USBx, uint8_t *src, uint8_t ch_ep_num, uint16_t len);
|
|
||||||
void *USB_ReadPacket(USB_TypeDef *USBx, uint8_t *dest, uint16_t len);
|
|
||||||
HAL_StatusTypeDef USB_EPSetStall(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_EPSetStall(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_EPClearStall(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
HAL_StatusTypeDef USB_EPClearStall(USB_TypeDef *USBx, USB_EPTypeDef *ep);
|
||||||
HAL_StatusTypeDef USB_SetDevAddress(USB_TypeDef *USBx, uint8_t address);
|
HAL_StatusTypeDef USB_SetDevAddress(USB_TypeDef *USBx, uint8_t address);
|
||||||
|
@ -612,17 +615,25 @@ HAL_StatusTypeDef USB_DevConnect(USB_TypeDef *USBx);
|
||||||
HAL_StatusTypeDef USB_DevDisconnect(USB_TypeDef *USBx);
|
HAL_StatusTypeDef USB_DevDisconnect(USB_TypeDef *USBx);
|
||||||
HAL_StatusTypeDef USB_StopDevice(USB_TypeDef *USBx);
|
HAL_StatusTypeDef USB_StopDevice(USB_TypeDef *USBx);
|
||||||
HAL_StatusTypeDef USB_EP0_OutStart(USB_TypeDef *USBx, uint8_t *psetup);
|
HAL_StatusTypeDef USB_EP0_OutStart(USB_TypeDef *USBx, uint8_t *psetup);
|
||||||
|
HAL_StatusTypeDef USB_WritePacket(USB_TypeDef *USBx, uint8_t *src,
|
||||||
|
uint8_t ch_ep_num, uint16_t len);
|
||||||
|
|
||||||
|
void *USB_ReadPacket(USB_TypeDef *USBx, uint8_t *dest, uint16_t len);
|
||||||
|
|
||||||
uint32_t USB_ReadInterrupts(USB_TypeDef *USBx);
|
uint32_t USB_ReadInterrupts(USB_TypeDef *USBx);
|
||||||
uint32_t USB_ReadDevAllOutEpInterrupt(USB_TypeDef *USBx);
|
uint32_t USB_ReadDevAllOutEpInterrupt(USB_TypeDef *USBx);
|
||||||
uint32_t USB_ReadDevOutEPInterrupt(USB_TypeDef *USBx, uint8_t epnum);
|
uint32_t USB_ReadDevOutEPInterrupt(USB_TypeDef *USBx, uint8_t epnum);
|
||||||
uint32_t USB_ReadDevAllInEpInterrupt(USB_TypeDef *USBx);
|
uint32_t USB_ReadDevAllInEpInterrupt(USB_TypeDef *USBx);
|
||||||
uint32_t USB_ReadDevInEPInterrupt(USB_TypeDef *USBx, uint8_t epnum);
|
uint32_t USB_ReadDevInEPInterrupt(USB_TypeDef *USBx, uint8_t epnum);
|
||||||
void USB_ClearInterrupts(USB_TypeDef *USBx, uint32_t interrupt);
|
void USB_ClearInterrupts(USB_TypeDef *USBx, uint32_t interrupt);
|
||||||
|
|
||||||
HAL_StatusTypeDef USB_ActivateRemoteWakeup(USB_TypeDef *USBx);
|
HAL_StatusTypeDef USB_ActivateRemoteWakeup(USB_TypeDef *USBx);
|
||||||
HAL_StatusTypeDef USB_DeActivateRemoteWakeup(USB_TypeDef *USBx);
|
HAL_StatusTypeDef USB_DeActivateRemoteWakeup(USB_TypeDef *USBx);
|
||||||
void USB_WritePMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf, uint16_t wPMABufAddr, uint16_t wNBytes);
|
|
||||||
void USB_ReadPMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf, uint16_t wPMABufAddr, uint16_t wNBytes);
|
void USB_WritePMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf,
|
||||||
|
uint16_t wPMABufAddr, uint16_t wNBytes);
|
||||||
|
|
||||||
|
void USB_ReadPMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf,
|
||||||
|
uint16_t wPMABufAddr, uint16_t wNBytes);
|
||||||
#endif /* defined (USB) */
|
#endif /* defined (USB) */
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
|
|
|
@ -53,11 +53,11 @@
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
/**
|
/**
|
||||||
* @brief STM32F1xx HAL Driver version number V1.1.4
|
* @brief STM32F1xx HAL Driver version number V1.1.7
|
||||||
*/
|
*/
|
||||||
#define __STM32F1xx_HAL_VERSION_MAIN (0x01U) /*!< [31:24] main version */
|
#define __STM32F1xx_HAL_VERSION_MAIN (0x01U) /*!< [31:24] main version */
|
||||||
#define __STM32F1xx_HAL_VERSION_SUB1 (0x01U) /*!< [23:16] sub1 version */
|
#define __STM32F1xx_HAL_VERSION_SUB1 (0x01U) /*!< [23:16] sub1 version */
|
||||||
#define __STM32F1xx_HAL_VERSION_SUB2 (0x04U) /*!< [15:8] sub2 version */
|
#define __STM32F1xx_HAL_VERSION_SUB2 (0x07U) /*!< [15:8] sub2 version */
|
||||||
#define __STM32F1xx_HAL_VERSION_RC (0x00U) /*!< [7:0] release candidate */
|
#define __STM32F1xx_HAL_VERSION_RC (0x00U) /*!< [7:0] release candidate */
|
||||||
#define __STM32F1xx_HAL_VERSION ((__STM32F1xx_HAL_VERSION_MAIN << 24)\
|
#define __STM32F1xx_HAL_VERSION ((__STM32F1xx_HAL_VERSION_MAIN << 24)\
|
||||||
|(__STM32F1xx_HAL_VERSION_SUB1 << 16)\
|
|(__STM32F1xx_HAL_VERSION_SUB1 << 16)\
|
||||||
|
@ -322,15 +322,25 @@ uint32_t HAL_GetTickPrio(void)
|
||||||
HAL_StatusTypeDef HAL_SetTickFreq(HAL_TickFreqTypeDef Freq)
|
HAL_StatusTypeDef HAL_SetTickFreq(HAL_TickFreqTypeDef Freq)
|
||||||
{
|
{
|
||||||
HAL_StatusTypeDef status = HAL_OK;
|
HAL_StatusTypeDef status = HAL_OK;
|
||||||
|
HAL_TickFreqTypeDef prevTickFreq;
|
||||||
|
|
||||||
assert_param(IS_TICKFREQ(Freq));
|
assert_param(IS_TICKFREQ(Freq));
|
||||||
|
|
||||||
if (uwTickFreq != Freq)
|
if (uwTickFreq != Freq)
|
||||||
{
|
{
|
||||||
|
/* Back up uwTickFreq frequency */
|
||||||
|
prevTickFreq = uwTickFreq;
|
||||||
|
|
||||||
|
/* Update uwTickFreq global variable used by HAL_InitTick() */
|
||||||
|
uwTickFreq = Freq;
|
||||||
|
|
||||||
/* Apply the new tick Freq */
|
/* Apply the new tick Freq */
|
||||||
status = HAL_InitTick(uwTickPrio);
|
status = HAL_InitTick(uwTickPrio);
|
||||||
if (status == HAL_OK)
|
|
||||||
|
if (status != HAL_OK)
|
||||||
{
|
{
|
||||||
uwTickFreq = Freq;
|
/* Restore previous tick frequency */
|
||||||
|
uwTickFreq = prevTickFreq;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1711,23 +1711,26 @@ HAL_StatusTypeDef HAL_ADC_Stop_DMA(ADC_HandleTypeDef* hadc)
|
||||||
|
|
||||||
/* Disable the DMA channel (in case of DMA in circular mode or stop while */
|
/* Disable the DMA channel (in case of DMA in circular mode or stop while */
|
||||||
/* DMA transfer is on going) */
|
/* DMA transfer is on going) */
|
||||||
tmp_hal_status = HAL_DMA_Abort(hadc->DMA_Handle);
|
if (hadc->DMA_Handle->State == HAL_DMA_STATE_BUSY)
|
||||||
|
|
||||||
/* Check if DMA channel effectively disabled */
|
|
||||||
if (tmp_hal_status == HAL_OK)
|
|
||||||
{
|
{
|
||||||
/* Set ADC state */
|
tmp_hal_status = HAL_DMA_Abort(hadc->DMA_Handle);
|
||||||
ADC_STATE_CLR_SET(hadc->State,
|
|
||||||
HAL_ADC_STATE_REG_BUSY | HAL_ADC_STATE_INJ_BUSY,
|
/* Check if DMA channel effectively disabled */
|
||||||
HAL_ADC_STATE_READY);
|
if (tmp_hal_status == HAL_OK)
|
||||||
}
|
{
|
||||||
else
|
/* Set ADC state */
|
||||||
{
|
ADC_STATE_CLR_SET(hadc->State,
|
||||||
/* Update ADC state machine to error */
|
HAL_ADC_STATE_REG_BUSY | HAL_ADC_STATE_INJ_BUSY,
|
||||||
SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_DMA);
|
HAL_ADC_STATE_READY);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Update ADC state machine to error */
|
||||||
|
SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_DMA);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Process unlocked */
|
/* Process unlocked */
|
||||||
__HAL_UNLOCK(hadc);
|
__HAL_UNLOCK(hadc);
|
||||||
|
|
||||||
|
|
|
@ -486,17 +486,16 @@ void HAL_GPIO_WritePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin, GPIO_PinState Pin
|
||||||
*/
|
*/
|
||||||
void HAL_GPIO_TogglePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin)
|
void HAL_GPIO_TogglePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin)
|
||||||
{
|
{
|
||||||
|
uint32_t odr;
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_GPIO_PIN(GPIO_Pin));
|
assert_param(IS_GPIO_PIN(GPIO_Pin));
|
||||||
|
|
||||||
if ((GPIOx->ODR & GPIO_Pin) != 0x00u)
|
/* get current Ouput Data Register value */
|
||||||
{
|
odr = GPIOx->ODR;
|
||||||
GPIOx->BRR = (uint32_t)GPIO_Pin;
|
|
||||||
}
|
/* Set selected pins that were at low level, and reset ones that were high */
|
||||||
else
|
GPIOx->BSRR = ((odr & GPIO_Pin) << GPIO_NUMBER) | (~odr & GPIO_Pin);
|
||||||
{
|
|
||||||
GPIOx->BSRR = (uint32_t)GPIO_Pin;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -337,6 +337,7 @@
|
||||||
*/
|
*/
|
||||||
#define I2C_TIMEOUT_FLAG 35U /*!< Timeout 35 ms */
|
#define I2C_TIMEOUT_FLAG 35U /*!< Timeout 35 ms */
|
||||||
#define I2C_TIMEOUT_BUSY_FLAG 25U /*!< Timeout 25 ms */
|
#define I2C_TIMEOUT_BUSY_FLAG 25U /*!< Timeout 25 ms */
|
||||||
|
#define I2C_TIMEOUT_STOP_FLAG 5U /*!< Timeout 5 ms */
|
||||||
#define I2C_NO_OPTION_FRAME 0xFFFF0000U /*!< XferOptions default value */
|
#define I2C_NO_OPTION_FRAME 0xFFFF0000U /*!< XferOptions default value */
|
||||||
|
|
||||||
/* Private define for @ref PreviousState usage */
|
/* Private define for @ref PreviousState usage */
|
||||||
|
@ -377,6 +378,7 @@ static HAL_StatusTypeDef I2C_WaitOnTXEFlagUntilTimeout(I2C_HandleTypeDef *hi2c,
|
||||||
static HAL_StatusTypeDef I2C_WaitOnBTFFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, uint32_t Tickstart);
|
static HAL_StatusTypeDef I2C_WaitOnBTFFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, uint32_t Tickstart);
|
||||||
static HAL_StatusTypeDef I2C_WaitOnRXNEFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, uint32_t Tickstart);
|
static HAL_StatusTypeDef I2C_WaitOnRXNEFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, uint32_t Tickstart);
|
||||||
static HAL_StatusTypeDef I2C_WaitOnSTOPFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, uint32_t Tickstart);
|
static HAL_StatusTypeDef I2C_WaitOnSTOPFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, uint32_t Tickstart);
|
||||||
|
static HAL_StatusTypeDef I2C_WaitOnSTOPRequestThroughIT(I2C_HandleTypeDef *hi2c);
|
||||||
static HAL_StatusTypeDef I2C_IsAcknowledgeFailed(I2C_HandleTypeDef *hi2c);
|
static HAL_StatusTypeDef I2C_IsAcknowledgeFailed(I2C_HandleTypeDef *hi2c);
|
||||||
|
|
||||||
/* Private functions for I2C transfer IRQ handler */
|
/* Private functions for I2C transfer IRQ handler */
|
||||||
|
@ -396,6 +398,8 @@ static void I2C_Slave_ADDR(I2C_HandleTypeDef *hi2c, uint32_t IT2Flags);
|
||||||
static void I2C_Slave_STOPF(I2C_HandleTypeDef *hi2c);
|
static void I2C_Slave_STOPF(I2C_HandleTypeDef *hi2c);
|
||||||
static void I2C_Slave_AF(I2C_HandleTypeDef *hi2c);
|
static void I2C_Slave_AF(I2C_HandleTypeDef *hi2c);
|
||||||
|
|
||||||
|
static void I2C_MemoryTransmit_TXE_BTF(I2C_HandleTypeDef *hi2c);
|
||||||
|
|
||||||
/* Private function to Convert Specific options */
|
/* Private function to Convert Specific options */
|
||||||
static void I2C_ConvertOtherXferOptions(I2C_HandleTypeDef *hi2c);
|
static void I2C_ConvertOtherXferOptions(I2C_HandleTypeDef *hi2c);
|
||||||
/**
|
/**
|
||||||
|
@ -504,6 +508,10 @@ HAL_StatusTypeDef HAL_I2C_Init(I2C_HandleTypeDef *hi2c)
|
||||||
/* Disable the selected I2C peripheral */
|
/* Disable the selected I2C peripheral */
|
||||||
__HAL_I2C_DISABLE(hi2c);
|
__HAL_I2C_DISABLE(hi2c);
|
||||||
|
|
||||||
|
/*Reset I2C*/
|
||||||
|
hi2c->Instance->CR1 |= I2C_CR1_SWRST;
|
||||||
|
hi2c->Instance->CR1 &= ~I2C_CR1_SWRST;
|
||||||
|
|
||||||
/* Get PCLK1 frequency */
|
/* Get PCLK1 frequency */
|
||||||
pclk1 = HAL_RCC_GetPCLK1Freq();
|
pclk1 = HAL_RCC_GetPCLK1Freq();
|
||||||
|
|
||||||
|
@ -1162,6 +1170,8 @@ HAL_StatusTypeDef HAL_I2C_Master_Transmit(I2C_HandleTypeDef *hi2c, uint16_t DevA
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_I2C_Master_Receive(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t Timeout)
|
HAL_StatusTypeDef HAL_I2C_Master_Receive(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t Timeout)
|
||||||
{
|
{
|
||||||
|
__IO uint32_t count = 0U;
|
||||||
|
|
||||||
/* Init tickstart for timeout management*/
|
/* Init tickstart for timeout management*/
|
||||||
uint32_t tickstart = HAL_GetTick();
|
uint32_t tickstart = HAL_GetTick();
|
||||||
|
|
||||||
|
@ -1344,10 +1354,27 @@ HAL_StatusTypeDef HAL_I2C_Master_Receive(I2C_HandleTypeDef *hi2c, uint16_t DevAd
|
||||||
hi2c->XferCount--;
|
hi2c->XferCount--;
|
||||||
|
|
||||||
/* Wait until BTF flag is set */
|
/* Wait until BTF flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BTF, RESET, Timeout, tickstart) != HAL_OK)
|
count = I2C_TIMEOUT_FLAG * (SystemCoreClock / 25U / 1000U);
|
||||||
|
do
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
count--;
|
||||||
|
if (count == 0U)
|
||||||
|
{
|
||||||
|
hi2c->PreviousState = I2C_STATE_NONE;
|
||||||
|
hi2c->State = HAL_I2C_STATE_READY;
|
||||||
|
hi2c->Mode = HAL_I2C_MODE_NONE;
|
||||||
|
hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
|
||||||
|
|
||||||
|
/* Re-enable IRQs */
|
||||||
|
__enable_irq();
|
||||||
|
|
||||||
|
/* Process Unlocked */
|
||||||
|
__HAL_UNLOCK(hi2c);
|
||||||
|
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BTF) == RESET);
|
||||||
|
|
||||||
/* Generate Stop */
|
/* Generate Stop */
|
||||||
SET_BIT(hi2c->Instance->CR1, I2C_CR1_STOP);
|
SET_BIT(hi2c->Instance->CR1, I2C_CR1_STOP);
|
||||||
|
@ -2567,6 +2594,8 @@ HAL_StatusTypeDef HAL_I2C_Mem_Write(I2C_HandleTypeDef *hi2c, uint16_t DevAddress
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_I2C_Mem_Read(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout)
|
HAL_StatusTypeDef HAL_I2C_Mem_Read(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout)
|
||||||
{
|
{
|
||||||
|
__IO uint32_t count = 0U;
|
||||||
|
|
||||||
/* Init tickstart for timeout management*/
|
/* Init tickstart for timeout management*/
|
||||||
uint32_t tickstart = HAL_GetTick();
|
uint32_t tickstart = HAL_GetTick();
|
||||||
|
|
||||||
|
@ -2751,10 +2780,27 @@ HAL_StatusTypeDef HAL_I2C_Mem_Read(I2C_HandleTypeDef *hi2c, uint16_t DevAddress,
|
||||||
hi2c->XferCount--;
|
hi2c->XferCount--;
|
||||||
|
|
||||||
/* Wait until BTF flag is set */
|
/* Wait until BTF flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BTF, RESET, Timeout, tickstart) != HAL_OK)
|
count = I2C_TIMEOUT_FLAG * (SystemCoreClock / 25U / 1000U);
|
||||||
|
do
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
count--;
|
||||||
|
if (count == 0U)
|
||||||
|
{
|
||||||
|
hi2c->PreviousState = I2C_STATE_NONE;
|
||||||
|
hi2c->State = HAL_I2C_STATE_READY;
|
||||||
|
hi2c->Mode = HAL_I2C_MODE_NONE;
|
||||||
|
hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
|
||||||
|
|
||||||
|
/* Re-enable IRQs */
|
||||||
|
__enable_irq();
|
||||||
|
|
||||||
|
/* Process Unlocked */
|
||||||
|
__HAL_UNLOCK(hi2c);
|
||||||
|
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BTF) == RESET);
|
||||||
|
|
||||||
/* Generate Stop */
|
/* Generate Stop */
|
||||||
SET_BIT(hi2c->Instance->CR1, I2C_CR1_STOP);
|
SET_BIT(hi2c->Instance->CR1, I2C_CR1_STOP);
|
||||||
|
@ -3100,6 +3146,27 @@ HAL_StatusTypeDef HAL_I2C_Mem_Write_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAdd
|
||||||
/* Send Slave Address and Memory Address */
|
/* Send Slave Address and Memory Address */
|
||||||
if (I2C_RequestMemoryWrite(hi2c, DevAddress, MemAddress, MemAddSize, I2C_TIMEOUT_FLAG, tickstart) != HAL_OK)
|
if (I2C_RequestMemoryWrite(hi2c, DevAddress, MemAddress, MemAddSize, I2C_TIMEOUT_FLAG, tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Abort the ongoing DMA */
|
||||||
|
dmaxferstatus = HAL_DMA_Abort_IT(hi2c->hdmatx);
|
||||||
|
|
||||||
|
/* Prevent unused argument(s) compilation and MISRA warning */
|
||||||
|
UNUSED(dmaxferstatus);
|
||||||
|
|
||||||
|
/* Clear directly Complete callback as no XferAbortCallback is used to finalize Abort treatment */
|
||||||
|
if (hi2c->hdmatx != NULL)
|
||||||
|
{
|
||||||
|
hi2c->hdmatx->XferCpltCallback = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable Acknowledge */
|
||||||
|
CLEAR_BIT(hi2c->Instance->CR1, I2C_CR1_ACK);
|
||||||
|
|
||||||
|
hi2c->XferSize = 0U;
|
||||||
|
hi2c->XferCount = 0U;
|
||||||
|
|
||||||
|
/* Disable I2C peripheral to prevent dummy data in buffer */
|
||||||
|
__HAL_I2C_DISABLE(hi2c);
|
||||||
|
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3243,6 +3310,27 @@ HAL_StatusTypeDef HAL_I2C_Mem_Read_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddr
|
||||||
/* Send Slave Address and Memory Address */
|
/* Send Slave Address and Memory Address */
|
||||||
if (I2C_RequestMemoryRead(hi2c, DevAddress, MemAddress, MemAddSize, I2C_TIMEOUT_FLAG, tickstart) != HAL_OK)
|
if (I2C_RequestMemoryRead(hi2c, DevAddress, MemAddress, MemAddSize, I2C_TIMEOUT_FLAG, tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Abort the ongoing DMA */
|
||||||
|
dmaxferstatus = HAL_DMA_Abort_IT(hi2c->hdmarx);
|
||||||
|
|
||||||
|
/* Prevent unused argument(s) compilation and MISRA warning */
|
||||||
|
UNUSED(dmaxferstatus);
|
||||||
|
|
||||||
|
/* Clear directly Complete callback as no XferAbortCallback is used to finalize Abort treatment */
|
||||||
|
if (hi2c->hdmarx != NULL)
|
||||||
|
{
|
||||||
|
hi2c->hdmarx->XferCpltCallback = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable Acknowledge */
|
||||||
|
CLEAR_BIT(hi2c->Instance->CR1, I2C_CR1_ACK);
|
||||||
|
|
||||||
|
hi2c->XferSize = 0U;
|
||||||
|
hi2c->XferCount = 0U;
|
||||||
|
|
||||||
|
/* Disable I2C peripheral to prevent dummy data in buffer */
|
||||||
|
__HAL_I2C_DISABLE(hi2c);
|
||||||
|
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3367,7 +3455,11 @@ HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAdd
|
||||||
/* Wait until SB flag is set */
|
/* Wait until SB flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, tickstart) != HAL_OK)
|
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
if (READ_BIT(hi2c->Instance->CR1, I2C_CR1_START) == I2C_CR1_START)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode = HAL_I2C_WRONG_START;
|
||||||
|
}
|
||||||
|
return HAL_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Send slave address */
|
/* Send slave address */
|
||||||
|
@ -3469,7 +3561,7 @@ HAL_StatusTypeDef HAL_I2C_Master_Seq_Transmit_IT(I2C_HandleTypeDef *hi2c, uint16
|
||||||
if (hi2c->State == HAL_I2C_STATE_READY)
|
if (hi2c->State == HAL_I2C_STATE_READY)
|
||||||
{
|
{
|
||||||
/* Check Busy Flag only if FIRST call of Master interface */
|
/* Check Busy Flag only if FIRST call of Master interface */
|
||||||
if ((XferOptions == I2C_FIRST_AND_LAST_FRAME) || (XferOptions == I2C_FIRST_FRAME))
|
if ((READ_BIT(hi2c->Instance->CR1, I2C_CR1_STOP) == I2C_CR1_STOP) || (XferOptions == I2C_FIRST_AND_LAST_FRAME) || (XferOptions == I2C_FIRST_FRAME))
|
||||||
{
|
{
|
||||||
/* Wait until BUSY flag is reset */
|
/* Wait until BUSY flag is reset */
|
||||||
count = I2C_TIMEOUT_BUSY_FLAG * (SystemCoreClock / 25U / 1000U);
|
count = I2C_TIMEOUT_BUSY_FLAG * (SystemCoreClock / 25U / 1000U);
|
||||||
|
@ -3568,7 +3660,7 @@ HAL_StatusTypeDef HAL_I2C_Master_Seq_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint1
|
||||||
if (hi2c->State == HAL_I2C_STATE_READY)
|
if (hi2c->State == HAL_I2C_STATE_READY)
|
||||||
{
|
{
|
||||||
/* Check Busy Flag only if FIRST call of Master interface */
|
/* Check Busy Flag only if FIRST call of Master interface */
|
||||||
if ((XferOptions == I2C_FIRST_AND_LAST_FRAME) || (XferOptions == I2C_FIRST_FRAME))
|
if ((READ_BIT(hi2c->Instance->CR1, I2C_CR1_STOP) == I2C_CR1_STOP) || (XferOptions == I2C_FIRST_AND_LAST_FRAME) || (XferOptions == I2C_FIRST_FRAME))
|
||||||
{
|
{
|
||||||
/* Wait until BUSY flag is reset */
|
/* Wait until BUSY flag is reset */
|
||||||
count = I2C_TIMEOUT_BUSY_FLAG * (SystemCoreClock / 25U / 1000U);
|
count = I2C_TIMEOUT_BUSY_FLAG * (SystemCoreClock / 25U / 1000U);
|
||||||
|
@ -3734,7 +3826,7 @@ HAL_StatusTypeDef HAL_I2C_Master_Seq_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_
|
||||||
if (hi2c->State == HAL_I2C_STATE_READY)
|
if (hi2c->State == HAL_I2C_STATE_READY)
|
||||||
{
|
{
|
||||||
/* Check Busy Flag only if FIRST call of Master interface */
|
/* Check Busy Flag only if FIRST call of Master interface */
|
||||||
if ((XferOptions == I2C_FIRST_AND_LAST_FRAME) || (XferOptions == I2C_FIRST_FRAME))
|
if ((READ_BIT(hi2c->Instance->CR1, I2C_CR1_STOP) == I2C_CR1_STOP) || (XferOptions == I2C_FIRST_AND_LAST_FRAME) || (XferOptions == I2C_FIRST_FRAME))
|
||||||
{
|
{
|
||||||
/* Wait until BUSY flag is reset */
|
/* Wait until BUSY flag is reset */
|
||||||
count = I2C_TIMEOUT_BUSY_FLAG * (SystemCoreClock / 25U / 1000U);
|
count = I2C_TIMEOUT_BUSY_FLAG * (SystemCoreClock / 25U / 1000U);
|
||||||
|
@ -3859,7 +3951,7 @@ HAL_StatusTypeDef HAL_I2C_Master_Seq_Receive_DMA(I2C_HandleTypeDef *hi2c, uint16
|
||||||
if (hi2c->State == HAL_I2C_STATE_READY)
|
if (hi2c->State == HAL_I2C_STATE_READY)
|
||||||
{
|
{
|
||||||
/* Check Busy Flag only if FIRST call of Master interface */
|
/* Check Busy Flag only if FIRST call of Master interface */
|
||||||
if ((XferOptions == I2C_FIRST_AND_LAST_FRAME) || (XferOptions == I2C_FIRST_FRAME))
|
if ((READ_BIT(hi2c->Instance->CR1, I2C_CR1_STOP) == I2C_CR1_STOP) || (XferOptions == I2C_FIRST_AND_LAST_FRAME) || (XferOptions == I2C_FIRST_FRAME))
|
||||||
{
|
{
|
||||||
/* Wait until BUSY flag is reset */
|
/* Wait until BUSY flag is reset */
|
||||||
count = I2C_TIMEOUT_BUSY_FLAG * (SystemCoreClock / 25U / 1000U);
|
count = I2C_TIMEOUT_BUSY_FLAG * (SystemCoreClock / 25U / 1000U);
|
||||||
|
@ -4561,11 +4653,14 @@ HAL_StatusTypeDef HAL_I2C_DisableListen_IT(I2C_HandleTypeDef *hi2c)
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_I2C_Master_Abort_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress)
|
HAL_StatusTypeDef HAL_I2C_Master_Abort_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress)
|
||||||
{
|
{
|
||||||
|
/* Declaration of temporary variables to prevent undefined behavior of volatile usage */
|
||||||
|
HAL_I2C_ModeTypeDef CurrentMode = hi2c->Mode;
|
||||||
|
|
||||||
/* Prevent unused argument(s) compilation warning */
|
/* Prevent unused argument(s) compilation warning */
|
||||||
UNUSED(DevAddress);
|
UNUSED(DevAddress);
|
||||||
|
|
||||||
/* Abort Master transfer during Receive or Transmit process */
|
/* Abort Master transfer during Receive or Transmit process */
|
||||||
if (hi2c->Mode == HAL_I2C_MODE_MASTER)
|
if ((__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) != RESET) && (CurrentMode == HAL_I2C_MODE_MASTER))
|
||||||
{
|
{
|
||||||
/* Process Locked */
|
/* Process Locked */
|
||||||
__HAL_LOCK(hi2c);
|
__HAL_LOCK(hi2c);
|
||||||
|
@ -4596,6 +4691,7 @@ HAL_StatusTypeDef HAL_I2C_Master_Abort_IT(I2C_HandleTypeDef *hi2c, uint16_t DevA
|
||||||
{
|
{
|
||||||
/* Wrong usage of abort function */
|
/* Wrong usage of abort function */
|
||||||
/* This function should be used only in case of abort monitored by master device */
|
/* This function should be used only in case of abort monitored by master device */
|
||||||
|
/* Or periphal is not in busy state, mean there is no active sequence to be abort */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4667,7 +4763,14 @@ void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c)
|
||||||
/* BTF set -------------------------------------------------------------*/
|
/* BTF set -------------------------------------------------------------*/
|
||||||
else if ((I2C_CHECK_FLAG(sr1itflags, I2C_FLAG_BTF) != RESET) && (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_EVT) != RESET))
|
else if ((I2C_CHECK_FLAG(sr1itflags, I2C_FLAG_BTF) != RESET) && (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_EVT) != RESET))
|
||||||
{
|
{
|
||||||
I2C_MasterTransmit_BTF(hi2c);
|
if (CurrentMode == HAL_I2C_MODE_MASTER)
|
||||||
|
{
|
||||||
|
I2C_MasterTransmit_BTF(hi2c);
|
||||||
|
}
|
||||||
|
else /* HAL_I2C_MODE_MEM */
|
||||||
|
{
|
||||||
|
I2C_MemoryTransmit_TXE_BTF(hi2c);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -4782,6 +4885,7 @@ void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c)
|
||||||
uint32_t sr1itflags = READ_REG(hi2c->Instance->SR1);
|
uint32_t sr1itflags = READ_REG(hi2c->Instance->SR1);
|
||||||
uint32_t itsources = READ_REG(hi2c->Instance->CR2);
|
uint32_t itsources = READ_REG(hi2c->Instance->CR2);
|
||||||
uint32_t error = HAL_I2C_ERROR_NONE;
|
uint32_t error = HAL_I2C_ERROR_NONE;
|
||||||
|
HAL_I2C_ModeTypeDef CurrentMode = hi2c->Mode;
|
||||||
|
|
||||||
/* I2C Bus error interrupt occurred ----------------------------------------*/
|
/* I2C Bus error interrupt occurred ----------------------------------------*/
|
||||||
if ((I2C_CHECK_FLAG(sr1itflags, I2C_FLAG_BERR) != RESET) && (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERR) != RESET))
|
if ((I2C_CHECK_FLAG(sr1itflags, I2C_FLAG_BERR) != RESET) && (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERR) != RESET))
|
||||||
|
@ -4807,7 +4911,7 @@ void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c)
|
||||||
/* I2C Acknowledge failure error interrupt occurred ------------------------*/
|
/* I2C Acknowledge failure error interrupt occurred ------------------------*/
|
||||||
if ((I2C_CHECK_FLAG(sr1itflags, I2C_FLAG_AF) != RESET) && (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERR) != RESET))
|
if ((I2C_CHECK_FLAG(sr1itflags, I2C_FLAG_AF) != RESET) && (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERR) != RESET))
|
||||||
{
|
{
|
||||||
tmp1 = hi2c->Mode;
|
tmp1 = CurrentMode;
|
||||||
tmp2 = hi2c->XferCount;
|
tmp2 = hi2c->XferCount;
|
||||||
tmp3 = hi2c->State;
|
tmp3 = hi2c->State;
|
||||||
tmp4 = hi2c->PreviousState;
|
tmp4 = hi2c->PreviousState;
|
||||||
|
@ -4825,7 +4929,7 @@ void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c)
|
||||||
error |= HAL_I2C_ERROR_AF;
|
error |= HAL_I2C_ERROR_AF;
|
||||||
|
|
||||||
/* Do not generate a STOP in case of Slave receive non acknowledge during transfer (mean not at the end of transfer) */
|
/* Do not generate a STOP in case of Slave receive non acknowledge during transfer (mean not at the end of transfer) */
|
||||||
if (hi2c->Mode == HAL_I2C_MODE_MASTER)
|
if ((CurrentMode == HAL_I2C_MODE_MASTER) || (CurrentMode == HAL_I2C_MODE_MEM))
|
||||||
{
|
{
|
||||||
/* Generate Stop */
|
/* Generate Stop */
|
||||||
SET_BIT(hi2c->Instance->CR1, I2C_CR1_STOP);
|
SET_BIT(hi2c->Instance->CR1, I2C_CR1_STOP);
|
||||||
|
@ -5150,59 +5254,7 @@ static void I2C_MasterTransmit_TXE(I2C_HandleTypeDef *hi2c)
|
||||||
{
|
{
|
||||||
if (hi2c->Mode == HAL_I2C_MODE_MEM)
|
if (hi2c->Mode == HAL_I2C_MODE_MEM)
|
||||||
{
|
{
|
||||||
if (hi2c->EventCount == 0U)
|
I2C_MemoryTransmit_TXE_BTF(hi2c);
|
||||||
{
|
|
||||||
/* If Memory address size is 8Bit */
|
|
||||||
if (hi2c->MemaddSize == I2C_MEMADD_SIZE_8BIT)
|
|
||||||
{
|
|
||||||
/* Send Memory Address */
|
|
||||||
hi2c->Instance->DR = I2C_MEM_ADD_LSB(hi2c->Memaddress);
|
|
||||||
|
|
||||||
hi2c->EventCount += 2U;
|
|
||||||
}
|
|
||||||
/* If Memory address size is 16Bit */
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Send MSB of Memory Address */
|
|
||||||
hi2c->Instance->DR = I2C_MEM_ADD_MSB(hi2c->Memaddress);
|
|
||||||
|
|
||||||
hi2c->EventCount++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (hi2c->EventCount == 1U)
|
|
||||||
{
|
|
||||||
/* Send LSB of Memory Address */
|
|
||||||
hi2c->Instance->DR = I2C_MEM_ADD_LSB(hi2c->Memaddress);
|
|
||||||
|
|
||||||
hi2c->EventCount++;
|
|
||||||
}
|
|
||||||
else if (hi2c->EventCount == 2U)
|
|
||||||
{
|
|
||||||
if (hi2c->State == HAL_I2C_STATE_BUSY_RX)
|
|
||||||
{
|
|
||||||
/* Generate Restart */
|
|
||||||
hi2c->Instance->CR1 |= I2C_CR1_START;
|
|
||||||
}
|
|
||||||
else if (hi2c->State == HAL_I2C_STATE_BUSY_TX)
|
|
||||||
{
|
|
||||||
/* Write data to DR */
|
|
||||||
hi2c->Instance->DR = *hi2c->pBuffPtr;
|
|
||||||
|
|
||||||
/* Increment Buffer pointer */
|
|
||||||
hi2c->pBuffPtr++;
|
|
||||||
|
|
||||||
/* Update counter */
|
|
||||||
hi2c->XferCount--;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Do nothing */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Do nothing */
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -5274,29 +5326,104 @@ static void I2C_MasterTransmit_BTF(I2C_HandleTypeDef *hi2c)
|
||||||
|
|
||||||
hi2c->PreviousState = I2C_STATE_NONE;
|
hi2c->PreviousState = I2C_STATE_NONE;
|
||||||
hi2c->State = HAL_I2C_STATE_READY;
|
hi2c->State = HAL_I2C_STATE_READY;
|
||||||
|
hi2c->Mode = HAL_I2C_MODE_NONE;
|
||||||
if (hi2c->Mode == HAL_I2C_MODE_MEM)
|
|
||||||
{
|
|
||||||
hi2c->Mode = HAL_I2C_MODE_NONE;
|
|
||||||
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
|
||||||
hi2c->MemTxCpltCallback(hi2c);
|
|
||||||
#else
|
|
||||||
HAL_I2C_MemTxCpltCallback(hi2c);
|
|
||||||
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
hi2c->Mode = HAL_I2C_MODE_NONE;
|
|
||||||
|
|
||||||
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
||||||
hi2c->MasterTxCpltCallback(hi2c);
|
hi2c->MasterTxCpltCallback(hi2c);
|
||||||
#else
|
#else
|
||||||
HAL_I2C_MasterTxCpltCallback(hi2c);
|
HAL_I2C_MasterTxCpltCallback(hi2c);
|
||||||
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Do nothing */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Handle TXE and BTF flag for Memory transmitter
|
||||||
|
* @param hi2c Pointer to a I2C_HandleTypeDef structure that contains
|
||||||
|
* the configuration information for I2C module
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
static void I2C_MemoryTransmit_TXE_BTF(I2C_HandleTypeDef *hi2c)
|
||||||
|
{
|
||||||
|
/* Declaration of temporary variables to prevent undefined behavior of volatile usage */
|
||||||
|
HAL_I2C_StateTypeDef CurrentState = hi2c->State;
|
||||||
|
|
||||||
|
if (hi2c->EventCount == 0U)
|
||||||
|
{
|
||||||
|
/* If Memory address size is 8Bit */
|
||||||
|
if (hi2c->MemaddSize == I2C_MEMADD_SIZE_8BIT)
|
||||||
|
{
|
||||||
|
/* Send Memory Address */
|
||||||
|
hi2c->Instance->DR = I2C_MEM_ADD_LSB(hi2c->Memaddress);
|
||||||
|
|
||||||
|
hi2c->EventCount += 2U;
|
||||||
|
}
|
||||||
|
/* If Memory address size is 16Bit */
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Send MSB of Memory Address */
|
||||||
|
hi2c->Instance->DR = I2C_MEM_ADD_MSB(hi2c->Memaddress);
|
||||||
|
|
||||||
|
hi2c->EventCount++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (hi2c->EventCount == 1U)
|
||||||
|
{
|
||||||
|
/* Send LSB of Memory Address */
|
||||||
|
hi2c->Instance->DR = I2C_MEM_ADD_LSB(hi2c->Memaddress);
|
||||||
|
|
||||||
|
hi2c->EventCount++;
|
||||||
|
}
|
||||||
|
else if (hi2c->EventCount == 2U)
|
||||||
|
{
|
||||||
|
if (CurrentState == HAL_I2C_STATE_BUSY_RX)
|
||||||
|
{
|
||||||
|
/* Generate Restart */
|
||||||
|
hi2c->Instance->CR1 |= I2C_CR1_START;
|
||||||
|
}
|
||||||
|
else if ((hi2c->XferCount > 0U) && (CurrentState == HAL_I2C_STATE_BUSY_TX))
|
||||||
|
{
|
||||||
|
/* Write data to DR */
|
||||||
|
hi2c->Instance->DR = *hi2c->pBuffPtr;
|
||||||
|
|
||||||
|
/* Increment Buffer pointer */
|
||||||
|
hi2c->pBuffPtr++;
|
||||||
|
|
||||||
|
/* Update counter */
|
||||||
|
hi2c->XferCount--;
|
||||||
|
}
|
||||||
|
else if ((hi2c->XferCount == 0U) && (CurrentState == HAL_I2C_STATE_BUSY_TX))
|
||||||
|
{
|
||||||
|
/* Generate Stop condition then Call TxCpltCallback() */
|
||||||
|
/* Disable EVT, BUF and ERR interrupt */
|
||||||
|
__HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_BUF | I2C_IT_ERR);
|
||||||
|
|
||||||
|
/* Generate Stop */
|
||||||
|
SET_BIT(hi2c->Instance->CR1, I2C_CR1_STOP);
|
||||||
|
|
||||||
|
hi2c->PreviousState = I2C_STATE_NONE;
|
||||||
|
hi2c->State = HAL_I2C_STATE_READY;
|
||||||
|
hi2c->Mode = HAL_I2C_MODE_NONE;
|
||||||
|
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
||||||
|
hi2c->MemTxCpltCallback(hi2c);
|
||||||
|
#else
|
||||||
|
HAL_I2C_MemTxCpltCallback(hi2c);
|
||||||
|
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Do nothing */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Do nothing */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -5333,43 +5460,70 @@ static void I2C_MasterReceive_RXNE(I2C_HandleTypeDef *hi2c)
|
||||||
}
|
}
|
||||||
else if ((hi2c->XferOptions != I2C_FIRST_AND_NEXT_FRAME) && ((tmp == 1U) || (tmp == 0U)))
|
else if ((hi2c->XferOptions != I2C_FIRST_AND_NEXT_FRAME) && ((tmp == 1U) || (tmp == 0U)))
|
||||||
{
|
{
|
||||||
/* Disable Acknowledge */
|
if (I2C_WaitOnSTOPRequestThroughIT(hi2c) == HAL_OK)
|
||||||
CLEAR_BIT(hi2c->Instance->CR1, I2C_CR1_ACK);
|
|
||||||
|
|
||||||
/* Disable EVT, BUF and ERR interrupt */
|
|
||||||
__HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_BUF | I2C_IT_ERR);
|
|
||||||
|
|
||||||
/* Read data from DR */
|
|
||||||
*hi2c->pBuffPtr = (uint8_t)hi2c->Instance->DR;
|
|
||||||
|
|
||||||
/* Increment Buffer pointer */
|
|
||||||
hi2c->pBuffPtr++;
|
|
||||||
|
|
||||||
/* Update counter */
|
|
||||||
hi2c->XferCount--;
|
|
||||||
|
|
||||||
hi2c->State = HAL_I2C_STATE_READY;
|
|
||||||
|
|
||||||
if (hi2c->Mode == HAL_I2C_MODE_MEM)
|
|
||||||
{
|
{
|
||||||
hi2c->Mode = HAL_I2C_MODE_NONE;
|
/* Disable Acknowledge */
|
||||||
hi2c->PreviousState = I2C_STATE_NONE;
|
CLEAR_BIT(hi2c->Instance->CR1, I2C_CR1_ACK);
|
||||||
|
|
||||||
|
/* Disable EVT, BUF and ERR interrupt */
|
||||||
|
__HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_BUF | I2C_IT_ERR);
|
||||||
|
|
||||||
|
/* Read data from DR */
|
||||||
|
*hi2c->pBuffPtr = (uint8_t)hi2c->Instance->DR;
|
||||||
|
|
||||||
|
/* Increment Buffer pointer */
|
||||||
|
hi2c->pBuffPtr++;
|
||||||
|
|
||||||
|
/* Update counter */
|
||||||
|
hi2c->XferCount--;
|
||||||
|
|
||||||
|
hi2c->State = HAL_I2C_STATE_READY;
|
||||||
|
|
||||||
|
if (hi2c->Mode == HAL_I2C_MODE_MEM)
|
||||||
|
{
|
||||||
|
hi2c->Mode = HAL_I2C_MODE_NONE;
|
||||||
|
hi2c->PreviousState = I2C_STATE_NONE;
|
||||||
|
|
||||||
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
||||||
hi2c->MemRxCpltCallback(hi2c);
|
hi2c->MemRxCpltCallback(hi2c);
|
||||||
#else
|
#else
|
||||||
HAL_I2C_MemRxCpltCallback(hi2c);
|
HAL_I2C_MemRxCpltCallback(hi2c);
|
||||||
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hi2c->Mode = HAL_I2C_MODE_NONE;
|
||||||
|
hi2c->PreviousState = I2C_STATE_MASTER_BUSY_RX;
|
||||||
|
|
||||||
|
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
||||||
|
hi2c->MasterRxCpltCallback(hi2c);
|
||||||
|
#else
|
||||||
|
HAL_I2C_MasterRxCpltCallback(hi2c);
|
||||||
|
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
hi2c->Mode = HAL_I2C_MODE_NONE;
|
/* Disable EVT, BUF and ERR interrupt */
|
||||||
hi2c->PreviousState = I2C_STATE_MASTER_BUSY_RX;
|
__HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_BUF | I2C_IT_ERR);
|
||||||
|
|
||||||
|
/* Read data from DR */
|
||||||
|
*hi2c->pBuffPtr = (uint8_t)hi2c->Instance->DR;
|
||||||
|
|
||||||
|
/* Increment Buffer pointer */
|
||||||
|
hi2c->pBuffPtr++;
|
||||||
|
|
||||||
|
/* Update counter */
|
||||||
|
hi2c->XferCount--;
|
||||||
|
|
||||||
|
hi2c->State = HAL_I2C_STATE_READY;
|
||||||
|
hi2c->Mode = HAL_I2C_MODE_NONE;
|
||||||
|
|
||||||
|
/* Call user error callback */
|
||||||
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
|
||||||
hi2c->MasterRxCpltCallback(hi2c);
|
hi2c->ErrorCallback(hi2c);
|
||||||
#else
|
#else
|
||||||
HAL_I2C_MasterRxCpltCallback(hi2c);
|
HAL_I2C_ErrorCallback(hi2c);
|
||||||
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5540,13 +5694,11 @@ static void I2C_Master_SB(I2C_HandleTypeDef *hi2c)
|
||||||
hi2c->Instance->DR = I2C_7BIT_ADD_READ(hi2c->Devaddress);
|
hi2c->Instance->DR = I2C_7BIT_ADD_READ(hi2c->Devaddress);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((hi2c->hdmatx != NULL) || (hi2c->hdmarx != NULL))
|
if (((hi2c->hdmatx != NULL) && (hi2c->hdmatx->XferCpltCallback != NULL))
|
||||||
|
|| ((hi2c->hdmarx != NULL) && (hi2c->hdmarx->XferCpltCallback != NULL)))
|
||||||
{
|
{
|
||||||
if ((hi2c->hdmatx->XferCpltCallback != NULL) || (hi2c->hdmarx->XferCpltCallback != NULL))
|
/* Enable DMA Request */
|
||||||
{
|
SET_BIT(hi2c->Instance->CR2, I2C_CR2_DMAEN);
|
||||||
/* Enable DMA Request */
|
|
||||||
SET_BIT(hi2c->Instance->CR2, I2C_CR2_DMAEN);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -6159,8 +6311,10 @@ static void I2C_ITError(I2C_HandleTypeDef *hi2c)
|
||||||
{
|
{
|
||||||
/* Declaration of temporary variable to prevent undefined behavior of volatile usage */
|
/* Declaration of temporary variable to prevent undefined behavior of volatile usage */
|
||||||
HAL_I2C_StateTypeDef CurrentState = hi2c->State;
|
HAL_I2C_StateTypeDef CurrentState = hi2c->State;
|
||||||
|
HAL_I2C_ModeTypeDef CurrentMode = hi2c->Mode;
|
||||||
|
uint32_t CurrentError;
|
||||||
|
|
||||||
if ((hi2c->Mode == HAL_I2C_MODE_MASTER) && (CurrentState == HAL_I2C_STATE_BUSY_RX))
|
if (((CurrentMode == HAL_I2C_MODE_MASTER) || (CurrentMode == HAL_I2C_MODE_MEM)) && (CurrentState == HAL_I2C_STATE_BUSY_RX))
|
||||||
{
|
{
|
||||||
/* Disable Pos bit in I2C CR1 when error occurred in Master/Mem Receive IT Process */
|
/* Disable Pos bit in I2C CR1 when error occurred in Master/Mem Receive IT Process */
|
||||||
hi2c->Instance->CR1 &= ~I2C_CR1_POS;
|
hi2c->Instance->CR1 &= ~I2C_CR1_POS;
|
||||||
|
@ -6179,9 +6333,9 @@ static void I2C_ITError(I2C_HandleTypeDef *hi2c)
|
||||||
if ((READ_BIT(hi2c->Instance->CR2, I2C_CR2_DMAEN) != I2C_CR2_DMAEN) && (CurrentState != HAL_I2C_STATE_ABORT))
|
if ((READ_BIT(hi2c->Instance->CR2, I2C_CR2_DMAEN) != I2C_CR2_DMAEN) && (CurrentState != HAL_I2C_STATE_ABORT))
|
||||||
{
|
{
|
||||||
hi2c->State = HAL_I2C_STATE_READY;
|
hi2c->State = HAL_I2C_STATE_READY;
|
||||||
|
hi2c->Mode = HAL_I2C_MODE_NONE;
|
||||||
}
|
}
|
||||||
hi2c->PreviousState = I2C_STATE_NONE;
|
hi2c->PreviousState = I2C_STATE_NONE;
|
||||||
hi2c->Mode = HAL_I2C_MODE_NONE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Abort DMA transfer */
|
/* Abort DMA transfer */
|
||||||
|
@ -6278,15 +6432,24 @@ static void I2C_ITError(I2C_HandleTypeDef *hi2c)
|
||||||
HAL_I2C_ErrorCallback(hi2c);
|
HAL_I2C_ErrorCallback(hi2c);
|
||||||
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
|
||||||
}
|
}
|
||||||
/* STOP Flag is not set after a NACK reception */
|
|
||||||
|
/* STOP Flag is not set after a NACK reception, BusError, ArbitrationLost, OverRun */
|
||||||
|
CurrentError = hi2c->ErrorCode;
|
||||||
|
|
||||||
|
if (((CurrentError & HAL_I2C_ERROR_BERR) == HAL_I2C_ERROR_BERR) || \
|
||||||
|
((CurrentError & HAL_I2C_ERROR_ARLO) == HAL_I2C_ERROR_ARLO) || \
|
||||||
|
((CurrentError & HAL_I2C_ERROR_AF) == HAL_I2C_ERROR_AF) || \
|
||||||
|
((CurrentError & HAL_I2C_ERROR_OVR) == HAL_I2C_ERROR_OVR))
|
||||||
|
{
|
||||||
|
/* Disable EVT, BUF and ERR interrupt */
|
||||||
|
__HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_BUF | I2C_IT_ERR);
|
||||||
|
}
|
||||||
|
|
||||||
/* So may inform upper layer that listen phase is stopped */
|
/* So may inform upper layer that listen phase is stopped */
|
||||||
/* during NACK error treatment */
|
/* during NACK error treatment */
|
||||||
CurrentState = hi2c->State;
|
CurrentState = hi2c->State;
|
||||||
if (((hi2c->ErrorCode & HAL_I2C_ERROR_AF) == HAL_I2C_ERROR_AF) && (CurrentState == HAL_I2C_STATE_LISTEN))
|
if (((hi2c->ErrorCode & HAL_I2C_ERROR_AF) == HAL_I2C_ERROR_AF) && (CurrentState == HAL_I2C_STATE_LISTEN))
|
||||||
{
|
{
|
||||||
/* Disable EVT, BUF and ERR interrupt */
|
|
||||||
__HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_BUF | I2C_IT_ERR);
|
|
||||||
|
|
||||||
hi2c->XferOptions = I2C_NO_OPTION_FRAME;
|
hi2c->XferOptions = I2C_NO_OPTION_FRAME;
|
||||||
hi2c->PreviousState = I2C_STATE_NONE;
|
hi2c->PreviousState = I2C_STATE_NONE;
|
||||||
hi2c->State = HAL_I2C_STATE_READY;
|
hi2c->State = HAL_I2C_STATE_READY;
|
||||||
|
@ -6334,7 +6497,11 @@ static HAL_StatusTypeDef I2C_MasterRequestWrite(I2C_HandleTypeDef *hi2c, uint16_
|
||||||
/* Wait until SB flag is set */
|
/* Wait until SB flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
if (READ_BIT(hi2c->Instance->CR1, I2C_CR1_START) == I2C_CR1_START)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode = HAL_I2C_WRONG_START;
|
||||||
|
}
|
||||||
|
return HAL_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_7BIT)
|
if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_7BIT)
|
||||||
|
@ -6403,7 +6570,11 @@ static HAL_StatusTypeDef I2C_MasterRequestRead(I2C_HandleTypeDef *hi2c, uint16_t
|
||||||
/* Wait until SB flag is set */
|
/* Wait until SB flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
if (READ_BIT(hi2c->Instance->CR1, I2C_CR1_START) == I2C_CR1_START)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode = HAL_I2C_WRONG_START;
|
||||||
|
}
|
||||||
|
return HAL_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_7BIT)
|
if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_7BIT)
|
||||||
|
@ -6440,7 +6611,11 @@ static HAL_StatusTypeDef I2C_MasterRequestRead(I2C_HandleTypeDef *hi2c, uint16_t
|
||||||
/* Wait until SB flag is set */
|
/* Wait until SB flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
if (READ_BIT(hi2c->Instance->CR1, I2C_CR1_START) == I2C_CR1_START)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode = HAL_I2C_WRONG_START;
|
||||||
|
}
|
||||||
|
return HAL_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Send header of slave address */
|
/* Send header of slave address */
|
||||||
|
@ -6476,7 +6651,11 @@ static HAL_StatusTypeDef I2C_RequestMemoryWrite(I2C_HandleTypeDef *hi2c, uint16_
|
||||||
/* Wait until SB flag is set */
|
/* Wait until SB flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
if (READ_BIT(hi2c->Instance->CR1, I2C_CR1_START) == I2C_CR1_START)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode = HAL_I2C_WRONG_START;
|
||||||
|
}
|
||||||
|
return HAL_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Send slave address */
|
/* Send slave address */
|
||||||
|
@ -6555,7 +6734,11 @@ static HAL_StatusTypeDef I2C_RequestMemoryRead(I2C_HandleTypeDef *hi2c, uint16_t
|
||||||
/* Wait until SB flag is set */
|
/* Wait until SB flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
if (READ_BIT(hi2c->Instance->CR1, I2C_CR1_START) == I2C_CR1_START)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode = HAL_I2C_WRONG_START;
|
||||||
|
}
|
||||||
|
return HAL_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Send slave address */
|
/* Send slave address */
|
||||||
|
@ -6625,7 +6808,11 @@ static HAL_StatusTypeDef I2C_RequestMemoryRead(I2C_HandleTypeDef *hi2c, uint16_t
|
||||||
/* Wait until SB flag is set */
|
/* Wait until SB flag is set */
|
||||||
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_SB, RESET, Timeout, Tickstart) != HAL_OK)
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
if (READ_BIT(hi2c->Instance->CR1, I2C_CR1_START) == I2C_CR1_START)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode = HAL_I2C_WRONG_START;
|
||||||
|
}
|
||||||
|
return HAL_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Send slave address */
|
/* Send slave address */
|
||||||
|
@ -6658,8 +6845,14 @@ static void I2C_DMAXferCplt(DMA_HandleTypeDef *hdma)
|
||||||
__HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_ERR);
|
__HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_ERR);
|
||||||
|
|
||||||
/* Clear Complete callback */
|
/* Clear Complete callback */
|
||||||
hi2c->hdmatx->XferCpltCallback = NULL;
|
if (hi2c->hdmatx != NULL)
|
||||||
hi2c->hdmarx->XferCpltCallback = NULL;
|
{
|
||||||
|
hi2c->hdmatx->XferCpltCallback = NULL;
|
||||||
|
}
|
||||||
|
if (hi2c->hdmarx != NULL)
|
||||||
|
{
|
||||||
|
hi2c->hdmarx->XferCpltCallback = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if ((((uint32_t)CurrentState & (uint32_t)HAL_I2C_STATE_BUSY_TX) == (uint32_t)HAL_I2C_STATE_BUSY_TX) || ((((uint32_t)CurrentState & (uint32_t)HAL_I2C_STATE_BUSY_RX) == (uint32_t)HAL_I2C_STATE_BUSY_RX) && (CurrentMode == HAL_I2C_MODE_SLAVE)))
|
if ((((uint32_t)CurrentState & (uint32_t)HAL_I2C_STATE_BUSY_TX) == (uint32_t)HAL_I2C_STATE_BUSY_TX) || ((((uint32_t)CurrentState & (uint32_t)HAL_I2C_STATE_BUSY_RX) == (uint32_t)HAL_I2C_STATE_BUSY_RX) && (CurrentMode == HAL_I2C_MODE_SLAVE)))
|
||||||
{
|
{
|
||||||
|
@ -6782,8 +6975,14 @@ static void I2C_DMAError(DMA_HandleTypeDef *hdma)
|
||||||
I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */
|
I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */
|
||||||
|
|
||||||
/* Clear Complete callback */
|
/* Clear Complete callback */
|
||||||
hi2c->hdmatx->XferCpltCallback = NULL;
|
if (hi2c->hdmatx != NULL)
|
||||||
hi2c->hdmarx->XferCpltCallback = NULL;
|
{
|
||||||
|
hi2c->hdmatx->XferCpltCallback = NULL;
|
||||||
|
}
|
||||||
|
if (hi2c->hdmarx != NULL)
|
||||||
|
{
|
||||||
|
hi2c->hdmarx->XferCpltCallback = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* Disable Acknowledge */
|
/* Disable Acknowledge */
|
||||||
CLEAR_BIT(hi2c->Instance->CR1, I2C_CR1_ACK);
|
CLEAR_BIT(hi2c->Instance->CR1, I2C_CR1_ACK);
|
||||||
|
@ -6808,14 +7007,35 @@ static void I2C_DMAError(DMA_HandleTypeDef *hdma)
|
||||||
*/
|
*/
|
||||||
static void I2C_DMAAbort(DMA_HandleTypeDef *hdma)
|
static void I2C_DMAAbort(DMA_HandleTypeDef *hdma)
|
||||||
{
|
{
|
||||||
|
__IO uint32_t count = 0U;
|
||||||
I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */
|
I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */
|
||||||
|
|
||||||
/* Declaration of temporary variable to prevent undefined behavior of volatile usage */
|
/* Declaration of temporary variable to prevent undefined behavior of volatile usage */
|
||||||
HAL_I2C_StateTypeDef CurrentState = hi2c->State;
|
HAL_I2C_StateTypeDef CurrentState = hi2c->State;
|
||||||
|
|
||||||
|
/* During abort treatment, check that there is no pending STOP request */
|
||||||
|
/* Wait until STOP flag is reset */
|
||||||
|
count = I2C_TIMEOUT_FLAG * (SystemCoreClock / 25U / 1000U);
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if (count == 0U)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
count--;
|
||||||
|
}
|
||||||
|
while (READ_BIT(hi2c->Instance->CR1, I2C_CR1_STOP) == I2C_CR1_STOP);
|
||||||
|
|
||||||
/* Clear Complete callback */
|
/* Clear Complete callback */
|
||||||
hi2c->hdmatx->XferCpltCallback = NULL;
|
if (hi2c->hdmatx != NULL)
|
||||||
hi2c->hdmarx->XferCpltCallback = NULL;
|
{
|
||||||
|
hi2c->hdmatx->XferCpltCallback = NULL;
|
||||||
|
}
|
||||||
|
if (hi2c->hdmarx != NULL)
|
||||||
|
{
|
||||||
|
hi2c->hdmarx->XferCpltCallback = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* Disable Acknowledge */
|
/* Disable Acknowledge */
|
||||||
CLEAR_BIT(hi2c->Instance->CR1, I2C_CR1_ACK);
|
CLEAR_BIT(hi2c->Instance->CR1, I2C_CR1_ACK);
|
||||||
|
@ -6823,8 +7043,14 @@ static void I2C_DMAAbort(DMA_HandleTypeDef *hdma)
|
||||||
hi2c->XferCount = 0U;
|
hi2c->XferCount = 0U;
|
||||||
|
|
||||||
/* Reset XferAbortCallback */
|
/* Reset XferAbortCallback */
|
||||||
hi2c->hdmatx->XferAbortCallback = NULL;
|
if (hi2c->hdmatx != NULL)
|
||||||
hi2c->hdmarx->XferAbortCallback = NULL;
|
{
|
||||||
|
hi2c->hdmatx->XferAbortCallback = NULL;
|
||||||
|
}
|
||||||
|
if (hi2c->hdmarx != NULL)
|
||||||
|
{
|
||||||
|
hi2c->hdmarx->XferAbortCallback = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* Disable I2C peripheral to prevent dummy data in buffer */
|
/* Disable I2C peripheral to prevent dummy data in buffer */
|
||||||
__HAL_I2C_DISABLE(hi2c);
|
__HAL_I2C_DISABLE(hi2c);
|
||||||
|
@ -7070,6 +7296,33 @@ static HAL_StatusTypeDef I2C_WaitOnSTOPFlagUntilTimeout(I2C_HandleTypeDef *hi2c,
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function handles I2C Communication Timeout for specific usage of STOP request through Interrupt.
|
||||||
|
* @param hi2c Pointer to a I2C_HandleTypeDef structure that contains
|
||||||
|
* the configuration information for the specified I2C.
|
||||||
|
* @retval HAL status
|
||||||
|
*/
|
||||||
|
static HAL_StatusTypeDef I2C_WaitOnSTOPRequestThroughIT(I2C_HandleTypeDef *hi2c)
|
||||||
|
{
|
||||||
|
__IO uint32_t count = 0U;
|
||||||
|
|
||||||
|
/* Wait until STOP flag is reset */
|
||||||
|
count = I2C_TIMEOUT_STOP_FLAG * (SystemCoreClock / 25U / 1000U);
|
||||||
|
do
|
||||||
|
{
|
||||||
|
count--;
|
||||||
|
if (count == 0U)
|
||||||
|
{
|
||||||
|
hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
|
||||||
|
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (READ_BIT(hi2c->Instance->CR1, I2C_CR1_STOP) == I2C_CR1_STOP);
|
||||||
|
|
||||||
|
return HAL_OK;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function handles I2C Communication Timeout for specific usage of RXNE flag.
|
* @brief This function handles I2C Communication Timeout for specific usage of RXNE flag.
|
||||||
* @param hi2c Pointer to a I2C_HandleTypeDef structure that contains
|
* @param hi2c Pointer to a I2C_HandleTypeDef structure that contains
|
||||||
|
|
|
@ -16,45 +16,56 @@
|
||||||
(+) The IWDG can be started by either software or hardware (configurable
|
(+) The IWDG can be started by either software or hardware (configurable
|
||||||
through option byte).
|
through option byte).
|
||||||
|
|
||||||
(+) The IWDG is clocked by Low-Speed clock (LSI) and thus stays active even
|
(+) The IWDG is clocked by the Low-Speed Internal clock (LSI) and thus stays
|
||||||
if the main clock fails.
|
active even if the main clock fails.
|
||||||
|
|
||||||
(+) Once the IWDG is started, the LSI is forced ON and both can not be
|
(+) Once the IWDG is started, the LSI is forced ON and both cannot be
|
||||||
disabled. The counter starts counting down from the reset value (0xFFF).
|
disabled. The counter starts counting down from the reset value (0xFFF).
|
||||||
When it reaches the end of count value (0x000) a reset signal is
|
When it reaches the end of count value (0x000) a reset signal is
|
||||||
generated (IWDG reset).
|
generated (IWDG reset).
|
||||||
|
|
||||||
(+) Whenever the key value 0x0000 AAAA is written in the IWDG_KR register,
|
(+) Whenever the key value 0x0000 AAAA is written in the IWDG_KR register,
|
||||||
the IWDG_RLR value is reloaded in the counter and the watchdog reset is
|
the IWDG_RLR value is reloaded into the counter and the watchdog reset
|
||||||
prevented.
|
is prevented.
|
||||||
|
|
||||||
(+) The IWDG is implemented in the VDD voltage domain that is still functional
|
(+) The IWDG is implemented in the VDD voltage domain that is still functional
|
||||||
in STOP and STANDBY mode (IWDG reset can wake-up from STANDBY).
|
in STOP and STANDBY mode (IWDG reset can wake up the CPU from STANDBY).
|
||||||
IWDGRST flag in RCC_CSR register can be used to inform when an IWDG
|
IWDGRST flag in RCC_CSR register can be used to inform when an IWDG
|
||||||
reset occurs.
|
reset occurs.
|
||||||
|
|
||||||
(+) Debug mode : When the microcontroller enters debug mode (core halted),
|
(+) Debug mode: When the microcontroller enters debug mode (core halted),
|
||||||
the IWDG counter either continues to work normally or stops, depending
|
the IWDG counter either continues to work normally or stops, depending
|
||||||
on DBG_IWDG_STOP configuration bit in DBG module, accessible through
|
on DBG_IWDG_STOP configuration bit in DBG module, accessible through
|
||||||
__HAL_DBGMCU_FREEZE_IWDG() and __HAL_DBGMCU_UNFREEZE_IWDG() macros
|
__HAL_DBGMCU_FREEZE_IWDG() and __HAL_DBGMCU_UNFREEZE_IWDG() macros.
|
||||||
|
|
||||||
[..] Min-max timeout value @32KHz (LSI): ~125us / ~32.7s
|
[..] Min-max timeout value @32KHz (LSI): ~125us / ~32.7s
|
||||||
The IWDG timeout may vary due to LSI frequency dispersion. STM32F1xx
|
The IWDG timeout may vary due to LSI clock frequency dispersion.
|
||||||
devices provide the capability to measure the LSI frequency (LSI clock
|
STM32F1xx devices provide the capability to measure the LSI clock
|
||||||
connected internally to TIM5 CH4 input capture). The measured value
|
frequency (LSI clock is internally connected to TIM5 CH4 input capture).
|
||||||
can be used to have an IWDG timeout with an acceptable accuracy.
|
The measured value can be used to have an IWDG timeout with an
|
||||||
|
acceptable accuracy.
|
||||||
|
|
||||||
|
[..] Default timeout value (necessary for IWDG_SR status register update):
|
||||||
|
Constant LSI_VALUE is defined based on the nominal LSI clock frequency.
|
||||||
|
This frequency being subject to variations as mentioned above, the
|
||||||
|
default timeout value (defined through constant HAL_IWDG_DEFAULT_TIMEOUT
|
||||||
|
below) may become too short or too long.
|
||||||
|
In such cases, this default timeout value can be tuned by redefining
|
||||||
|
the constant LSI_VALUE at user-application level (based, for instance,
|
||||||
|
on the measured LSI clock frequency as explained above).
|
||||||
|
|
||||||
##### How to use this driver #####
|
##### How to use this driver #####
|
||||||
==============================================================================
|
==============================================================================
|
||||||
[..]
|
[..]
|
||||||
(#) Use IWDG using HAL_IWDG_Init() function to :
|
(#) Use IWDG using HAL_IWDG_Init() function to :
|
||||||
(++) Enable instance by writing Start keyword in IWDG_KEY register. LSI
|
(++) Enable instance by writing Start keyword in IWDG_KEY register. LSI
|
||||||
clock is forced ON and IWDG counter starts downcounting.
|
clock is forced ON and IWDG counter starts counting down.
|
||||||
(++) Enable write access to configuration register: IWDG_PR & IWDG_RLR.
|
(++) Enable write access to configuration registers:
|
||||||
|
IWDG_PR and IWDG_RLR.
|
||||||
(++) Configure the IWDG prescaler and counter reload value. This reload
|
(++) Configure the IWDG prescaler and counter reload value. This reload
|
||||||
value will be loaded in the IWDG counter each time the watchdog is
|
value will be loaded in the IWDG counter each time the watchdog is
|
||||||
reloaded, then the IWDG will start counting down from this value.
|
reloaded, then the IWDG will start counting down from this value.
|
||||||
(++) wait for status flags to be reset"
|
(++) Wait for status flags to be reset.
|
||||||
|
|
||||||
(#) Then the application program must refresh the IWDG counter at regular
|
(#) Then the application program must refresh the IWDG counter at regular
|
||||||
intervals during normal operation to prevent an MCU reset, using
|
intervals during normal operation to prevent an MCU reset, using
|
||||||
|
@ -91,7 +102,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAL_IWDG_MODULE_ENABLED
|
#ifdef HAL_IWDG_MODULE_ENABLED
|
||||||
/** @defgroup IWDG IWDG
|
/** @addtogroup IWDG
|
||||||
* @brief IWDG HAL module driver.
|
* @brief IWDG HAL module driver.
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
@ -101,10 +112,14 @@
|
||||||
/** @defgroup IWDG_Private_Defines IWDG Private Defines
|
/** @defgroup IWDG_Private_Defines IWDG Private Defines
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
/* Status register need 5 RC LSI divided by prescaler clock to be updated. With
|
/* Status register needs up to 5 LSI clock periods divided by the clock
|
||||||
higher prescaler (256), and according to HSI variation, we need to wait at
|
prescaler to be updated. The number of LSI clock periods is upper-rounded to
|
||||||
least 6 cycles so 48 ms. */
|
6 for the timeout value calculation.
|
||||||
#define HAL_IWDG_DEFAULT_TIMEOUT 48U
|
The timeout value is also calculated using the highest prescaler (256) and
|
||||||
|
the LSI_VALUE constant. The value of this constant can be changed by the user
|
||||||
|
to take into account possible LSI clock period variations.
|
||||||
|
The timeout value is multiplied by 1000 to be converted in milliseconds. */
|
||||||
|
#define HAL_IWDG_DEFAULT_TIMEOUT ((6UL * 256UL * 1000UL) / LSI_VALUE)
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -158,10 +173,11 @@ HAL_StatusTypeDef HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg)
|
||||||
assert_param(IS_IWDG_PRESCALER(hiwdg->Init.Prescaler));
|
assert_param(IS_IWDG_PRESCALER(hiwdg->Init.Prescaler));
|
||||||
assert_param(IS_IWDG_RELOAD(hiwdg->Init.Reload));
|
assert_param(IS_IWDG_RELOAD(hiwdg->Init.Reload));
|
||||||
|
|
||||||
/* Enable IWDG. LSI is turned on automaticaly */
|
/* Enable IWDG. LSI is turned on automatically */
|
||||||
__HAL_IWDG_START(hiwdg);
|
__HAL_IWDG_START(hiwdg);
|
||||||
|
|
||||||
/* Enable write access to IWDG_PR and IWDG_RLR registers by writing 0x5555 in KR */
|
/* Enable write access to IWDG_PR and IWDG_RLR registers by writing
|
||||||
|
0x5555 in KR */
|
||||||
IWDG_ENABLE_WRITE_ACCESS(hiwdg);
|
IWDG_ENABLE_WRITE_ACCESS(hiwdg);
|
||||||
|
|
||||||
/* Write to IWDG registers the Prescaler & Reload values to work with */
|
/* Write to IWDG registers the Prescaler & Reload values to work with */
|
||||||
|
@ -172,7 +188,7 @@ HAL_StatusTypeDef HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg)
|
||||||
tickstart = HAL_GetTick();
|
tickstart = HAL_GetTick();
|
||||||
|
|
||||||
/* Wait for register to be updated */
|
/* Wait for register to be updated */
|
||||||
while (hiwdg->Instance->SR != RESET)
|
while (hiwdg->Instance->SR != 0x00u)
|
||||||
{
|
{
|
||||||
if ((HAL_GetTick() - tickstart) > HAL_IWDG_DEFAULT_TIMEOUT)
|
if ((HAL_GetTick() - tickstart) > HAL_IWDG_DEFAULT_TIMEOUT)
|
||||||
{
|
{
|
||||||
|
@ -191,6 +207,7 @@ HAL_StatusTypeDef HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg)
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/** @addtogroup IWDG_Exported_Functions_Group2
|
/** @addtogroup IWDG_Exported_Functions_Group2
|
||||||
* @brief IO operation functions
|
* @brief IO operation functions
|
||||||
*
|
*
|
||||||
|
@ -205,6 +222,7 @@ HAL_StatusTypeDef HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg)
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Refresh the IWDG.
|
* @brief Refresh the IWDG.
|
||||||
* @param hiwdg pointer to a IWDG_HandleTypeDef structure that contains
|
* @param hiwdg pointer to a IWDG_HandleTypeDef structure that contains
|
||||||
|
|
|
@ -49,7 +49,7 @@
|
||||||
|
|
||||||
/** @defgroup PCDEx_Exported_Functions_Group1 Peripheral Control functions
|
/** @defgroup PCDEx_Exported_Functions_Group1 Peripheral Control functions
|
||||||
* @brief PCDEx control functions
|
* @brief PCDEx control functions
|
||||||
*
|
*
|
||||||
@verbatim
|
@verbatim
|
||||||
===============================================================================
|
===============================================================================
|
||||||
##### Extended features functions #####
|
##### Extended features functions #####
|
||||||
|
@ -135,10 +135,8 @@ HAL_StatusTypeDef HAL_PCDEx_SetRxFiFo(PCD_HandleTypeDef *hpcd, uint16_t size)
|
||||||
* @retval HAL status
|
* @retval HAL status
|
||||||
*/
|
*/
|
||||||
|
|
||||||
HAL_StatusTypeDef HAL_PCDEx_PMAConfig(PCD_HandleTypeDef *hpcd,
|
HAL_StatusTypeDef HAL_PCDEx_PMAConfig(PCD_HandleTypeDef *hpcd, uint16_t ep_addr,
|
||||||
uint16_t ep_addr,
|
uint16_t ep_kind, uint32_t pmaadress)
|
||||||
uint16_t ep_kind,
|
|
||||||
uint32_t pmaadress)
|
|
||||||
{
|
{
|
||||||
PCD_EPTypeDef *ep;
|
PCD_EPTypeDef *ep;
|
||||||
|
|
||||||
|
@ -176,8 +174,8 @@ HAL_StatusTypeDef HAL_PCDEx_PMAConfig(PCD_HandleTypeDef *hpcd,
|
||||||
* @brief Software Device Connection,
|
* @brief Software Device Connection,
|
||||||
* this function is not required by USB OTG FS peripheral, it is used
|
* this function is not required by USB OTG FS peripheral, it is used
|
||||||
* only by USB Device FS peripheral.
|
* only by USB Device FS peripheral.
|
||||||
* @param hpcd: PCD handle
|
* @param hpcd PCD handle
|
||||||
* @param state: connection state (0 : disconnected / 1: connected)
|
* @param state connection state (0 : disconnected / 1: connected)
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
__weak void HAL_PCDEx_SetConnectionState(PCD_HandleTypeDef *hpcd, uint8_t state)
|
__weak void HAL_PCDEx_SetConnectionState(PCD_HandleTypeDef *hpcd, uint8_t state)
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -54,7 +54,7 @@
|
||||||
the commutation event).
|
the commutation event).
|
||||||
|
|
||||||
(#) Activate the TIM peripheral using one of the start functions:
|
(#) Activate the TIM peripheral using one of the start functions:
|
||||||
(++) Complementary Output Compare : HAL_TIMEx_OCN_Start(), HAL_TIMEx_OCN_Start_DMA(), HAL_TIMEx_OC_Start_IT()
|
(++) Complementary Output Compare : HAL_TIMEx_OCN_Start(), HAL_TIMEx_OCN_Start_DMA(), HAL_TIMEx_OCN_Start_IT()
|
||||||
(++) Complementary PWM generation : HAL_TIMEx_PWMN_Start(), HAL_TIMEx_PWMN_Start_DMA(), HAL_TIMEx_PWMN_Start_IT()
|
(++) Complementary PWM generation : HAL_TIMEx_PWMN_Start(), HAL_TIMEx_PWMN_Start_DMA(), HAL_TIMEx_PWMN_Start_IT()
|
||||||
(++) Complementary One-pulse mode output : HAL_TIMEx_OnePulseN_Start(), HAL_TIMEx_OnePulseN_Start_IT()
|
(++) Complementary One-pulse mode output : HAL_TIMEx_OnePulseN_Start(), HAL_TIMEx_OnePulseN_Start_IT()
|
||||||
(++) Hall Sensor output : HAL_TIMEx_HallSensor_Start(), HAL_TIMEx_HallSensor_Start_DMA(), HAL_TIMEx_HallSensor_Start_IT().
|
(++) Hall Sensor output : HAL_TIMEx_HallSensor_Start(), HAL_TIMEx_HallSensor_Start_DMA(), HAL_TIMEx_HallSensor_Start_IT().
|
||||||
|
@ -90,9 +90,11 @@
|
||||||
|
|
||||||
/* Private typedef -----------------------------------------------------------*/
|
/* Private typedef -----------------------------------------------------------*/
|
||||||
/* Private define ------------------------------------------------------------*/
|
/* Private define ------------------------------------------------------------*/
|
||||||
/* Private macro -------------------------------------------------------------*/
|
/* Private macros ------------------------------------------------------------*/
|
||||||
/* Private variables ---------------------------------------------------------*/
|
/* Private variables ---------------------------------------------------------*/
|
||||||
/* Private function prototypes -----------------------------------------------*/
|
/* Private function prototypes -----------------------------------------------*/
|
||||||
|
static void TIM_DMADelayPulseNCplt(DMA_HandleTypeDef *hdma);
|
||||||
|
static void TIM_DMAErrorCCxN(DMA_HandleTypeDef *hdma);
|
||||||
static void TIM_CCxNChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ChannelNState);
|
static void TIM_CCxNChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ChannelNState);
|
||||||
|
|
||||||
/* Exported functions --------------------------------------------------------*/
|
/* Exported functions --------------------------------------------------------*/
|
||||||
|
@ -123,6 +125,9 @@ static void TIM_CCxNChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t Cha
|
||||||
*/
|
*/
|
||||||
/**
|
/**
|
||||||
* @brief Initializes the TIM Hall Sensor Interface and initialize the associated handle.
|
* @brief Initializes the TIM Hall Sensor Interface and initialize the associated handle.
|
||||||
|
* @note When the timer instance is initialized in Hall Sensor Interface mode,
|
||||||
|
* timer channels 1 and channel 2 are reserved and cannot be used for
|
||||||
|
* other purpose.
|
||||||
* @param htim TIM Hall Sensor Interface handle
|
* @param htim TIM Hall Sensor Interface handle
|
||||||
* @param sConfig TIM Hall Sensor configuration structure
|
* @param sConfig TIM Hall Sensor configuration structure
|
||||||
* @retval HAL status
|
* @retval HAL status
|
||||||
|
@ -208,6 +213,15 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, TIM_HallSen
|
||||||
htim->Instance->CR2 &= ~TIM_CR2_MMS;
|
htim->Instance->CR2 &= ~TIM_CR2_MMS;
|
||||||
htim->Instance->CR2 |= TIM_TRGO_OC2REF;
|
htim->Instance->CR2 |= TIM_TRGO_OC2REF;
|
||||||
|
|
||||||
|
/* Initialize the DMA burst operation state */
|
||||||
|
htim->DMABurstState = HAL_DMA_BURST_STATE_READY;
|
||||||
|
|
||||||
|
/* Initialize the TIM channels state */
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Initialize the TIM state*/
|
/* Initialize the TIM state*/
|
||||||
htim->State = HAL_TIM_STATE_READY;
|
htim->State = HAL_TIM_STATE_READY;
|
||||||
|
|
||||||
|
@ -241,6 +255,15 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_DeInit(TIM_HandleTypeDef *htim)
|
||||||
HAL_TIMEx_HallSensor_MspDeInit(htim);
|
HAL_TIMEx_HallSensor_MspDeInit(htim);
|
||||||
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
||||||
|
|
||||||
|
/* Change the DMA burst operation state */
|
||||||
|
htim->DMABurstState = HAL_DMA_BURST_STATE_RESET;
|
||||||
|
|
||||||
|
/* Change the TIM channels state */
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_RESET);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_RESET);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_RESET);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_RESET);
|
||||||
|
|
||||||
/* Change TIM state */
|
/* Change TIM state */
|
||||||
htim->State = HAL_TIM_STATE_RESET;
|
htim->State = HAL_TIM_STATE_RESET;
|
||||||
|
|
||||||
|
@ -288,17 +311,43 @@ __weak void HAL_TIMEx_HallSensor_MspDeInit(TIM_HandleTypeDef *htim)
|
||||||
HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start(TIM_HandleTypeDef *htim)
|
HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start(TIM_HandleTypeDef *htim)
|
||||||
{
|
{
|
||||||
uint32_t tmpsmcr;
|
uint32_t tmpsmcr;
|
||||||
|
HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1);
|
||||||
|
HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2);
|
||||||
|
HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1);
|
||||||
|
HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2);
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance));
|
assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance));
|
||||||
|
|
||||||
|
/* Check the TIM channels state */
|
||||||
|
if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
|| (channel_2_state != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
|| (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
|| (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY))
|
||||||
|
{
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the TIM channels state */
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
|
||||||
/* Enable the Input Capture channel 1
|
/* Enable the Input Capture channel 1
|
||||||
(in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */
|
(in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */
|
||||||
TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE);
|
TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -324,6 +373,12 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop(TIM_HandleTypeDef *htim)
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM channels state */
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -336,10 +391,29 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop(TIM_HandleTypeDef *htim)
|
||||||
HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_IT(TIM_HandleTypeDef *htim)
|
HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_IT(TIM_HandleTypeDef *htim)
|
||||||
{
|
{
|
||||||
uint32_t tmpsmcr;
|
uint32_t tmpsmcr;
|
||||||
|
HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1);
|
||||||
|
HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2);
|
||||||
|
HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1);
|
||||||
|
HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2);
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance));
|
assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance));
|
||||||
|
|
||||||
|
/* Check the TIM channels state */
|
||||||
|
if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
|| (channel_2_state != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
|| (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
|| (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY))
|
||||||
|
{
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the TIM channels state */
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
|
||||||
/* Enable the capture compare Interrupts 1 event */
|
/* Enable the capture compare Interrupts 1 event */
|
||||||
__HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1);
|
__HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1);
|
||||||
|
|
||||||
|
@ -348,8 +422,15 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_IT(TIM_HandleTypeDef *htim)
|
||||||
TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE);
|
TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -378,6 +459,12 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_IT(TIM_HandleTypeDef *htim)
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM channels state */
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -392,29 +479,36 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_IT(TIM_HandleTypeDef *htim)
|
||||||
HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_DMA(TIM_HandleTypeDef *htim, uint32_t *pData, uint16_t Length)
|
HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_DMA(TIM_HandleTypeDef *htim, uint32_t *pData, uint16_t Length)
|
||||||
{
|
{
|
||||||
uint32_t tmpsmcr;
|
uint32_t tmpsmcr;
|
||||||
|
HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1);
|
||||||
|
HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1);
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance));
|
assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance));
|
||||||
|
|
||||||
if (htim->State == HAL_TIM_STATE_BUSY)
|
/* Set the TIM channel state */
|
||||||
|
if ((channel_1_state == HAL_TIM_CHANNEL_STATE_BUSY)
|
||||||
|
|| (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_BUSY))
|
||||||
{
|
{
|
||||||
return HAL_BUSY;
|
return HAL_BUSY;
|
||||||
}
|
}
|
||||||
else if (htim->State == HAL_TIM_STATE_READY)
|
else if ((channel_1_state == HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
&& (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_READY))
|
||||||
{
|
{
|
||||||
if (((uint32_t)pData == 0U) && (Length > 0U))
|
if ((pData == NULL) && (Length > 0U))
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
htim->State = HAL_TIM_STATE_BUSY;
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* nothing to do */
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Enable the Input Capture channel 1
|
/* Enable the Input Capture channel 1
|
||||||
(in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */
|
(in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */
|
||||||
TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE);
|
TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE);
|
||||||
|
@ -428,14 +522,22 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_DMA(TIM_HandleTypeDef *htim, uint32
|
||||||
/* Enable the DMA channel for Capture 1*/
|
/* Enable the DMA channel for Capture 1*/
|
||||||
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)&htim->Instance->CCR1, (uint32_t)pData, Length) != HAL_OK)
|
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)&htim->Instance->CCR1, (uint32_t)pData, Length) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Return error status */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
/* Enable the capture compare 1 Interrupt */
|
/* Enable the capture compare 1 Interrupt */
|
||||||
__HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1);
|
__HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -463,9 +565,14 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_DMA(TIM_HandleTypeDef *htim)
|
||||||
__HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1);
|
__HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1);
|
||||||
|
|
||||||
(void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]);
|
(void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]);
|
||||||
|
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM channel state */
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -512,6 +619,15 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start(TIM_HandleTypeDef *htim, uint32_t Channel)
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
||||||
|
|
||||||
|
/* Check the TIM complementary channel state */
|
||||||
|
if (TIM_CHANNEL_N_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
{
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the TIM complementary channel state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
|
||||||
/* Enable the Capture compare channel N */
|
/* Enable the Capture compare channel N */
|
||||||
TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE);
|
TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE);
|
||||||
|
|
||||||
|
@ -519,8 +635,15 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start(TIM_HandleTypeDef *htim, uint32_t Channel)
|
||||||
__HAL_TIM_MOE_ENABLE(htim);
|
__HAL_TIM_MOE_ENABLE(htim);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -554,6 +677,9 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel)
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM complementary channel state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -576,6 +702,15 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chann
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
||||||
|
|
||||||
|
/* Check the TIM complementary channel state */
|
||||||
|
if (TIM_CHANNEL_N_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
{
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the TIM complementary channel state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
|
||||||
switch (Channel)
|
switch (Channel)
|
||||||
{
|
{
|
||||||
case TIM_CHANNEL_1:
|
case TIM_CHANNEL_1:
|
||||||
|
@ -614,8 +749,15 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chann
|
||||||
__HAL_TIM_MOE_ENABLE(htim);
|
__HAL_TIM_MOE_ENABLE(htim);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -684,6 +826,9 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channe
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM complementary channel state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -708,24 +853,25 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
||||||
|
|
||||||
if (htim->State == HAL_TIM_STATE_BUSY)
|
/* Set the TIM complementary channel state */
|
||||||
|
if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_BUSY)
|
||||||
{
|
{
|
||||||
return HAL_BUSY;
|
return HAL_BUSY;
|
||||||
}
|
}
|
||||||
else if (htim->State == HAL_TIM_STATE_READY)
|
else if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_READY)
|
||||||
{
|
{
|
||||||
if (((uint32_t)pData == 0U) && (Length > 0U))
|
if ((pData == NULL) && (Length > 0U))
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
htim->State = HAL_TIM_STATE_BUSY;
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* nothing to do */
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (Channel)
|
switch (Channel)
|
||||||
|
@ -733,15 +879,16 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
case TIM_CHANNEL_1:
|
case TIM_CHANNEL_1:
|
||||||
{
|
{
|
||||||
/* Set the DMA compare callbacks */
|
/* Set the DMA compare callbacks */
|
||||||
htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseCplt;
|
htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseNCplt;
|
||||||
htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
||||||
|
|
||||||
/* Set the DMA error callback */
|
/* Set the DMA error callback */
|
||||||
htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ;
|
htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAErrorCCxN ;
|
||||||
|
|
||||||
/* Enable the DMA channel */
|
/* Enable the DMA channel */
|
||||||
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, Length) != HAL_OK)
|
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, Length) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Return error status */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
/* Enable the TIM Output Compare DMA request */
|
/* Enable the TIM Output Compare DMA request */
|
||||||
|
@ -752,15 +899,16 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
case TIM_CHANNEL_2:
|
case TIM_CHANNEL_2:
|
||||||
{
|
{
|
||||||
/* Set the DMA compare callbacks */
|
/* Set the DMA compare callbacks */
|
||||||
htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseCplt;
|
htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseNCplt;
|
||||||
htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
||||||
|
|
||||||
/* Set the DMA error callback */
|
/* Set the DMA error callback */
|
||||||
htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError ;
|
htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAErrorCCxN ;
|
||||||
|
|
||||||
/* Enable the DMA channel */
|
/* Enable the DMA channel */
|
||||||
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, Length) != HAL_OK)
|
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, Length) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Return error status */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
/* Enable the TIM Output Compare DMA request */
|
/* Enable the TIM Output Compare DMA request */
|
||||||
|
@ -771,15 +919,16 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
case TIM_CHANNEL_3:
|
case TIM_CHANNEL_3:
|
||||||
{
|
{
|
||||||
/* Set the DMA compare callbacks */
|
/* Set the DMA compare callbacks */
|
||||||
htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseCplt;
|
htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseNCplt;
|
||||||
htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
||||||
|
|
||||||
/* Set the DMA error callback */
|
/* Set the DMA error callback */
|
||||||
htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAError ;
|
htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAErrorCCxN ;
|
||||||
|
|
||||||
/* Enable the DMA channel */
|
/* Enable the DMA channel */
|
||||||
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, Length) != HAL_OK)
|
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, Length) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Return error status */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
/* Enable the TIM Output Compare DMA request */
|
/* Enable the TIM Output Compare DMA request */
|
||||||
|
@ -798,8 +947,15 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
__HAL_TIM_MOE_ENABLE(htim);
|
__HAL_TIM_MOE_ENABLE(htim);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -863,8 +1019,8 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Chann
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
/* Change the htim state */
|
/* Set the TIM complementary channel state */
|
||||||
htim->State = HAL_TIM_STATE_READY;
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
|
@ -921,6 +1077,15 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start(TIM_HandleTypeDef *htim, uint32_t Channel
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
||||||
|
|
||||||
|
/* Check the TIM complementary channel state */
|
||||||
|
if (TIM_CHANNEL_N_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
{
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the TIM complementary channel state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
|
||||||
/* Enable the complementary PWM output */
|
/* Enable the complementary PWM output */
|
||||||
TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE);
|
TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE);
|
||||||
|
|
||||||
|
@ -928,8 +1093,15 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start(TIM_HandleTypeDef *htim, uint32_t Channel
|
||||||
__HAL_TIM_MOE_ENABLE(htim);
|
__HAL_TIM_MOE_ENABLE(htim);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -962,6 +1134,9 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel)
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM complementary channel state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -984,6 +1159,15 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
||||||
|
|
||||||
|
/* Check the TIM complementary channel state */
|
||||||
|
if (TIM_CHANNEL_N_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
{
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the TIM complementary channel state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
|
||||||
switch (Channel)
|
switch (Channel)
|
||||||
{
|
{
|
||||||
case TIM_CHANNEL_1:
|
case TIM_CHANNEL_1:
|
||||||
|
@ -1021,8 +1205,15 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
__HAL_TIM_MOE_ENABLE(htim);
|
__HAL_TIM_MOE_ENABLE(htim);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -1092,6 +1283,9 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Chann
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM complementary channel state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -1116,39 +1310,42 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel));
|
||||||
|
|
||||||
if (htim->State == HAL_TIM_STATE_BUSY)
|
/* Set the TIM complementary channel state */
|
||||||
|
if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_BUSY)
|
||||||
{
|
{
|
||||||
return HAL_BUSY;
|
return HAL_BUSY;
|
||||||
}
|
}
|
||||||
else if (htim->State == HAL_TIM_STATE_READY)
|
else if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_READY)
|
||||||
{
|
{
|
||||||
if (((uint32_t)pData == 0U) && (Length > 0U))
|
if ((pData == NULL) && (Length > 0U))
|
||||||
{
|
{
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
htim->State = HAL_TIM_STATE_BUSY;
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* nothing to do */
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (Channel)
|
switch (Channel)
|
||||||
{
|
{
|
||||||
case TIM_CHANNEL_1:
|
case TIM_CHANNEL_1:
|
||||||
{
|
{
|
||||||
/* Set the DMA compare callbacks */
|
/* Set the DMA compare callbacks */
|
||||||
htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseCplt;
|
htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseNCplt;
|
||||||
htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
||||||
|
|
||||||
/* Set the DMA error callback */
|
/* Set the DMA error callback */
|
||||||
htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ;
|
htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAErrorCCxN ;
|
||||||
|
|
||||||
/* Enable the DMA channel */
|
/* Enable the DMA channel */
|
||||||
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, Length) != HAL_OK)
|
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, Length) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Return error status */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
/* Enable the TIM Capture/Compare 1 DMA request */
|
/* Enable the TIM Capture/Compare 1 DMA request */
|
||||||
|
@ -1159,15 +1356,16 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha
|
||||||
case TIM_CHANNEL_2:
|
case TIM_CHANNEL_2:
|
||||||
{
|
{
|
||||||
/* Set the DMA compare callbacks */
|
/* Set the DMA compare callbacks */
|
||||||
htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseCplt;
|
htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseNCplt;
|
||||||
htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
||||||
|
|
||||||
/* Set the DMA error callback */
|
/* Set the DMA error callback */
|
||||||
htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError ;
|
htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAErrorCCxN ;
|
||||||
|
|
||||||
/* Enable the DMA channel */
|
/* Enable the DMA channel */
|
||||||
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, Length) != HAL_OK)
|
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, Length) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Return error status */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
/* Enable the TIM Capture/Compare 2 DMA request */
|
/* Enable the TIM Capture/Compare 2 DMA request */
|
||||||
|
@ -1178,15 +1376,16 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha
|
||||||
case TIM_CHANNEL_3:
|
case TIM_CHANNEL_3:
|
||||||
{
|
{
|
||||||
/* Set the DMA compare callbacks */
|
/* Set the DMA compare callbacks */
|
||||||
htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseCplt;
|
htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseNCplt;
|
||||||
htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt;
|
||||||
|
|
||||||
/* Set the DMA error callback */
|
/* Set the DMA error callback */
|
||||||
htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAError ;
|
htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAErrorCCxN ;
|
||||||
|
|
||||||
/* Enable the DMA channel */
|
/* Enable the DMA channel */
|
||||||
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, Length) != HAL_OK)
|
if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, Length) != HAL_OK)
|
||||||
{
|
{
|
||||||
|
/* Return error status */
|
||||||
return HAL_ERROR;
|
return HAL_ERROR;
|
||||||
}
|
}
|
||||||
/* Enable the TIM Capture/Compare 3 DMA request */
|
/* Enable the TIM Capture/Compare 3 DMA request */
|
||||||
|
@ -1205,8 +1404,15 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha
|
||||||
__HAL_TIM_MOE_ENABLE(htim);
|
__HAL_TIM_MOE_ENABLE(htim);
|
||||||
|
|
||||||
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
/* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
|
||||||
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
{
|
||||||
|
tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
|
||||||
|
if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
|
||||||
|
{
|
||||||
|
__HAL_TIM_ENABLE(htim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
__HAL_TIM_ENABLE(htim);
|
__HAL_TIM_ENABLE(htim);
|
||||||
}
|
}
|
||||||
|
@ -1270,8 +1476,8 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
/* Change the htim state */
|
/* Set the TIM complementary channel state */
|
||||||
htim->State = HAL_TIM_STATE_READY;
|
TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
|
@ -1311,11 +1517,27 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Chan
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start(TIM_HandleTypeDef *htim, uint32_t OutputChannel)
|
HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start(TIM_HandleTypeDef *htim, uint32_t OutputChannel)
|
||||||
{
|
{
|
||||||
|
uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1;
|
||||||
|
HAL_TIM_ChannelStateTypeDef input_channel_state = TIM_CHANNEL_STATE_GET(htim, input_channel);
|
||||||
|
HAL_TIM_ChannelStateTypeDef output_channel_state = TIM_CHANNEL_N_STATE_GET(htim, OutputChannel);
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel));
|
||||||
|
|
||||||
/* Enable the complementary One Pulse output */
|
/* Check the TIM channels state */
|
||||||
|
if ((output_channel_state != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
|| (input_channel_state != HAL_TIM_CHANNEL_STATE_READY))
|
||||||
|
{
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the TIM channels state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, OutputChannel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, input_channel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
|
||||||
|
/* Enable the complementary One Pulse output channel and the Input Capture channel */
|
||||||
TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_ENABLE);
|
TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_ENABLE);
|
||||||
|
TIM_CCxChannelCmd(htim->Instance, input_channel, TIM_CCx_ENABLE);
|
||||||
|
|
||||||
/* Enable the Main Output */
|
/* Enable the Main Output */
|
||||||
__HAL_TIM_MOE_ENABLE(htim);
|
__HAL_TIM_MOE_ENABLE(htim);
|
||||||
|
@ -1336,12 +1558,14 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start(TIM_HandleTypeDef *htim, uint32_t Ou
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t OutputChannel)
|
HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t OutputChannel)
|
||||||
{
|
{
|
||||||
|
uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1;
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel));
|
||||||
|
|
||||||
/* Disable the complementary One Pulse output */
|
/* Disable the complementary One Pulse output channel and the Input Capture channel */
|
||||||
TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_DISABLE);
|
TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_DISABLE);
|
||||||
|
TIM_CCxChannelCmd(htim->Instance, input_channel, TIM_CCx_DISABLE);
|
||||||
|
|
||||||
/* Disable the Main Output */
|
/* Disable the Main Output */
|
||||||
__HAL_TIM_MOE_DISABLE(htim);
|
__HAL_TIM_MOE_DISABLE(htim);
|
||||||
|
@ -1349,6 +1573,10 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t Out
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM channels state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, OutputChannel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, input_channel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -1365,17 +1593,33 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t Out
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel)
|
HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel)
|
||||||
{
|
{
|
||||||
|
uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1;
|
||||||
|
HAL_TIM_ChannelStateTypeDef input_channel_state = TIM_CHANNEL_STATE_GET(htim, input_channel);
|
||||||
|
HAL_TIM_ChannelStateTypeDef output_channel_state = TIM_CHANNEL_N_STATE_GET(htim, OutputChannel);
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel));
|
||||||
|
|
||||||
|
/* Check the TIM channels state */
|
||||||
|
if ((output_channel_state != HAL_TIM_CHANNEL_STATE_READY)
|
||||||
|
|| (input_channel_state != HAL_TIM_CHANNEL_STATE_READY))
|
||||||
|
{
|
||||||
|
return HAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the TIM channels state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, OutputChannel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, input_channel, HAL_TIM_CHANNEL_STATE_BUSY);
|
||||||
|
|
||||||
/* Enable the TIM Capture/Compare 1 interrupt */
|
/* Enable the TIM Capture/Compare 1 interrupt */
|
||||||
__HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1);
|
__HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1);
|
||||||
|
|
||||||
/* Enable the TIM Capture/Compare 2 interrupt */
|
/* Enable the TIM Capture/Compare 2 interrupt */
|
||||||
__HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2);
|
__HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2);
|
||||||
|
|
||||||
/* Enable the complementary One Pulse output */
|
/* Enable the complementary One Pulse output channel and the Input Capture channel */
|
||||||
TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_ENABLE);
|
TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_ENABLE);
|
||||||
|
TIM_CCxChannelCmd(htim->Instance, input_channel, TIM_CCx_ENABLE);
|
||||||
|
|
||||||
/* Enable the Main Output */
|
/* Enable the Main Output */
|
||||||
__HAL_TIM_MOE_ENABLE(htim);
|
__HAL_TIM_MOE_ENABLE(htim);
|
||||||
|
@ -1396,6 +1640,8 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start_IT(TIM_HandleTypeDef *htim, uint32_t
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel)
|
HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel)
|
||||||
{
|
{
|
||||||
|
uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1;
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel));
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel));
|
||||||
|
|
||||||
|
@ -1405,8 +1651,9 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t
|
||||||
/* Disable the TIM Capture/Compare 2 interrupt */
|
/* Disable the TIM Capture/Compare 2 interrupt */
|
||||||
__HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2);
|
__HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2);
|
||||||
|
|
||||||
/* Disable the complementary One Pulse output */
|
/* Disable the complementary One Pulse output channel and the Input Capture channel */
|
||||||
TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_DISABLE);
|
TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_DISABLE);
|
||||||
|
TIM_CCxChannelCmd(htim->Instance, input_channel, TIM_CCx_DISABLE);
|
||||||
|
|
||||||
/* Disable the Main Output */
|
/* Disable the Main Output */
|
||||||
__HAL_TIM_MOE_DISABLE(htim);
|
__HAL_TIM_MOE_DISABLE(htim);
|
||||||
|
@ -1414,6 +1661,10 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t
|
||||||
/* Disable the Peripheral */
|
/* Disable the Peripheral */
|
||||||
__HAL_TIM_DISABLE(htim);
|
__HAL_TIM_DISABLE(htim);
|
||||||
|
|
||||||
|
/* Set the TIM channels state */
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, OutputChannel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
TIM_CHANNEL_STATE_SET(htim, input_channel, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
|
||||||
/* Return function status */
|
/* Return function status */
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -1633,7 +1884,7 @@ HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim,
|
||||||
uint32_t tmpsmcr;
|
uint32_t tmpsmcr;
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
assert_param(IS_TIM_SYNCHRO_INSTANCE(htim->Instance));
|
assert_param(IS_TIM_MASTER_INSTANCE(htim->Instance));
|
||||||
assert_param(IS_TIM_TRGO_SOURCE(sMasterConfig->MasterOutputTrigger));
|
assert_param(IS_TIM_TRGO_SOURCE(sMasterConfig->MasterOutputTrigger));
|
||||||
assert_param(IS_TIM_MSM_STATE(sMasterConfig->MasterSlaveMode));
|
assert_param(IS_TIM_MSM_STATE(sMasterConfig->MasterSlaveMode));
|
||||||
|
|
||||||
|
@ -1654,16 +1905,19 @@ HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim,
|
||||||
/* Select the TRGO source */
|
/* Select the TRGO source */
|
||||||
tmpcr2 |= sMasterConfig->MasterOutputTrigger;
|
tmpcr2 |= sMasterConfig->MasterOutputTrigger;
|
||||||
|
|
||||||
/* Reset the MSM Bit */
|
|
||||||
tmpsmcr &= ~TIM_SMCR_MSM;
|
|
||||||
/* Set master mode */
|
|
||||||
tmpsmcr |= sMasterConfig->MasterSlaveMode;
|
|
||||||
|
|
||||||
/* Update TIMx CR2 */
|
/* Update TIMx CR2 */
|
||||||
htim->Instance->CR2 = tmpcr2;
|
htim->Instance->CR2 = tmpcr2;
|
||||||
|
|
||||||
/* Update TIMx SMCR */
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
||||||
htim->Instance->SMCR = tmpsmcr;
|
{
|
||||||
|
/* Reset the MSM Bit */
|
||||||
|
tmpsmcr &= ~TIM_SMCR_MSM;
|
||||||
|
/* Set master mode */
|
||||||
|
tmpsmcr |= sMasterConfig->MasterSlaveMode;
|
||||||
|
|
||||||
|
/* Update TIMx SMCR */
|
||||||
|
htim->Instance->SMCR = tmpsmcr;
|
||||||
|
}
|
||||||
|
|
||||||
/* Change the htim state */
|
/* Change the htim state */
|
||||||
htim->State = HAL_TIM_STATE_READY;
|
htim->State = HAL_TIM_STATE_READY;
|
||||||
|
@ -1733,6 +1987,9 @@ HAL_StatusTypeDef HAL_TIMEx_ConfigBreakDeadTime(TIM_HandleTypeDef *htim,
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_TIMEx_RemapConfig(TIM_HandleTypeDef *htim, uint32_t Remap)
|
HAL_StatusTypeDef HAL_TIMEx_RemapConfig(TIM_HandleTypeDef *htim, uint32_t Remap)
|
||||||
{
|
{
|
||||||
|
/* Prevent unused argument(s) compilation warning */
|
||||||
|
UNUSED(htim);
|
||||||
|
UNUSED(Remap);
|
||||||
|
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
|
@ -1829,6 +2086,27 @@ HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(TIM_HandleTypeDef *htim)
|
||||||
return htim->State;
|
return htim->State;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Return actual state of the TIM complementary channel.
|
||||||
|
* @param htim TIM handle
|
||||||
|
* @param ChannelN TIM Complementary channel
|
||||||
|
* This parameter can be one of the following values:
|
||||||
|
* @arg TIM_CHANNEL_1: TIM Channel 1
|
||||||
|
* @arg TIM_CHANNEL_2: TIM Channel 2
|
||||||
|
* @arg TIM_CHANNEL_3: TIM Channel 3
|
||||||
|
* @retval TIM Complementary channel state
|
||||||
|
*/
|
||||||
|
HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(TIM_HandleTypeDef *htim, uint32_t ChannelN)
|
||||||
|
{
|
||||||
|
HAL_TIM_ChannelStateTypeDef channel_state;
|
||||||
|
|
||||||
|
/* Check the parameters */
|
||||||
|
assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, ChannelN));
|
||||||
|
|
||||||
|
channel_state = TIM_CHANNEL_N_STATE_GET(htim, ChannelN);
|
||||||
|
|
||||||
|
return channel_state;
|
||||||
|
}
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
@ -1881,6 +2159,103 @@ void TIMEx_DMACommutationHalfCplt(DMA_HandleTypeDef *hdma)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief TIM DMA Delay Pulse complete callback (complementary channel).
|
||||||
|
* @param hdma pointer to DMA handle.
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
static void TIM_DMADelayPulseNCplt(DMA_HandleTypeDef *hdma)
|
||||||
|
{
|
||||||
|
TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent;
|
||||||
|
|
||||||
|
if (hdma == htim->hdma[TIM_DMA_ID_CC1])
|
||||||
|
{
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1;
|
||||||
|
|
||||||
|
if (hdma->Init.Mode == DMA_NORMAL)
|
||||||
|
{
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (hdma == htim->hdma[TIM_DMA_ID_CC2])
|
||||||
|
{
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2;
|
||||||
|
|
||||||
|
if (hdma->Init.Mode == DMA_NORMAL)
|
||||||
|
{
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (hdma == htim->hdma[TIM_DMA_ID_CC3])
|
||||||
|
{
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3;
|
||||||
|
|
||||||
|
if (hdma->Init.Mode == DMA_NORMAL)
|
||||||
|
{
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (hdma == htim->hdma[TIM_DMA_ID_CC4])
|
||||||
|
{
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4;
|
||||||
|
|
||||||
|
if (hdma->Init.Mode == DMA_NORMAL)
|
||||||
|
{
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_4, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* nothing to do */
|
||||||
|
}
|
||||||
|
|
||||||
|
#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1)
|
||||||
|
htim->PWM_PulseFinishedCallback(htim);
|
||||||
|
#else
|
||||||
|
HAL_TIM_PWM_PulseFinishedCallback(htim);
|
||||||
|
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
||||||
|
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief TIM DMA error callback (complementary channel)
|
||||||
|
* @param hdma pointer to DMA handle.
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
static void TIM_DMAErrorCCxN(DMA_HandleTypeDef *hdma)
|
||||||
|
{
|
||||||
|
TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent;
|
||||||
|
|
||||||
|
if (hdma == htim->hdma[TIM_DMA_ID_CC1])
|
||||||
|
{
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1;
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
}
|
||||||
|
else if (hdma == htim->hdma[TIM_DMA_ID_CC2])
|
||||||
|
{
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2;
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
}
|
||||||
|
else if (hdma == htim->hdma[TIM_DMA_ID_CC3])
|
||||||
|
{
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3;
|
||||||
|
TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* nothing to do */
|
||||||
|
}
|
||||||
|
|
||||||
|
#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1)
|
||||||
|
htim->ErrorCallback(htim);
|
||||||
|
#else
|
||||||
|
HAL_TIM_ErrorCallback(htim);
|
||||||
|
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
||||||
|
|
||||||
|
htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Enables or disables the TIM Capture Compare Channel xN.
|
* @brief Enables or disables the TIM Capture Compare Channel xN.
|
||||||
* @param TIMx to select the TIM peripheral
|
* @param TIMx to select the TIM peripheral
|
||||||
|
|
|
@ -1026,7 +1026,8 @@ HAL_StatusTypeDef HAL_UART_UnRegisterCallback(UART_HandleTypeDef *huart, HAL_UAR
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout)
|
HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout)
|
||||||
{
|
{
|
||||||
uint16_t *tmp;
|
uint8_t *pdata8bits;
|
||||||
|
uint16_t *pdata16bits;
|
||||||
uint32_t tickstart = 0U;
|
uint32_t tickstart = 0U;
|
||||||
|
|
||||||
/* Check that a Tx process is not already ongoing */
|
/* Check that a Tx process is not already ongoing */
|
||||||
|
@ -1048,34 +1049,39 @@ HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, u
|
||||||
|
|
||||||
huart->TxXferSize = Size;
|
huart->TxXferSize = Size;
|
||||||
huart->TxXferCount = Size;
|
huart->TxXferCount = Size;
|
||||||
|
|
||||||
|
/* In case of 9bits/No Parity transfer, pData needs to be handled as a uint16_t pointer */
|
||||||
|
if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE))
|
||||||
|
{
|
||||||
|
pdata8bits = NULL;
|
||||||
|
pdata16bits = (uint16_t *) pData;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pdata8bits = pData;
|
||||||
|
pdata16bits = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Process Unlocked */
|
||||||
|
__HAL_UNLOCK(huart);
|
||||||
|
|
||||||
while (huart->TxXferCount > 0U)
|
while (huart->TxXferCount > 0U)
|
||||||
{
|
{
|
||||||
huart->TxXferCount--;
|
if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK)
|
||||||
if (huart->Init.WordLength == UART_WORDLENGTH_9B)
|
|
||||||
{
|
{
|
||||||
if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK)
|
return HAL_TIMEOUT;
|
||||||
{
|
}
|
||||||
return HAL_TIMEOUT;
|
if (pdata8bits == NULL)
|
||||||
}
|
{
|
||||||
tmp = (uint16_t *) pData;
|
huart->Instance->DR = (uint16_t)(*pdata16bits & 0x01FFU);
|
||||||
huart->Instance->DR = (*tmp & (uint16_t)0x01FF);
|
pdata16bits++;
|
||||||
if (huart->Init.Parity == UART_PARITY_NONE)
|
|
||||||
{
|
|
||||||
pData += 2U;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
pData += 1U;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK)
|
huart->Instance->DR = (uint8_t)(*pdata8bits & 0xFFU);
|
||||||
{
|
pdata8bits++;
|
||||||
return HAL_TIMEOUT;
|
|
||||||
}
|
|
||||||
huart->Instance->DR = (*pData++ & (uint8_t)0xFF);
|
|
||||||
}
|
}
|
||||||
|
huart->TxXferCount--;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TC, RESET, tickstart, Timeout) != HAL_OK)
|
if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TC, RESET, tickstart, Timeout) != HAL_OK)
|
||||||
|
@ -1086,9 +1092,6 @@ HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, u
|
||||||
/* At end of Tx process, restore huart->gState to Ready */
|
/* At end of Tx process, restore huart->gState to Ready */
|
||||||
huart->gState = HAL_UART_STATE_READY;
|
huart->gState = HAL_UART_STATE_READY;
|
||||||
|
|
||||||
/* Process Unlocked */
|
|
||||||
__HAL_UNLOCK(huart);
|
|
||||||
|
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1111,7 +1114,8 @@ HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, u
|
||||||
*/
|
*/
|
||||||
HAL_StatusTypeDef HAL_UART_Receive(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout)
|
HAL_StatusTypeDef HAL_UART_Receive(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout)
|
||||||
{
|
{
|
||||||
uint16_t *tmp;
|
uint8_t *pdata8bits;
|
||||||
|
uint16_t *pdata16bits;
|
||||||
uint32_t tickstart = 0U;
|
uint32_t tickstart = 0U;
|
||||||
|
|
||||||
/* Check that a Rx process is not already ongoing */
|
/* Check that a Rx process is not already ongoing */
|
||||||
|
@ -1134,53 +1138,51 @@ HAL_StatusTypeDef HAL_UART_Receive(UART_HandleTypeDef *huart, uint8_t *pData, ui
|
||||||
huart->RxXferSize = Size;
|
huart->RxXferSize = Size;
|
||||||
huart->RxXferCount = Size;
|
huart->RxXferCount = Size;
|
||||||
|
|
||||||
|
/* In case of 9bits/No Parity transfer, pRxData needs to be handled as a uint16_t pointer */
|
||||||
|
if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE))
|
||||||
|
{
|
||||||
|
pdata8bits = NULL;
|
||||||
|
pdata16bits = (uint16_t *) pData;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pdata8bits = pData;
|
||||||
|
pdata16bits = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Process Unlocked */
|
||||||
|
__HAL_UNLOCK(huart);
|
||||||
|
|
||||||
/* Check the remain data to be received */
|
/* Check the remain data to be received */
|
||||||
while (huart->RxXferCount > 0U)
|
while (huart->RxXferCount > 0U)
|
||||||
{
|
{
|
||||||
huart->RxXferCount--;
|
if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK)
|
||||||
if (huart->Init.WordLength == UART_WORDLENGTH_9B)
|
|
||||||
{
|
{
|
||||||
if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK)
|
return HAL_TIMEOUT;
|
||||||
{
|
}
|
||||||
return HAL_TIMEOUT;
|
if (pdata8bits == NULL)
|
||||||
}
|
{
|
||||||
tmp = (uint16_t *) pData;
|
*pdata16bits = (uint16_t)(huart->Instance->DR & 0x01FF);
|
||||||
if (huart->Init.Parity == UART_PARITY_NONE)
|
pdata16bits++;
|
||||||
{
|
|
||||||
*tmp = (uint16_t)(huart->Instance->DR & (uint16_t)0x01FF);
|
|
||||||
pData += 2U;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*tmp = (uint16_t)(huart->Instance->DR & (uint16_t)0x00FF);
|
|
||||||
pData += 1U;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK)
|
if ((huart->Init.WordLength == UART_WORDLENGTH_9B) || ((huart->Init.WordLength == UART_WORDLENGTH_8B) && (huart->Init.Parity == UART_PARITY_NONE)))
|
||||||
{
|
{
|
||||||
return HAL_TIMEOUT;
|
*pdata8bits = (uint8_t)(huart->Instance->DR & (uint8_t)0x00FF);
|
||||||
}
|
|
||||||
if (huart->Init.Parity == UART_PARITY_NONE)
|
|
||||||
{
|
|
||||||
*pData++ = (uint8_t)(huart->Instance->DR & (uint8_t)0x00FF);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
*pData++ = (uint8_t)(huart->Instance->DR & (uint8_t)0x007F);
|
*pdata8bits = (uint8_t)(huart->Instance->DR & (uint8_t)0x007F);
|
||||||
}
|
}
|
||||||
|
pdata8bits++;
|
||||||
}
|
}
|
||||||
|
huart->RxXferCount--;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* At end of Rx process, restore huart->RxState to Ready */
|
/* At end of Rx process, restore huart->RxState to Ready */
|
||||||
huart->RxState = HAL_UART_STATE_READY;
|
huart->RxState = HAL_UART_STATE_READY;
|
||||||
|
|
||||||
/* Process Unlocked */
|
|
||||||
__HAL_UNLOCK(huart);
|
|
||||||
|
|
||||||
return HAL_OK;
|
return HAL_OK;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -2060,7 +2062,7 @@ void HAL_UART_IRQHandler(UART_HandleTypeDef *huart)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* UART Over-Run interrupt occurred --------------------------------------*/
|
/* UART Over-Run interrupt occurred --------------------------------------*/
|
||||||
if (((isrflags & USART_SR_ORE) != RESET) && ((cr3its & USART_CR3_EIE) != RESET))
|
if (((isrflags & USART_SR_ORE) != RESET) && (((cr1its & USART_CR1_RXNEIE) != RESET) || ((cr3its & USART_CR3_EIE) != RESET)))
|
||||||
{
|
{
|
||||||
huart->ErrorCode |= HAL_UART_ERROR_ORE;
|
huart->ErrorCode |= HAL_UART_ERROR_ORE;
|
||||||
}
|
}
|
||||||
|
@ -2924,18 +2926,11 @@ static HAL_StatusTypeDef UART_Transmit_IT(UART_HandleTypeDef *huart)
|
||||||
/* Check that a Tx process is ongoing */
|
/* Check that a Tx process is ongoing */
|
||||||
if (huart->gState == HAL_UART_STATE_BUSY_TX)
|
if (huart->gState == HAL_UART_STATE_BUSY_TX)
|
||||||
{
|
{
|
||||||
if (huart->Init.WordLength == UART_WORDLENGTH_9B)
|
if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE))
|
||||||
{
|
{
|
||||||
tmp = (uint16_t *) huart->pTxBuffPtr;
|
tmp = (uint16_t *) huart->pTxBuffPtr;
|
||||||
huart->Instance->DR = (uint16_t)(*tmp & (uint16_t)0x01FF);
|
huart->Instance->DR = (uint16_t)(*tmp & (uint16_t)0x01FF);
|
||||||
if (huart->Init.Parity == UART_PARITY_NONE)
|
huart->pTxBuffPtr += 2U;
|
||||||
{
|
|
||||||
huart->pTxBuffPtr += 2U;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
huart->pTxBuffPtr += 1U;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -2991,35 +2986,33 @@ static HAL_StatusTypeDef UART_EndTransmit_IT(UART_HandleTypeDef *huart)
|
||||||
*/
|
*/
|
||||||
static HAL_StatusTypeDef UART_Receive_IT(UART_HandleTypeDef *huart)
|
static HAL_StatusTypeDef UART_Receive_IT(UART_HandleTypeDef *huart)
|
||||||
{
|
{
|
||||||
uint16_t *tmp;
|
uint8_t *pdata8bits;
|
||||||
|
uint16_t *pdata16bits;
|
||||||
|
|
||||||
/* Check that a Rx process is ongoing */
|
/* Check that a Rx process is ongoing */
|
||||||
if (huart->RxState == HAL_UART_STATE_BUSY_RX)
|
if (huart->RxState == HAL_UART_STATE_BUSY_RX)
|
||||||
{
|
{
|
||||||
if (huart->Init.WordLength == UART_WORDLENGTH_9B)
|
if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE))
|
||||||
{
|
{
|
||||||
tmp = (uint16_t *) huart->pRxBuffPtr;
|
pdata8bits = NULL;
|
||||||
if (huart->Init.Parity == UART_PARITY_NONE)
|
pdata16bits = (uint16_t *) huart->pRxBuffPtr;
|
||||||
{
|
*pdata16bits = (uint16_t)(huart->Instance->DR & (uint16_t)0x01FF);
|
||||||
*tmp = (uint16_t)(huart->Instance->DR & (uint16_t)0x01FF);
|
huart->pRxBuffPtr += 2U;
|
||||||
huart->pRxBuffPtr += 2U;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*tmp = (uint16_t)(huart->Instance->DR & (uint16_t)0x00FF);
|
|
||||||
huart->pRxBuffPtr += 1U;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (huart->Init.Parity == UART_PARITY_NONE)
|
pdata8bits = (uint8_t *) huart->pRxBuffPtr;
|
||||||
|
pdata16bits = NULL;
|
||||||
|
|
||||||
|
if ((huart->Init.WordLength == UART_WORDLENGTH_9B) || ((huart->Init.WordLength == UART_WORDLENGTH_8B) && (huart->Init.Parity == UART_PARITY_NONE)))
|
||||||
{
|
{
|
||||||
*huart->pRxBuffPtr++ = (uint8_t)(huart->Instance->DR & (uint8_t)0x00FF);
|
*pdata8bits = (uint8_t)(huart->Instance->DR & (uint8_t)0x00FF);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
*huart->pRxBuffPtr++ = (uint8_t)(huart->Instance->DR & (uint8_t)0x007F);
|
*pdata8bits = (uint8_t)(huart->Instance->DR & (uint8_t)0x007F);
|
||||||
}
|
}
|
||||||
|
huart->pRxBuffPtr += 1U;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (--huart->RxXferCount == 0U)
|
if (--huart->RxXferCount == 0U)
|
||||||
|
@ -3099,48 +3092,28 @@ static void UART_SetConfig(UART_HandleTypeDef *huart)
|
||||||
/* Configure the UART HFC: Set CTSE and RTSE bits according to huart->Init.HwFlowCtl value */
|
/* Configure the UART HFC: Set CTSE and RTSE bits according to huart->Init.HwFlowCtl value */
|
||||||
MODIFY_REG(huart->Instance->CR3, (USART_CR3_RTSE | USART_CR3_CTSE), huart->Init.HwFlowCtl);
|
MODIFY_REG(huart->Instance->CR3, (USART_CR3_RTSE | USART_CR3_CTSE), huart->Init.HwFlowCtl);
|
||||||
|
|
||||||
#if defined(USART_CR1_OVER8)
|
|
||||||
/* Check the Over Sampling */
|
|
||||||
if(huart->Init.OverSampling == UART_OVERSAMPLING_8)
|
|
||||||
{
|
|
||||||
/*-------------------------- USART BRR Configuration ---------------------*/
|
|
||||||
if(huart->Instance == USART1)
|
|
||||||
{
|
|
||||||
pclk = HAL_RCC_GetPCLK2Freq();
|
|
||||||
huart->Instance->BRR = UART_BRR_SAMPLING8(pclk, huart->Init.BaudRate);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
pclk = HAL_RCC_GetPCLK1Freq();
|
|
||||||
huart->Instance->BRR = UART_BRR_SAMPLING8(pclk, huart->Init.BaudRate);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/*-------------------------- USART BRR Configuration ---------------------*/
|
|
||||||
if(huart->Instance == USART1)
|
|
||||||
{
|
|
||||||
pclk = HAL_RCC_GetPCLK2Freq();
|
|
||||||
huart->Instance->BRR = UART_BRR_SAMPLING16(pclk, huart->Init.BaudRate);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
pclk = HAL_RCC_GetPCLK1Freq();
|
|
||||||
huart->Instance->BRR = UART_BRR_SAMPLING16(pclk, huart->Init.BaudRate);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
/*-------------------------- USART BRR Configuration ---------------------*/
|
|
||||||
if(huart->Instance == USART1)
|
if(huart->Instance == USART1)
|
||||||
{
|
{
|
||||||
pclk = HAL_RCC_GetPCLK2Freq();
|
pclk = HAL_RCC_GetPCLK2Freq();
|
||||||
huart->Instance->BRR = UART_BRR_SAMPLING16(pclk, huart->Init.BaudRate);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pclk = HAL_RCC_GetPCLK1Freq();
|
pclk = HAL_RCC_GetPCLK1Freq();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*-------------------------- USART BRR Configuration ---------------------*/
|
||||||
|
#if defined(USART_CR1_OVER8)
|
||||||
|
if (huart->Init.OverSampling == UART_OVERSAMPLING_8)
|
||||||
|
{
|
||||||
|
huart->Instance->BRR = UART_BRR_SAMPLING8(pclk, huart->Init.BaudRate);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
huart->Instance->BRR = UART_BRR_SAMPLING16(pclk, huart->Init.BaudRate);
|
huart->Instance->BRR = UART_BRR_SAMPLING16(pclk, huart->Init.BaudRate);
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
huart->Instance->BRR = UART_BRR_SAMPLING16(pclk, huart->Init.BaudRate);
|
||||||
#endif /* USART_CR1_OVER8 */
|
#endif /* USART_CR1_OVER8 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -32,7 +32,7 @@ ADC1.SamplingTime-6\#ChannelRegularConversion=ADC_SAMPLETIME_239CYCLES_5
|
||||||
ADC1.WatchdogChannel=ADC_CHANNEL_TEMPSENSOR
|
ADC1.WatchdogChannel=ADC_CHANNEL_TEMPSENSOR
|
||||||
ADC1.WatchdogMode=ADC_ANALOGWATCHDOG_SINGLE_REG
|
ADC1.WatchdogMode=ADC_ANALOGWATCHDOG_SINGLE_REG
|
||||||
ADC1.master=1
|
ADC1.master=1
|
||||||
ARM.CMSIS.5.6.0.CMSISJjCORE=true
|
ARM.CMSIS.5.6.0.CMSISJjCORE_Checked=false
|
||||||
ARM.CMSIS.5.6.0.CMSISJjDSP=Library
|
ARM.CMSIS.5.6.0.CMSISJjDSP=Library
|
||||||
ARM.CMSIS.5.6.0.CMSISJjNNOoLib=true
|
ARM.CMSIS.5.6.0.CMSISJjNNOoLib=true
|
||||||
ARM.CMSIS.5.6.0.CMSISOoDriverJjCANJjCustom=true
|
ARM.CMSIS.5.6.0.CMSISOoDriverJjCANJjCustom=true
|
||||||
|
@ -53,8 +53,8 @@ ARM.CMSIS.5.6.0.CMSISOoDriverJjWiFiJjCustom=true
|
||||||
ARM.CMSIS.5.6.0.DeviceJjIRQOoControllerJjGIC=true
|
ARM.CMSIS.5.6.0.DeviceJjIRQOoControllerJjGIC=true
|
||||||
ARM.CMSIS.5.6.0.DeviceJjOSOoTickJjPrivateOoTimer=true
|
ARM.CMSIS.5.6.0.DeviceJjOSOoTickJjPrivateOoTimer=true
|
||||||
ARM.CMSIS.5.6.0.DeviceJjStartup=COoStartup
|
ARM.CMSIS.5.6.0.DeviceJjStartup=COoStartup
|
||||||
ARM.CMSIS.5.6.0.IPParameters=CMSISJjCORE,CMSISJjNNOoLib,DeviceJjIRQOoControllerJjGIC,DeviceJjOSOoTickJjPrivateOoTimer,CMSISOoDriverJjUSARTJjCustom,CMSISOoDriverJjSPIJjCustom,CMSISOoDriverJjSAIJjCustom,CMSISOoDriverJjI2CJjCustom,CMSISOoDriverJjCANJjCustom,CMSISOoDriverJjFlashJjCustom,CMSISOoDriverJjMCIJjCustom,CMSISOoDriverJjNANDJjCustom,CMSISOoDriverJjEthernetJjCustom,CMSISOoDriverJjEthernetOoMACJjCustom,CMSISOoDriverJjEthernetOoPHYJjCustom,CMSISOoDriverJjUSBOoDeviceJjCustom,CMSISOoDriverJjUSBOoHostJjCustom,CMSISOoDriverJjWiFiJjCustom,CMSISJjDSP,DeviceJjStartup
|
ARM.CMSIS.5.6.0.IPParameters=CMSISJjNNOoLib,DeviceJjIRQOoControllerJjGIC,DeviceJjOSOoTickJjPrivateOoTimer,CMSISOoDriverJjUSARTJjCustom,CMSISOoDriverJjSPIJjCustom,CMSISOoDriverJjSAIJjCustom,CMSISOoDriverJjI2CJjCustom,CMSISOoDriverJjCANJjCustom,CMSISOoDriverJjFlashJjCustom,CMSISOoDriverJjMCIJjCustom,CMSISOoDriverJjNANDJjCustom,CMSISOoDriverJjEthernetJjCustom,CMSISOoDriverJjEthernetOoMACJjCustom,CMSISOoDriverJjEthernetOoPHYJjCustom,CMSISOoDriverJjUSBOoDeviceJjCustom,CMSISOoDriverJjUSBOoHostJjCustom,CMSISOoDriverJjWiFiJjCustom,CMSISJjDSP,DeviceJjStartup
|
||||||
ARM.CMSIS.5.6.0_SwParameter=CMSISOoDriverJjUSARTJjCustom\:true;DeviceJjOSOoTickJjPrivateOoTimer\:true;CMSISOoDriverJjUSBOoDeviceJjCustom\:true;CMSISOoDriverJjCANJjCustom\:true;CMSISJjCORE\:true;CMSISOoDriverJjFlashJjCustom\:true;CMSISOoDriverJjNANDJjCustom\:true;CMSISOoDriverJjEthernetJjCustom\:true;CMSISOoDriverJjEthernetOoMACJjCustom\:true;CMSISOoDriverJjUSBOoHostJjCustom\:true;CMSISOoDriverJjSAIJjCustom\:true;CMSISOoDriverJjWiFiJjCustom\:true;CMSISJjDSP\:Library;CMSISOoDriverJjSPIJjCustom\:true;CMSISOoDriverJjMCIJjCustom\:true;CMSISOoDriverJjEthernetOoPHYJjCustom\:true;DeviceJjIRQOoControllerJjGIC\:true;CMSISJjNNOoLib\:true;DeviceJjStartup\:COoStartup;CMSISOoDriverJjI2CJjCustom\:true;
|
ARM.CMSIS.5.6.0_SwParameter=CMSISOoDriverJjUSARTJjCustom\:true;DeviceJjOSOoTickJjPrivateOoTimer\:true;CMSISOoDriverJjUSBOoDeviceJjCustom\:true;CMSISOoDriverJjCANJjCustom\:true;CMSISJjCORE\:false;CMSISOoDriverJjFlashJjCustom\:true;CMSISOoDriverJjNANDJjCustom\:true;CMSISOoDriverJjEthernetJjCustom\:true;CMSISOoDriverJjEthernetOoMACJjCustom\:true;CMSISOoDriverJjUSBOoHostJjCustom\:true;CMSISOoDriverJjSAIJjCustom\:true;CMSISOoDriverJjWiFiJjCustom\:true;CMSISJjDSP\:Library;CMSISOoDriverJjSPIJjCustom\:true;CMSISOoDriverJjMCIJjCustom\:true;CMSISOoDriverJjEthernetOoPHYJjCustom\:true;DeviceJjIRQOoControllerJjGIC\:true;CMSISJjNNOoLib\:true;CMSISOoDriverJjI2CJjCustom\:true;
|
||||||
Dma.ADC1.0.Direction=DMA_PERIPH_TO_MEMORY
|
Dma.ADC1.0.Direction=DMA_PERIPH_TO_MEMORY
|
||||||
Dma.ADC1.0.Instance=DMA1_Channel1
|
Dma.ADC1.0.Instance=DMA1_Channel1
|
||||||
Dma.ADC1.0.MemDataAlignment=DMA_MDATAALIGN_WORD
|
Dma.ADC1.0.MemDataAlignment=DMA_MDATAALIGN_WORD
|
||||||
|
@ -185,8 +185,8 @@ Mcu.ThirdParty0=ARM.CMSIS.5.6.0
|
||||||
Mcu.ThirdPartyNb=1
|
Mcu.ThirdPartyNb=1
|
||||||
Mcu.UserConstants=
|
Mcu.UserConstants=
|
||||||
Mcu.UserName=STM32F107VCTx
|
Mcu.UserName=STM32F107VCTx
|
||||||
MxCube.Version=5.6.1
|
MxCube.Version=6.0.1
|
||||||
MxDb.Version=DB.5.0.60
|
MxDb.Version=DB.6.0.0
|
||||||
NVIC.ADC1_2_IRQn=true\:5\:0\:false\:true\:true\:8\:true\:true\:true
|
NVIC.ADC1_2_IRQn=true\:5\:0\:false\:true\:true\:8\:true\:true\:true
|
||||||
NVIC.BusFault_IRQn=true\:5\:0\:false\:false\:true\:true\:false\:false
|
NVIC.BusFault_IRQn=true\:5\:0\:false\:false\:true\:true\:false\:false
|
||||||
NVIC.DMA1_Channel1_IRQn=true\:5\:0\:false\:true\:true\:9\:true\:false\:true
|
NVIC.DMA1_Channel1_IRQn=true\:5\:0\:false\:true\:true\:9\:true\:false\:true
|
||||||
|
@ -201,19 +201,22 @@ NVIC.I2C1_ER_IRQn=true\:5\:0\:true\:true\:true\:7\:true\:true\:true
|
||||||
NVIC.I2C1_EV_IRQn=true\:5\:0\:false\:true\:true\:6\:true\:true\:true
|
NVIC.I2C1_EV_IRQn=true\:5\:0\:false\:true\:true\:6\:true\:true\:true
|
||||||
NVIC.MemoryManagement_IRQn=true\:5\:0\:false\:false\:true\:true\:false\:false
|
NVIC.MemoryManagement_IRQn=true\:5\:0\:false\:false\:true\:true\:false\:false
|
||||||
NVIC.NonMaskableInt_IRQn=true\:0\:0\:false\:false\:true\:false\:false\:true
|
NVIC.NonMaskableInt_IRQn=true\:0\:0\:false\:false\:true\:false\:false\:true
|
||||||
NVIC.OTG_FS_IRQn=true\:5\:0\:false\:true\:true\:5\:true\:false\:true
|
NVIC.OTG_FS_IRQn=true\:5\:0\:false\:true\:true\:4\:true\:false\:true
|
||||||
NVIC.PVD_IRQn=true\:5\:0\:true\:true\:true\:1\:true\:true\:true
|
NVIC.PVD_IRQn=true\:5\:0\:true\:true\:true\:1\:true\:true\:true
|
||||||
NVIC.PendSV_IRQn=true\:15\:0\:false\:false\:false\:true\:false\:false
|
NVIC.PendSV_IRQn=true\:15\:0\:false\:false\:false\:true\:false\:false
|
||||||
NVIC.PriorityGroup=NVIC_PRIORITYGROUP_4
|
NVIC.PriorityGroup=NVIC_PRIORITYGROUP_4
|
||||||
NVIC.RCC_IRQn=true\:5\:0\:false\:true\:true\:3\:true\:true\:false
|
NVIC.RCC_IRQn=true\:5\:0\:false\:true\:true\:3\:true\:true\:false
|
||||||
NVIC.RTC_IRQn=true\:5\:0\:true\:false\:true\:true\:true\:true
|
NVIC.RTC_IRQn=true\:5\:0\:true\:false\:true\:true\:true\:true
|
||||||
NVIC.SVCall_IRQn=true\:0\:0\:false\:false\:false\:false\:false\:false
|
NVIC.SVCall_IRQn=true\:0\:0\:false\:false\:false\:false\:false\:false
|
||||||
|
NVIC.SavedPendsvIrqHandlerGenerated=true
|
||||||
|
NVIC.SavedSvcallIrqHandlerGenerated=true
|
||||||
|
NVIC.SavedSystickIrqHandlerGenerated=true
|
||||||
NVIC.SysTick_IRQn=true\:15\:0\:false\:false\:false\:true\:false\:false
|
NVIC.SysTick_IRQn=true\:15\:0\:false\:false\:false\:true\:false\:false
|
||||||
NVIC.TIM1_UP_IRQn=true\:0\:0\:false\:false\:true\:false\:false\:true
|
NVIC.TIM1_UP_IRQn=true\:0\:0\:false\:false\:true\:false\:false\:true
|
||||||
NVIC.TimeBase=TIM1_UP_IRQn
|
NVIC.TimeBase=TIM1_UP_IRQn
|
||||||
NVIC.TimeBaseIP=TIM1
|
NVIC.TimeBaseIP=TIM1
|
||||||
NVIC.UART4_IRQn=true\:5\:0\:false\:true\:true\:4\:true\:true\:true
|
NVIC.UART4_IRQn=true\:5\:0\:false\:true\:true\:5\:true\:true\:true
|
||||||
NVIC.USART1_IRQn=true\:5\:0\:false\:false\:true\:true\:true\:true
|
NVIC.USART1_IRQn=true\:5\:0\:false\:true\:true\:10\:true\:true\:true
|
||||||
NVIC.UsageFault_IRQn=true\:5\:0\:false\:false\:true\:true\:false\:false
|
NVIC.UsageFault_IRQn=true\:5\:0\:false\:false\:true\:true\:false\:false
|
||||||
OSC_IN.Mode=HSE-External-Oscillator
|
OSC_IN.Mode=HSE-External-Oscillator
|
||||||
OSC_IN.Signal=RCC_OSC_IN
|
OSC_IN.Signal=RCC_OSC_IN
|
||||||
|
@ -372,6 +375,44 @@ PC8.GPIOParameters=GPIO_Label
|
||||||
PC8.GPIO_Label=SOC_U2_HUB_PWR_STA
|
PC8.GPIO_Label=SOC_U2_HUB_PWR_STA
|
||||||
PC8.Locked=true
|
PC8.Locked=true
|
||||||
PC8.Signal=GPXTI8
|
PC8.Signal=GPXTI8
|
||||||
|
PCC.Checker=false
|
||||||
|
PCC.Line=STM32F105/107
|
||||||
|
PCC.MCU=STM32F107V(B-C)Tx
|
||||||
|
PCC.PartNumber=STM32F107VCTx
|
||||||
|
PCC.Seq0=2
|
||||||
|
PCC.Seq0.Step0.Average_Current=2.9 mA
|
||||||
|
PCC.Seq0.Step0.CPU_Frequency=4 MHz
|
||||||
|
PCC.Seq0.Step0.Category=In DS Table
|
||||||
|
PCC.Seq0.Step0.DMIPS=5.0
|
||||||
|
PCC.Seq0.Step0.Duration=0.1 ms
|
||||||
|
PCC.Seq0.Step0.Frequency=8 MHz
|
||||||
|
PCC.Seq0.Step0.Memory=FLASH
|
||||||
|
PCC.Seq0.Step0.Mode=RUN
|
||||||
|
PCC.Seq0.Step0.Oscillator=HSE
|
||||||
|
PCC.Seq0.Step0.Peripherals=
|
||||||
|
PCC.Seq0.Step0.TaMax=104.56
|
||||||
|
PCC.Seq0.Step0.User's_Consumption=0 mA
|
||||||
|
PCC.Seq0.Step0.Vcore=No Scale
|
||||||
|
PCC.Seq0.Step0.Vdd=3.3
|
||||||
|
PCC.Seq0.Step0.Voltage_Source=Battery
|
||||||
|
PCC.Seq0.Step1.Average_Current=26 \u00B5A
|
||||||
|
PCC.Seq0.Step1.CPU_Frequency=0 Hz
|
||||||
|
PCC.Seq0.Step1.Category=In DS Table
|
||||||
|
PCC.Seq0.Step1.DMIPS=0.0
|
||||||
|
PCC.Seq0.Step1.Duration=0.9 ms
|
||||||
|
PCC.Seq0.Step1.Frequency=0 Hz
|
||||||
|
PCC.Seq0.Step1.Memory=n/a
|
||||||
|
PCC.Seq0.Step1.Mode=STOP
|
||||||
|
PCC.Seq0.Step1.Oscillator=Regulator_LP
|
||||||
|
PCC.Seq0.Step1.Peripherals=
|
||||||
|
PCC.Seq0.Step1.TaMax=105
|
||||||
|
PCC.Seq0.Step1.User's_Consumption=0 mA
|
||||||
|
PCC.Seq0.Step1.Vcore=No Scale
|
||||||
|
PCC.Seq0.Step1.Vdd=3.3
|
||||||
|
PCC.Seq0.Step1.Voltage_Source=Battery
|
||||||
|
PCC.Series=STM32F1
|
||||||
|
PCC.Temperature=25
|
||||||
|
PCC.Vdd=3.3
|
||||||
PD0.GPIOParameters=GPIO_Label
|
PD0.GPIOParameters=GPIO_Label
|
||||||
PD0.GPIO_Label=SOC_U3_HUB_PWR_CTL
|
PD0.GPIO_Label=SOC_U3_HUB_PWR_CTL
|
||||||
PD0.Locked=true
|
PD0.Locked=true
|
||||||
|
@ -498,7 +539,7 @@ ProjectManager.CustomerFirmwarePackage=
|
||||||
ProjectManager.DefaultFWLocation=true
|
ProjectManager.DefaultFWLocation=true
|
||||||
ProjectManager.DeletePrevious=true
|
ProjectManager.DeletePrevious=true
|
||||||
ProjectManager.DeviceId=STM32F107VCTx
|
ProjectManager.DeviceId=STM32F107VCTx
|
||||||
ProjectManager.FirmwarePackage=STM32Cube FW_F1 V1.8.0
|
ProjectManager.FirmwarePackage=STM32Cube FW_F1 V1.8.3
|
||||||
ProjectManager.FreePins=false
|
ProjectManager.FreePins=false
|
||||||
ProjectManager.HalAssertFull=false
|
ProjectManager.HalAssertFull=false
|
||||||
ProjectManager.HeapSize=0x400
|
ProjectManager.HeapSize=0x400
|
||||||
|
@ -511,6 +552,7 @@ ProjectManager.PreviousToolchain=
|
||||||
ProjectManager.ProjectBuild=false
|
ProjectManager.ProjectBuild=false
|
||||||
ProjectManager.ProjectFileName=NaviKit_stm32.ioc
|
ProjectManager.ProjectFileName=NaviKit_stm32.ioc
|
||||||
ProjectManager.ProjectName=NaviKit_stm32
|
ProjectManager.ProjectName=NaviKit_stm32
|
||||||
|
ProjectManager.RegisterCallBack=
|
||||||
ProjectManager.StackSize=0x800
|
ProjectManager.StackSize=0x800
|
||||||
ProjectManager.TargetToolchain=STM32CubeIDE
|
ProjectManager.TargetToolchain=STM32CubeIDE
|
||||||
ProjectManager.ToolChainLocation=
|
ProjectManager.ToolChainLocation=
|
||||||
|
|
|
@ -67,7 +67,7 @@ void MX_USB_DEVICE_Init(void)
|
||||||
/* USER CODE BEGIN USB_DEVICE_Init_PreTreatment */
|
/* USER CODE BEGIN USB_DEVICE_Init_PreTreatment */
|
||||||
|
|
||||||
/* USER CODE END USB_DEVICE_Init_PreTreatment */
|
/* USER CODE END USB_DEVICE_Init_PreTreatment */
|
||||||
|
|
||||||
/* Init Device Library, add supported class and start the library. */
|
/* Init Device Library, add supported class and start the library. */
|
||||||
if (USBD_Init(&hUsbDeviceFS, &FS_Desc, DEVICE_FS) != USBD_OK)
|
if (USBD_Init(&hUsbDeviceFS, &FS_Desc, DEVICE_FS) != USBD_OK)
|
||||||
{
|
{
|
||||||
|
|
|
@ -251,10 +251,11 @@ static int8_t CDC_Control_FS(uint8_t cmd, uint8_t* pbuf, uint16_t length)
|
||||||
* through this function.
|
* through this function.
|
||||||
*
|
*
|
||||||
* @note
|
* @note
|
||||||
* This function will block any OUT packet reception on USB endpoint
|
* This function will issue a NAK packet on any OUT packet received on
|
||||||
* untill exiting this function. If you exit this function before transfer
|
* USB endpoint until exiting this function. If you exit this function
|
||||||
* is complete on CDC interface (ie. using DMA controller) it will result
|
* before transfer is complete on CDC interface (ie. using DMA controller)
|
||||||
* in receiving more data while previous ones are still not sent.
|
* it will result in receiving more data while previous ones are still
|
||||||
|
* not sent.
|
||||||
*
|
*
|
||||||
* @param Buf: Buffer of data to be received
|
* @param Buf: Buffer of data to be received
|
||||||
* @param Len: Number of data received (in bytes)
|
* @param Len: Number of data received (in bytes)
|
||||||
|
|
|
@ -38,11 +38,11 @@
|
||||||
* @brief For Usb device.
|
* @brief For Usb device.
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** @defgroup USBD_CDC_IF USBD_CDC_IF
|
/** @defgroup USBD_CDC_IF USBD_CDC_IF
|
||||||
* @brief Usb VCP device module
|
* @brief Usb VCP device module
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** @defgroup USBD_CDC_IF_Exported_Defines USBD_CDC_IF_Exported_Defines
|
/** @defgroup USBD_CDC_IF_Exported_Defines USBD_CDC_IF_Exported_Defines
|
||||||
* @brief Defines.
|
* @brief Defines.
|
||||||
|
|
|
@ -95,19 +95,18 @@
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** @defgroup USBD_DESC_Private_FunctionPrototypes USBD_DESC_Private_FunctionPrototypes
|
/** @defgroup USBD_DESC_Private_FunctionPrototypes USBD_DESC_Private_FunctionPrototypes
|
||||||
* @brief Private functions declaration.
|
* @brief Private functions declaration.
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void Get_SerialNum(void);
|
static void Get_SerialNum(void);
|
||||||
static void IntToUnicode(uint32_t value, uint8_t * pbuf, uint8_t len);
|
static void IntToUnicode(uint32_t value, uint8_t * pbuf, uint8_t len);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/** @defgroup USBD_DESC_Private_FunctionPrototypes USBD_DESC_Private_FunctionPrototypes
|
/** @defgroup USBD_DESC_Private_FunctionPrototypes USBD_DESC_Private_FunctionPrototypes
|
||||||
* @brief Private functions declaration for FS.
|
* @brief Private functions declaration for FS.
|
||||||
|
@ -199,7 +198,7 @@ __ALIGN_BEGIN uint8_t USBD_LangIDDesc[USB_LEN_LANGID_STR_DESC] __ALIGN_END =
|
||||||
__ALIGN_BEGIN uint8_t USBD_StrDesc[USBD_MAX_STR_DESC_SIZ] __ALIGN_END;
|
__ALIGN_BEGIN uint8_t USBD_StrDesc[USBD_MAX_STR_DESC_SIZ] __ALIGN_END;
|
||||||
|
|
||||||
#if defined ( __ICCARM__ ) /*!< IAR Compiler */
|
#if defined ( __ICCARM__ ) /*!< IAR Compiler */
|
||||||
#pragma data_alignment=4
|
#pragma data_alignment=4
|
||||||
#endif
|
#endif
|
||||||
__ALIGN_BEGIN uint8_t USBD_StringSerial[USB_SIZ_STRING_SERIAL] __ALIGN_END = {
|
__ALIGN_BEGIN uint8_t USBD_StringSerial[USB_SIZ_STRING_SERIAL] __ALIGN_END = {
|
||||||
USB_SIZ_STRING_SERIAL,
|
USB_SIZ_STRING_SERIAL,
|
||||||
|
@ -332,8 +331,8 @@ uint8_t * USBD_FS_InterfaceStrDescriptor(USBD_SpeedTypeDef speed, uint16_t *leng
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Create the serial number string descriptor
|
* @brief Create the serial number string descriptor
|
||||||
* @param None
|
* @param None
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
static void Get_SerialNum(void)
|
static void Get_SerialNum(void)
|
||||||
|
@ -354,9 +353,9 @@ static void Get_SerialNum(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Convert Hex 32Bits value into char
|
* @brief Convert Hex 32Bits value into char
|
||||||
* @param value: value to convert
|
* @param value: value to convert
|
||||||
* @param pbuf: pointer to the buffer
|
* @param pbuf: pointer to the buffer
|
||||||
* @param len: buffer length
|
* @param len: buffer length
|
||||||
* @retval None
|
* @retval None
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
*
|
*
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
*/
|
*/
|
||||||
/* USER CODE END Header */
|
/* USER CODE END Header */
|
||||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
#ifndef __USBD_DESC__C__
|
#ifndef __USBD_DESC__C__
|
||||||
#define __USBD_DESC__C__
|
#define __USBD_DESC__C__
|
||||||
|
@ -41,7 +41,7 @@
|
||||||
* @brief Usb device descriptors module.
|
* @brief Usb device descriptors module.
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** @defgroup USBD_DESC_Exported_Constants USBD_DESC_Exported_Constants
|
/** @defgroup USBD_DESC_Exported_Constants USBD_DESC_Exported_Constants
|
||||||
* @brief Constants.
|
* @brief Constants.
|
||||||
* @{
|
* @{
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
*
|
*
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
*/
|
*/
|
||||||
/* USER CODE END Header */
|
/* USER CODE END Header */
|
||||||
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* Includes ------------------------------------------------------------------*/
|
||||||
#include "stm32f1xx.h"
|
#include "stm32f1xx.h"
|
||||||
|
@ -166,7 +166,7 @@ static void PCD_ResetCallback(PCD_HandleTypeDef *hpcd)
|
||||||
#else
|
#else
|
||||||
void HAL_PCD_ResetCallback(PCD_HandleTypeDef *hpcd)
|
void HAL_PCD_ResetCallback(PCD_HandleTypeDef *hpcd)
|
||||||
#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */
|
#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */
|
||||||
{
|
{
|
||||||
USBD_SpeedTypeDef speed = USBD_SPEED_FULL;
|
USBD_SpeedTypeDef speed = USBD_SPEED_FULL;
|
||||||
|
|
||||||
if ( hpcd->Init.speed != PCD_SPEED_FULL)
|
if ( hpcd->Init.speed != PCD_SPEED_FULL)
|
||||||
|
@ -297,7 +297,7 @@ USBD_StatusTypeDef USBD_LL_Init(USBD_HandleTypeDef *pdev)
|
||||||
/* Link the driver to the stack. */
|
/* Link the driver to the stack. */
|
||||||
hpcd_USB_OTG_FS.pData = pdev;
|
hpcd_USB_OTG_FS.pData = pdev;
|
||||||
pdev->pData = &hpcd_USB_OTG_FS;
|
pdev->pData = &hpcd_USB_OTG_FS;
|
||||||
|
|
||||||
hpcd_USB_OTG_FS.Instance = USB_OTG_FS;
|
hpcd_USB_OTG_FS.Instance = USB_OTG_FS;
|
||||||
hpcd_USB_OTG_FS.Init.dev_endpoints = 4;
|
hpcd_USB_OTG_FS.Init.dev_endpoints = 4;
|
||||||
hpcd_USB_OTG_FS.Init.speed = PCD_SPEED_FULL;
|
hpcd_USB_OTG_FS.Init.speed = PCD_SPEED_FULL;
|
||||||
|
@ -344,8 +344,8 @@ USBD_StatusTypeDef USBD_LL_DeInit(USBD_HandleTypeDef *pdev)
|
||||||
hal_status = HAL_PCD_DeInit(pdev->pData);
|
hal_status = HAL_PCD_DeInit(pdev->pData);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -357,11 +357,11 @@ USBD_StatusTypeDef USBD_LL_Start(USBD_HandleTypeDef *pdev)
|
||||||
{
|
{
|
||||||
HAL_StatusTypeDef hal_status = HAL_OK;
|
HAL_StatusTypeDef hal_status = HAL_OK;
|
||||||
USBD_StatusTypeDef usb_status = USBD_OK;
|
USBD_StatusTypeDef usb_status = USBD_OK;
|
||||||
|
|
||||||
hal_status = HAL_PCD_Start(pdev->pData);
|
hal_status = HAL_PCD_Start(pdev->pData);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -378,7 +378,7 @@ USBD_StatusTypeDef USBD_LL_Stop(USBD_HandleTypeDef *pdev)
|
||||||
hal_status = HAL_PCD_Stop(pdev->pData);
|
hal_status = HAL_PCD_Stop(pdev->pData);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -398,7 +398,7 @@ USBD_StatusTypeDef USBD_LL_OpenEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr, uin
|
||||||
hal_status = HAL_PCD_EP_Open(pdev->pData, ep_addr, ep_mps, ep_type);
|
hal_status = HAL_PCD_EP_Open(pdev->pData, ep_addr, ep_mps, ep_type);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -412,12 +412,12 @@ USBD_StatusTypeDef USBD_LL_CloseEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
||||||
{
|
{
|
||||||
HAL_StatusTypeDef hal_status = HAL_OK;
|
HAL_StatusTypeDef hal_status = HAL_OK;
|
||||||
USBD_StatusTypeDef usb_status = USBD_OK;
|
USBD_StatusTypeDef usb_status = USBD_OK;
|
||||||
|
|
||||||
hal_status = HAL_PCD_EP_Close(pdev->pData, ep_addr);
|
hal_status = HAL_PCD_EP_Close(pdev->pData, ep_addr);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -430,12 +430,12 @@ USBD_StatusTypeDef USBD_LL_FlushEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
||||||
{
|
{
|
||||||
HAL_StatusTypeDef hal_status = HAL_OK;
|
HAL_StatusTypeDef hal_status = HAL_OK;
|
||||||
USBD_StatusTypeDef usb_status = USBD_OK;
|
USBD_StatusTypeDef usb_status = USBD_OK;
|
||||||
|
|
||||||
hal_status = HAL_PCD_EP_Flush(pdev->pData, ep_addr);
|
hal_status = HAL_PCD_EP_Flush(pdev->pData, ep_addr);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -448,12 +448,12 @@ USBD_StatusTypeDef USBD_LL_StallEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
||||||
{
|
{
|
||||||
HAL_StatusTypeDef hal_status = HAL_OK;
|
HAL_StatusTypeDef hal_status = HAL_OK;
|
||||||
USBD_StatusTypeDef usb_status = USBD_OK;
|
USBD_StatusTypeDef usb_status = USBD_OK;
|
||||||
|
|
||||||
hal_status = HAL_PCD_EP_SetStall(pdev->pData, ep_addr);
|
hal_status = HAL_PCD_EP_SetStall(pdev->pData, ep_addr);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -466,12 +466,12 @@ USBD_StatusTypeDef USBD_LL_ClearStallEP(USBD_HandleTypeDef *pdev, uint8_t ep_add
|
||||||
{
|
{
|
||||||
HAL_StatusTypeDef hal_status = HAL_OK;
|
HAL_StatusTypeDef hal_status = HAL_OK;
|
||||||
USBD_StatusTypeDef usb_status = USBD_OK;
|
USBD_StatusTypeDef usb_status = USBD_OK;
|
||||||
|
|
||||||
hal_status = HAL_PCD_EP_ClrStall(pdev->pData, ep_addr);
|
hal_status = HAL_PCD_EP_ClrStall(pdev->pData, ep_addr);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -483,14 +483,14 @@ USBD_StatusTypeDef USBD_LL_ClearStallEP(USBD_HandleTypeDef *pdev, uint8_t ep_add
|
||||||
uint8_t USBD_LL_IsStallEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
uint8_t USBD_LL_IsStallEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
||||||
{
|
{
|
||||||
PCD_HandleTypeDef *hpcd = (PCD_HandleTypeDef*) pdev->pData;
|
PCD_HandleTypeDef *hpcd = (PCD_HandleTypeDef*) pdev->pData;
|
||||||
|
|
||||||
if((ep_addr & 0x80) == 0x80)
|
if((ep_addr & 0x80) == 0x80)
|
||||||
{
|
{
|
||||||
return hpcd->IN_ep[ep_addr & 0x7F].is_stall;
|
return hpcd->IN_ep[ep_addr & 0x7F].is_stall;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return hpcd->OUT_ep[ep_addr & 0x7F].is_stall;
|
return hpcd->OUT_ep[ep_addr & 0x7F].is_stall;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -504,12 +504,12 @@ USBD_StatusTypeDef USBD_LL_SetUSBAddress(USBD_HandleTypeDef *pdev, uint8_t dev_a
|
||||||
{
|
{
|
||||||
HAL_StatusTypeDef hal_status = HAL_OK;
|
HAL_StatusTypeDef hal_status = HAL_OK;
|
||||||
USBD_StatusTypeDef usb_status = USBD_OK;
|
USBD_StatusTypeDef usb_status = USBD_OK;
|
||||||
|
|
||||||
hal_status = HAL_PCD_SetAddress(pdev->pData, dev_addr);
|
hal_status = HAL_PCD_SetAddress(pdev->pData, dev_addr);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -517,7 +517,7 @@ USBD_StatusTypeDef USBD_LL_SetUSBAddress(USBD_HandleTypeDef *pdev, uint8_t dev_a
|
||||||
* @param pdev: Device handle
|
* @param pdev: Device handle
|
||||||
* @param ep_addr: Endpoint number
|
* @param ep_addr: Endpoint number
|
||||||
* @param pbuf: Pointer to data to be sent
|
* @param pbuf: Pointer to data to be sent
|
||||||
* @param size: Data size
|
* @param size: Data size
|
||||||
* @retval USBD status
|
* @retval USBD status
|
||||||
*/
|
*/
|
||||||
USBD_StatusTypeDef USBD_LL_Transmit(USBD_HandleTypeDef *pdev, uint8_t ep_addr, uint8_t *pbuf, uint16_t size)
|
USBD_StatusTypeDef USBD_LL_Transmit(USBD_HandleTypeDef *pdev, uint8_t ep_addr, uint8_t *pbuf, uint16_t size)
|
||||||
|
@ -526,10 +526,10 @@ USBD_StatusTypeDef USBD_LL_Transmit(USBD_HandleTypeDef *pdev, uint8_t ep_addr, u
|
||||||
USBD_StatusTypeDef usb_status = USBD_OK;
|
USBD_StatusTypeDef usb_status = USBD_OK;
|
||||||
|
|
||||||
hal_status = HAL_PCD_EP_Transmit(pdev->pData, ep_addr, pbuf, size);
|
hal_status = HAL_PCD_EP_Transmit(pdev->pData, ep_addr, pbuf, size);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -546,10 +546,10 @@ USBD_StatusTypeDef USBD_LL_PrepareReceive(USBD_HandleTypeDef *pdev, uint8_t ep_a
|
||||||
USBD_StatusTypeDef usb_status = USBD_OK;
|
USBD_StatusTypeDef usb_status = USBD_OK;
|
||||||
|
|
||||||
hal_status = HAL_PCD_EP_Receive(pdev->pData, ep_addr, pbuf, size);
|
hal_status = HAL_PCD_EP_Receive(pdev->pData, ep_addr, pbuf, size);
|
||||||
|
|
||||||
usb_status = USBD_Get_USB_Status(hal_status);
|
usb_status = USBD_Get_USB_Status(hal_status);
|
||||||
|
|
||||||
return usb_status;
|
return usb_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue