Init
This commit is contained in:
		
						commit
						35c019f62f
					
				
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							|  | @ -0,0 +1,779 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     at32f435_437.h | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    at32f435_437 header file | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| #ifndef __AT32F435_437_H | ||||
| #define __AT32F435_437_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| #if defined (__CC_ARM) | ||||
|  #pragma anon_unions | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /** @addtogroup CMSIS
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup AT32F435_437
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| /** @addtogroup Library_configuration_section
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * tip: to avoid modifying this file each time you need to switch between these | ||||
|   *      devices, you can define the device in your toolchain compiler preprocessor. | ||||
|   */ | ||||
| 
 | ||||
| #if !defined (AT32F435CCU7) && !defined (AT32F435CGU7) && !defined (AT32F435CMU7) && \ | ||||
|     !defined (AT32F435CCT7) && !defined (AT32F435CGT7) && !defined (AT32F435CMT7) && \ | ||||
|     !defined (AT32F435RCT7) && !defined (AT32F435RGT7) && !defined (AT32F435RMT7) && \ | ||||
|     !defined (AT32F435VCT7) && !defined (AT32F435VGT7) && !defined (AT32F435VMT7) && \ | ||||
|     !defined (AT32F435ZCT7) && !defined (AT32F435ZGT7) && !defined (AT32F435ZMT7) && \ | ||||
|     !defined (AT32F437RCT7) && !defined (AT32F437RGT7) && !defined (AT32F437RMT7) && \ | ||||
|     !defined (AT32F437VCT7) && !defined (AT32F437VGT7) && !defined (AT32F437VMT7) && \ | ||||
|     !defined (AT32F437ZCT7) && !defined (AT32F437ZGT7) && !defined (AT32F437ZMT7) | ||||
| 
 | ||||
|     #error "Please select first the target device used in your application (in at32f435_437.h file)" | ||||
| #endif | ||||
| 
 | ||||
| #if defined (AT32F435CCU7) || defined (AT32F435CGU7) || defined (AT32F435CMU7) || \ | ||||
|     defined (AT32F435CCT7) || defined (AT32F435CGT7) || defined (AT32F435CMT7) || \ | ||||
|     defined (AT32F435RCT7) || defined (AT32F435RGT7) || defined (AT32F435RMT7) || \ | ||||
|     defined (AT32F435VCT7) || defined (AT32F435VGT7) || defined (AT32F435VMT7) || \ | ||||
|     defined (AT32F435ZCT7) || defined (AT32F435ZGT7) || defined (AT32F435ZMT7) | ||||
| 
 | ||||
|     #define AT32F435xx | ||||
| #endif | ||||
| 
 | ||||
| #if defined (AT32F437RCT7) || defined (AT32F437RGT7) || defined (AT32F437RMT7) || \ | ||||
|     defined (AT32F437VCT7) || defined (AT32F437VGT7) || defined (AT32F437VMT7) || \ | ||||
|     defined (AT32F437ZCT7) || defined (AT32F437ZGT7) || defined (AT32F437ZMT7) | ||||
| 
 | ||||
|     #define AT32F437xx | ||||
| #endif | ||||
| 
 | ||||
| #ifndef USE_STDPERIPH_DRIVER | ||||
| /**
 | ||||
|   * @brief comment the line below if you will not use the peripherals drivers. | ||||
|   * in this case, these drivers will not be included and the application code will  | ||||
|   * be based on direct access to peripherals registers  | ||||
|   */ | ||||
|   #ifdef _RTE_ | ||||
|     #include "RTE_Components.h" | ||||
|     #ifdef RTE_DEVICE_STDPERIPH_FRAMEWORK | ||||
|       #define USE_STDPERIPH_DRIVER | ||||
|     #endif | ||||
|   #endif | ||||
| #endif | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief at32f435_437 standard peripheral library version number | ||||
|   */ | ||||
| #define __AT32F435_437_LIBRARY_VERSION_MAJOR    (0x02) /*!< [31:24] major version */ | ||||
| #define __AT32F435_437_LIBRARY_VERSION_MIDDLE   (0x00) /*!< [23:16] middle version */ | ||||
| #define __AT32F435_437_LIBRARY_VERSION_MINOR    (0x04) /*!< [15:8]  minor version */ | ||||
| #define __AT32F435_437_LIBRARY_VERSION_RC       (0x00) /*!< [7:0]  release candidate */ | ||||
| #define __AT32F435_437_LIBRARY_VERSION          ((__AT32F435_437_LIBRARY_VERSION_MAJOR << 24)  | \ | ||||
|                                                  (__AT32F435_437_LIBRARY_VERSION_MIDDLE << 16) | \ | ||||
|                                                  (__AT32F435_437_LIBRARY_VERSION_MINOR << 8)   | \ | ||||
|                                                  (__AT32F435_437_LIBRARY_VERSION_RC)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup configuration_section_for_cmsis
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief configuration of the cortex-m4 processor and core peripherals | ||||
|   */ | ||||
| #define __CM4_REV                 0x0001U  /*!< core revision r0p1                           */ | ||||
| #define __MPU_PRESENT             1        /*!< mpu present                                  */ | ||||
| #define __NVIC_PRIO_BITS          4        /*!< at32 uses 4 bits for the priority levels     */ | ||||
| #define __Vendor_SysTickConfig    0        /*!< set to 1 if different systick config is used */ | ||||
| #define __FPU_PRESENT             1U       /*!< fpu present                                  */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief at32f435_437 interrupt number definition, according to the selected device | ||||
|   *        in @ref library_configuration_section | ||||
|   */ | ||||
| typedef enum IRQn | ||||
| { | ||||
|     /******  cortex-m4 processor exceptions numbers ***************************************************/ | ||||
|     Reset_IRQn                  = -15,    /*!< 1 reset vector, invoked on power up and warm reset   */ | ||||
|     NonMaskableInt_IRQn         = -14,    /*!< 2 non maskable interrupt                             */ | ||||
|     HardFault_IRQn              = -13,    /*!< 3 hard fault, all classes of fault                   */ | ||||
|     MemoryManagement_IRQn       = -12,    /*!< 4 cortex-m4 memory management interrupt              */ | ||||
|     BusFault_IRQn               = -11,    /*!< 5 cortex-m4 bus fault interrupt                      */ | ||||
|     UsageFault_IRQn             = -10,    /*!< 6 cortex-m4 usage fault interrupt                    */ | ||||
|     SVCall_IRQn                 = -5,     /*!< 11 cortex-m4 sv call interrupt                       */ | ||||
|     DebugMonitor_IRQn           = -4,     /*!< 12 cortex-m4 debug monitor interrupt                 */ | ||||
|     PendSV_IRQn                 = -2,     /*!< 14 cortex-m4 pend sv interrupt                       */ | ||||
|     SysTick_IRQn                = -1,     /*!< 15 cortex-m4 system tick interrupt                   */ | ||||
| 
 | ||||
|     /******  at32 specific interrupt numbers *********************************************************/ | ||||
|     WWDT_IRQn                   = 0,      /*!< window watchdog timer interrupt                      */ | ||||
|     PVM_IRQn                    = 1,      /*!< pvm through exint line detection interrupt           */ | ||||
|     TAMP_STAMP_IRQn             = 2,      /*!< tamper and timestamp interrupts through the exint line */ | ||||
|     ERTC_WKUP_IRQn              = 3,      /*!< ertc wakeup through the exint line                   */ | ||||
|     FLASH_IRQn                  = 4,      /*!< flash global interrupt                               */ | ||||
|     CRM_IRQn                    = 5,      /*!< crm global interrupt                                 */ | ||||
|     EXINT0_IRQn                 = 6,      /*!< exint line0 interrupt                                */ | ||||
|     EXINT1_IRQn                 = 7,      /*!< exint line1 interrupt                                */ | ||||
|     EXINT2_IRQn                 = 8,      /*!< exint line2 interrupt                                */ | ||||
|     EXINT3_IRQn                 = 9,      /*!< exint line3 interrupt                                */ | ||||
|     EXINT4_IRQn                 = 10,     /*!< exint line4 interrupt                                */ | ||||
|     EDMA_Stream1_IRQn           = 11,     /*!< edma stream 1 global interrupt                       */ | ||||
|     EDMA_Stream2_IRQn           = 12,     /*!< edma stream 2 global interrupt                       */ | ||||
|     EDMA_Stream3_IRQn           = 13,     /*!< edma stream 3 global interrupt                       */ | ||||
|     EDMA_Stream4_IRQn           = 14,     /*!< edma stream 4 global interrupt                       */ | ||||
|     EDMA_Stream5_IRQn           = 15,     /*!< edma stream 5 global interrupt                       */ | ||||
|     EDMA_Stream6_IRQn           = 16,     /*!< edma stream 6 global interrupt                       */ | ||||
|     EDMA_Stream7_IRQn           = 17,     /*!< edma stream 7 global interrupt                       */ | ||||
| 
 | ||||
| #if defined (AT32F435xx) | ||||
|     ADC1_2_3_IRQn               = 18,     /*!< adc1 adc2 and adc3 global interrupt                  */ | ||||
|     CAN1_TX_IRQn                = 19,     /*!< can1 tx interrupts                                   */ | ||||
|     CAN1_RX0_IRQn               = 20,     /*!< can1 rx0 interrupts                                  */ | ||||
|     CAN1_RX1_IRQn               = 21,     /*!< can1 rx1 interrupt                                   */ | ||||
|     CAN1_SE_IRQn                = 22,     /*!< can1 se interrupt                                    */ | ||||
|     EXINT9_5_IRQn               = 23,     /*!< external line[9:5] interrupts                        */ | ||||
|     TMR1_BRK_TMR9_IRQn          = 24,     /*!< tmr1 brake interrupt                                 */ | ||||
|     TMR1_OVF_TMR10_IRQn         = 25,     /*!< tmr1 overflow interrupt                              */ | ||||
|     TMR1_TRG_HALL_TMR11_IRQn    = 26,     /*!< tmr1 trigger and hall interrupt                      */ | ||||
|     TMR1_CH_IRQn                = 27,     /*!< tmr1 channel interrupt                               */ | ||||
|     TMR2_GLOBAL_IRQn            = 28,     /*!< tmr2 global interrupt                                */ | ||||
|     TMR3_GLOBAL_IRQn            = 29,     /*!< tmr3 global interrupt                                */ | ||||
|     TMR4_GLOBAL_IRQn            = 30,     /*!< tmr4 global interrupt                                */ | ||||
|     I2C1_EVT_IRQn               = 31,     /*!< i2c1 event interrupt                                 */ | ||||
|     I2C1_ERR_IRQn               = 32,     /*!< i2c1 error interrupt                                 */ | ||||
|     I2C2_EVT_IRQn               = 33,     /*!< i2c2 event interrupt                                 */ | ||||
|     I2C2_ERR_IRQn               = 34,     /*!< i2c2 error interrupt                                 */ | ||||
|     SPI1_IRQn                   = 35,     /*!< spi1 global interrupt                                */ | ||||
|     SPI2_I2S2EXT_IRQn           = 36,     /*!< spi2 global interrupt                                */ | ||||
|     USART1_IRQn                 = 37,     /*!< usart1 global interrupt                              */ | ||||
|     USART2_IRQn                 = 38,     /*!< usart2 global interrupt                              */ | ||||
|     USART3_IRQn                 = 39,     /*!< usart3 global interrupt                              */ | ||||
|     EXINT15_10_IRQn             = 40,     /*!< external line[15:10] interrupts                      */ | ||||
|     ERTCAlarm_IRQn              = 41,     /*!< ertc alarm through exint line interrupt              */ | ||||
|     OTGFS1_WKUP_IRQn            = 42,     /*!< otgfs1 wakeup from suspend through exint line interrupt */ | ||||
|     TMR8_BRK_TMR12_IRQn         = 43,     /*!< tmr8 brake interrupt                                 */ | ||||
|     TMR8_OVF_TMR13_IRQn         = 44,     /*!< tmr8 overflow interrupt                              */ | ||||
|     TMR8_TRG_HALL_TMR14_IRQn    = 45,     /*!< tmr8 trigger and hall interrupt                      */ | ||||
|     TMR8_CH_IRQn                = 46,     /*!< tmr8 channel interrupt                               */ | ||||
|     EDMA_Stream8_IRQn           = 47,     /*!< edma stream 8 global interrupt                       */ | ||||
|     XMC_IRQn                    = 48,     /*!< xmc global interrupt                                 */ | ||||
|     SDIO1_IRQn                  = 49,     /*!< sdio global interrupt                                */ | ||||
|     TMR5_GLOBAL_IRQn            = 50,     /*!< tmr5 global interrupt                                */ | ||||
|     SPI3_I2S3EXT_IRQn           = 51,     /*!< spi3 global interrupt                                */ | ||||
|     UART4_IRQn                  = 52,     /*!< uart4 global interrupt                               */ | ||||
|     UART5_IRQn                  = 53,     /*!< uart5 global interrupt                               */ | ||||
|     TMR6_DAC_GLOBAL_IRQn        = 54,     /*!< tmr6 and dac global interrupt                        */ | ||||
|     TMR7_GLOBAL_IRQn            = 55,     /*!< tmr7 global interrupt                                */ | ||||
|     DMA1_Channel1_IRQn          = 56,     /*!< dma1 channel 0 global interrupt                      */ | ||||
|     DMA1_Channel2_IRQn          = 57,     /*!< dma1 channel 1 global interrupt                      */ | ||||
|     DMA1_Channel3_IRQn          = 58,     /*!< dma1 channel 2 global interrupt                      */ | ||||
|     DMA1_Channel4_IRQn          = 59,     /*!< dma1 channel 3 global interrupt                      */ | ||||
|     DMA1_Channel5_IRQn          = 60,     /*!< dma1 channel 4 global interrupt                      */ | ||||
|     CAN2_TX_IRQn                = 63,     /*!< can2 tx interrupt                                    */ | ||||
|     CAN2_RX0_IRQn               = 64,     /*!< can2 rx0 interrupt                                   */ | ||||
|     CAN2_RX1_IRQn               = 65,     /*!< can2 rx1 interrupt                                   */ | ||||
|     CAN2_SE_IRQn                = 66,     /*!< can2 se interrupt                                    */ | ||||
|     OTGFS1_IRQn                 = 67,     /*!< otgfs1 interrupt                                     */ | ||||
|     DMA1_Channel6_IRQn          = 68,     /*!< dma1 channel 5 global interrupt                      */ | ||||
|     DMA1_Channel7_IRQn          = 69,     /*!< dma1 channel 6 global interrupt                      */ | ||||
|     USART6_IRQn                 = 71,     /*!< usart6 interrupt                                     */ | ||||
|     I2C3_EVT_IRQn               = 72,     /*!< i2c3 event interrupt                                 */ | ||||
|     I2C3_ERR_IRQn               = 73,     /*!< i2c3 error interrupt                                 */ | ||||
|     OTGFS2_WKUP_IRQn            = 76,     /*!< otgfs2 wakeup from suspend through exint line interrupt */ | ||||
|     OTGFS2_IRQn                 = 77,     /*!< otgfs2 interrupt                                     */ | ||||
|     DVP_IRQn                    = 78,     /*!< dvp interrupt                                        */ | ||||
|     FPU_IRQn                    = 81,     /*!< fpu interrupt                                        */ | ||||
|     UART7_IRQn                  = 82,     /*!< uart7 interrupt                                      */ | ||||
|     UART8_IRQn                  = 83,     /*!< uart8 interrupt                                      */ | ||||
|     SPI4_IRQn                   = 84,     /*!< spi4 global interrupt                                */ | ||||
|     QSPI2_IRQn                  = 91,     /*!< qspi2 global interrupt                               */ | ||||
|     QSPI1_IRQn                  = 92,     /*!< qspi1 global interrupt                               */ | ||||
|     DMAMUX_IRQn                 = 94,     /*!< dmamux global interrupt                              */ | ||||
|     SDIO2_IRQn                  = 102,    /*!< sdio2 global interrupt                               */ | ||||
|     ACC_IRQn                    = 103,    /*!< acc interrupt                                        */ | ||||
|     TMR20_BRK_IRQn              = 104,    /*!< tmr20 brake interrupt                                */ | ||||
|     TMR20_OVF_IRQn              = 105,    /*!< tmr20 overflow interrupt                             */ | ||||
|     TMR20_TRG_HALL_IRQn         = 106,    /*!< tmr20 trigger and hall interrupt                     */ | ||||
|     TMR20_CH_IRQn               = 107,    /*!< tmr20 channel interrupt                              */ | ||||
|     DMA2_Channel1_IRQn          = 108,    /*!< dma1 channel 1 global interrupt                      */ | ||||
|     DMA2_Channel2_IRQn          = 109,    /*!< dma1 channel 2 global interrupt                      */ | ||||
|     DMA2_Channel3_IRQn          = 110,    /*!< dma1 channel 3 global interrupt                      */ | ||||
|     DMA2_Channel4_IRQn          = 111,    /*!< dma1 channel 4 global interrupt                      */ | ||||
|     DMA2_Channel5_IRQn          = 112,    /*!< dma1 channel 5 global interrupt                      */ | ||||
|     DMA2_Channel6_IRQn          = 113,    /*!< dma1 channel 6 global interrupt                      */ | ||||
|     DMA2_Channel7_IRQn          = 114,    /*!< dma1 channel 7 global interrupt                      */ | ||||
| #endif | ||||
| 
 | ||||
| #if defined (AT32F437xx) | ||||
|     ADC1_2_3_IRQn               = 18,     /*!< adc1 adc2 and adc3 global interrupt                  */ | ||||
|     CAN1_TX_IRQn                = 19,     /*!< can1 tx interrupts                                   */ | ||||
|     CAN1_RX0_IRQn               = 20,     /*!< can1 rx0 interrupts                                  */ | ||||
|     CAN1_RX1_IRQn               = 21,     /*!< can1 rx1 interrupt                                   */ | ||||
|     CAN1_SE_IRQn                = 22,     /*!< can1 se interrupt                                    */ | ||||
|     EXINT9_5_IRQn               = 23,     /*!< external line[9:5] interrupts                        */ | ||||
|     TMR1_BRK_TMR9_IRQn          = 24,     /*!< tmr1 brake interrupt                                 */ | ||||
|     TMR1_OVF_TMR10_IRQn         = 25,     /*!< tmr1 overflow interrupt                              */ | ||||
|     TMR1_TRG_HALL_TMR11_IRQn    = 26,     /*!< tmr1 trigger and hall interrupt                      */ | ||||
|     TMR1_CH_IRQn                = 27,     /*!< tmr1 channel interrupt                               */ | ||||
|     TMR2_GLOBAL_IRQn            = 28,     /*!< tmr2 global interrupt                                */ | ||||
|     TMR3_GLOBAL_IRQn            = 29,     /*!< tmr3 global interrupt                                */ | ||||
|     TMR4_GLOBAL_IRQn            = 30,     /*!< tmr4 global interrupt                                */ | ||||
|     I2C1_EVT_IRQn               = 31,     /*!< i2c1 event interrupt                                 */ | ||||
|     I2C1_ERR_IRQn               = 32,     /*!< i2c1 error interrupt                                 */ | ||||
|     I2C2_EVT_IRQn               = 33,     /*!< i2c2 event interrupt                                 */ | ||||
|     I2C2_ERR_IRQn               = 34,     /*!< i2c2 error interrupt                                 */ | ||||
|     SPI1_IRQn                   = 35,     /*!< spi1 global interrupt                                */ | ||||
|     SPI2_I2S2EXT_IRQn           = 36,     /*!< spi2 global interrupt                                */ | ||||
|     USART1_IRQn                 = 37,     /*!< usart1 global interrupt                              */ | ||||
|     USART2_IRQn                 = 38,     /*!< usart2 global interrupt                              */ | ||||
|     USART3_IRQn                 = 39,     /*!< usart3 global interrupt                              */ | ||||
|     EXINT15_10_IRQn             = 40,     /*!< external line[15:10] interrupts                      */ | ||||
|     ERTCAlarm_IRQn              = 41,     /*!< ertc alarm through exint line interrupt              */ | ||||
|     OTGFS1_WKUP_IRQn            = 42,     /*!< otgfs1 wakeup from suspend through exint line interrupt */ | ||||
|     TMR8_BRK_TMR12_IRQn         = 43,     /*!< tmr8 brake interrupt                                 */ | ||||
|     TMR8_OVF_TMR13_IRQn         = 44,     /*!< tmr8 overflow interrupt                              */ | ||||
|     TMR8_TRG_HALL_TMR14_IRQn    = 45,     /*!< tmr8 trigger and hall interrupt                      */ | ||||
|     TMR8_CH_IRQn                = 46,     /*!< tmr8 channel interrupt                               */ | ||||
|     EDMA_Stream8_IRQn           = 47,     /*!< dma1 stream 8 global interrupt                       */ | ||||
|     XMC_IRQn                    = 48,     /*!< xmc global interrupt                                 */ | ||||
|     SDIO1_IRQn                  = 49,     /*!< sdio global interrupt                                */ | ||||
|     TMR5_GLOBAL_IRQn            = 50,     /*!< tmr5 global interrupt                                */ | ||||
|     SPI3_I2S3EXT_IRQn           = 51,     /*!< spi3 global interrupt                                */ | ||||
|     UART4_IRQn                  = 52,     /*!< uart4 global interrupt                               */ | ||||
|     UART5_IRQn                  = 53,     /*!< uart5 global interrupt                               */ | ||||
|     TMR6_DAC_GLOBAL_IRQn        = 54,     /*!< tmr6 and dac global interrupt                        */ | ||||
|     TMR7_GLOBAL_IRQn            = 55,     /*!< tmr7 global interrupt                                */ | ||||
|     DMA1_Channel1_IRQn          = 56,     /*!< dma1 channel 0 global interrupt                      */ | ||||
|     DMA1_Channel2_IRQn          = 57,     /*!< dma1 channel 1 global interrupt                      */ | ||||
|     DMA1_Channel3_IRQn          = 58,     /*!< dma1 channel 2 global interrupt                      */ | ||||
|     DMA1_Channel4_IRQn          = 59,     /*!< dma1 channel 3 global interrupt                      */ | ||||
|     DMA1_Channel5_IRQn          = 60,     /*!< dma1 channel 4 global interrupt                      */ | ||||
|     EMAC_IRQn                   = 61,     /*!< emac interrupt                                       */ | ||||
|     EMAC_WKUP_IRQn              = 62,     /*!< emac wakeup interrupt                                */ | ||||
|     CAN2_TX_IRQn                = 63,     /*!< can2 tx interrupt                                    */ | ||||
|     CAN2_RX0_IRQn               = 64,     /*!< can2 rx0 interrupt                                   */ | ||||
|     CAN2_RX1_IRQn               = 65,     /*!< can2 rx1 interrupt                                   */ | ||||
|     CAN2_SE_IRQn                = 66,     /*!< can2 se interrupt                                    */ | ||||
|     OTGFS1_IRQn                 = 67,     /*!< otgfs1 interrupt                                     */ | ||||
|     DMA1_Channel6_IRQn          = 68,     /*!< dma1 channel 5 global interrupt                      */ | ||||
|     DMA1_Channel7_IRQn          = 69,     /*!< dma1 channel 6 global interrupt                      */ | ||||
|     USART6_IRQn                 = 71,     /*!< usart6 interrupt                                     */ | ||||
|     I2C3_EVT_IRQn               = 72,     /*!< i2c3 event interrupt                                 */ | ||||
|     I2C3_ERR_IRQn               = 73,     /*!< i2c3 error interrupt                                 */ | ||||
|     OTGFS2_WKUP_IRQn            = 76,     /*!< otgfs2 wakeup from suspend through exint line interrupt */ | ||||
|     OTGFS2_IRQn                 = 77,     /*!< otgfs2 interrupt                                     */ | ||||
|     DVP_IRQn                    = 78,     /*!< dvp interrupt                                        */ | ||||
|     FPU_IRQn                    = 81,     /*!< fpu interrupt                                        */ | ||||
|     UART7_IRQn                  = 82,     /*!< uart7 interrupt                                      */ | ||||
|     UART8_IRQn                  = 83,     /*!< uart8 interrupt                                      */ | ||||
|     SPI4_IRQn                   = 84,     /*!< spi4 global interrupt                                */ | ||||
|     QSPI2_IRQn                  = 91,     /*!< qspi2 global interrupt                               */ | ||||
|     QSPI1_IRQn                  = 92,     /*!< qspi1 global interrupt                               */ | ||||
|     DMAMUX_IRQn                 = 94,     /*!< dmamux global interrupt                              */ | ||||
|     SDIO2_IRQn                  = 102,    /*!< sdio2 global interrupt                               */ | ||||
|     ACC_IRQn                    = 103,    /*!< acc interrupt                                        */ | ||||
|     TMR20_BRK_IRQn              = 104,    /*!< tmr20 brake interrupt                                */ | ||||
|     TMR20_OVF_IRQn              = 105,    /*!< tmr20 overflow interrupt                             */ | ||||
|     TMR20_TRG_HALL_IRQn         = 106,    /*!< tmr20 trigger and hall interrupt                     */ | ||||
|     TMR20_CH_IRQn               = 107,    /*!< tmr20 channel interrupt                              */ | ||||
|     DMA2_Channel1_IRQn          = 108,    /*!< dma1 channel 1 global interrupt                      */ | ||||
|     DMA2_Channel2_IRQn          = 109,    /*!< dma1 channel 2 global interrupt                      */ | ||||
|     DMA2_Channel3_IRQn          = 110,    /*!< dma1 channel 3 global interrupt                      */ | ||||
|     DMA2_Channel4_IRQn          = 111,    /*!< dma1 channel 4 global interrupt                      */ | ||||
|     DMA2_Channel5_IRQn          = 112,    /*!< dma1 channel 5 global interrupt                      */ | ||||
|     DMA2_Channel6_IRQn          = 113,    /*!< dma1 channel 6 global interrupt                      */ | ||||
|     DMA2_Channel7_IRQn          = 114,    /*!< dma1 channel 7 global interrupt                      */ | ||||
| #endif | ||||
| 
 | ||||
| } IRQn_Type; | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #include "core_cm4.h" | ||||
| #include "system_at32f435_437.h" | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| /** @addtogroup Exported_types
 | ||||
|   * @{ | ||||
|   */   | ||||
| 
 | ||||
| typedef int32_t  INT32; | ||||
| typedef int16_t  INT16; | ||||
| typedef int8_t   INT8; | ||||
| typedef uint32_t UINT32; | ||||
| typedef uint16_t UINT16; | ||||
| typedef uint8_t  UINT8; | ||||
| 
 | ||||
| typedef int32_t  s32; | ||||
| typedef int16_t  s16; | ||||
| typedef int8_t   s8; | ||||
| 
 | ||||
| typedef const int32_t sc32;   /*!< read only */ | ||||
| typedef const int16_t sc16;   /*!< read only */ | ||||
| typedef const int8_t  sc8;    /*!< read only */ | ||||
| 
 | ||||
| typedef __IO int32_t  vs32; | ||||
| typedef __IO int16_t  vs16; | ||||
| typedef __IO int8_t   vs8; | ||||
| 
 | ||||
| typedef __I int32_t vsc32;    /*!< read only */ | ||||
| typedef __I int16_t vsc16;    /*!< read only */ | ||||
| typedef __I int8_t  vsc8;     /*!< read only */ | ||||
| 
 | ||||
| typedef uint32_t u32; | ||||
| typedef uint16_t u16; | ||||
| typedef uint8_t  u8; | ||||
| 
 | ||||
| typedef const uint32_t uc32;  /*!< read only */ | ||||
| typedef const uint16_t uc16;  /*!< read only */ | ||||
| typedef const uint8_t  uc8;   /*!< read only */ | ||||
| 
 | ||||
| typedef __IO uint32_t vu32; | ||||
| typedef __IO uint16_t vu16; | ||||
| typedef __IO uint8_t  vu8; | ||||
| 
 | ||||
| typedef __I uint32_t vuc32;   /*!< read only */ | ||||
| typedef __I uint16_t vuc16;   /*!< read only */ | ||||
| typedef __I uint8_t  vuc8;    /*!< read only */ | ||||
| 
 | ||||
| typedef enum {RESET = 0, SET = !RESET} flag_status; | ||||
| typedef enum {FALSE = 0, TRUE = !FALSE} confirm_state;  | ||||
| typedef enum {ERROR = 0, SUCCESS = !ERROR} error_status; | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup Exported_macro
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define REG8(addr)                       *(volatile uint8_t *)(addr) | ||||
| #define REG16(addr)                      *(volatile uint16_t *)(addr) | ||||
| #define REG32(addr)                      *(volatile uint32_t *)(addr) | ||||
| 
 | ||||
| #define MAKE_VALUE(reg_offset, bit_num)  (((reg_offset) << 16) | (bit_num & 0x1f)) | ||||
| 
 | ||||
| #define PERIPH_REG(periph_base, value)   REG32((periph_base + (value >> 16))) | ||||
| #define PERIPH_REG_BIT(value)            (0x1u << (value & 0x1f)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup Peripheral_memory_map
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define XMC_SDRAM_MEM_BASE               ((uint32_t)0xC0000000) | ||||
| #define QSPI2_MEM_BASE                   ((uint32_t)0xB0000000) | ||||
| #define XMC_CARD_MEM_BASE                ((uint32_t)0xA8000000) | ||||
| #define QSPI2_REG_BASE                   ((uint32_t)0xA0002000) | ||||
| #define QSPI1_REG_BASE                   ((uint32_t)0xA0001000) | ||||
| #define XMC_REG_BASE                     ((uint32_t)0xA0000000) | ||||
| #define XMC_BANK1_REG_BASE               (XMC_REG_BASE + 0x0000) | ||||
| #define XMC_BANK2_REG_BASE               (XMC_REG_BASE + 0x0060) | ||||
| #define XMC_BANK3_REG_BASE               (XMC_REG_BASE + 0x0080) | ||||
| #define XMC_BANK4_REG_BASE               (XMC_REG_BASE + 0x00A0) | ||||
| #define XMC_SDRAM_REG_BASE               (XMC_REG_BASE + 0x0140) | ||||
| #define QSPI1_MEM_BASE                   ((uint32_t)0x90000000) | ||||
| #define XMC_MEM_BASE                     ((uint32_t)0x60000000) | ||||
| #define PERIPH_BASE                      ((uint32_t)0x40000000) | ||||
| #define SRAM_BB_BASE                     ((uint32_t)0x22000000) | ||||
| #define PERIPH_BB_BASE                   ((uint32_t)0x42000000) | ||||
| #define SRAM_BASE                        ((uint32_t)0x20000000) | ||||
| #define USD_BASE                         ((uint32_t)0x1FFFC000) | ||||
| #define FLASH_BASE                       ((uint32_t)0x08000000) | ||||
| 
 | ||||
| #define DEBUG_BASE                       ((uint32_t)0xE0042000) | ||||
| 
 | ||||
| #define APB1PERIPH_BASE                  (PERIPH_BASE) | ||||
| #define APB2PERIPH_BASE                  (PERIPH_BASE + 0x10000) | ||||
| #define AHBPERIPH1_BASE                  (PERIPH_BASE + 0x20000) | ||||
| #define AHBPERIPH2_BASE                  (PERIPH_BASE + 0x10000000) | ||||
| 
 | ||||
| #if defined (AT32F435xx) | ||||
| /* apb1 bus base address */ | ||||
| #define UART8_BASE                       (APB1PERIPH_BASE + 0x7C00) | ||||
| #define UART7_BASE                       (APB1PERIPH_BASE + 0x7800) | ||||
| #define DAC_BASE                         (APB1PERIPH_BASE + 0x7400) | ||||
| #define PWC_BASE                         (APB1PERIPH_BASE + 0x7000) | ||||
| #define CAN2_BASE                        (APB1PERIPH_BASE + 0x6800) | ||||
| #define CAN1_BASE                        (APB1PERIPH_BASE + 0x6400) | ||||
| #define I2C3_BASE                        (APB1PERIPH_BASE + 0x5C00) | ||||
| #define I2C2_BASE                        (APB1PERIPH_BASE + 0x5800) | ||||
| #define I2C1_BASE                        (APB1PERIPH_BASE + 0x5400) | ||||
| #define UART5_BASE                       (APB1PERIPH_BASE + 0x5000) | ||||
| #define UART4_BASE                       (APB1PERIPH_BASE + 0x4C00) | ||||
| #define USART3_BASE                      (APB1PERIPH_BASE + 0x4800) | ||||
| #define USART2_BASE                      (APB1PERIPH_BASE + 0x4400) | ||||
| #define SPI3_BASE                        (APB1PERIPH_BASE + 0x3C00) | ||||
| #define SPI2_BASE                        (APB1PERIPH_BASE + 0x3800) | ||||
| #define WDT_BASE                         (APB1PERIPH_BASE + 0x3000) | ||||
| #define WWDT_BASE                        (APB1PERIPH_BASE + 0x2C00) | ||||
| #define ERTC_BASE                        (APB1PERIPH_BASE + 0x2800) | ||||
| #define TMR14_BASE                       (APB1PERIPH_BASE + 0x2000) | ||||
| #define TMR13_BASE                       (APB1PERIPH_BASE + 0x1C00) | ||||
| #define TMR12_BASE                       (APB1PERIPH_BASE + 0x1800) | ||||
| #define TMR7_BASE                        (APB1PERIPH_BASE + 0x1400) | ||||
| #define TMR6_BASE                        (APB1PERIPH_BASE + 0x1000) | ||||
| #define TMR5_BASE                        (APB1PERIPH_BASE + 0x0C00) | ||||
| #define TMR4_BASE                        (APB1PERIPH_BASE + 0x0800) | ||||
| #define TMR3_BASE                        (APB1PERIPH_BASE + 0x0400) | ||||
| #define TMR2_BASE                        (APB1PERIPH_BASE + 0x0000) | ||||
| /* apb2 bus base address */ | ||||
| #define I2S2EXT_BASE                     (APB2PERIPH_BASE + 0x7800) | ||||
| #define I2S3EXT_BASE                     (APB2PERIPH_BASE + 0x7C00) | ||||
| #define ACC_BASE                         (APB2PERIPH_BASE + 0x7400) | ||||
| #define TMR20_BASE                       (APB2PERIPH_BASE + 0x4C00) | ||||
| #define TMR11_BASE                       (APB2PERIPH_BASE + 0x4800) | ||||
| #define TMR10_BASE                       (APB2PERIPH_BASE + 0x4400) | ||||
| #define TMR9_BASE                        (APB2PERIPH_BASE + 0x4000) | ||||
| #define EXINT_BASE                       (APB2PERIPH_BASE + 0x3C00) | ||||
| #define SCFG_BASE                        (APB2PERIPH_BASE + 0x3800) | ||||
| #define SPI4_BASE                        (APB2PERIPH_BASE + 0x3400) | ||||
| #define SPI1_BASE                        (APB2PERIPH_BASE + 0x3000) | ||||
| #define ADC1_BASE                        (APB2PERIPH_BASE + 0x2000) | ||||
| #define ADC2_BASE                        (APB2PERIPH_BASE + 0x2100) | ||||
| #define ADC3_BASE                        (APB2PERIPH_BASE + 0x2200) | ||||
| #define ADCCOM_BASE                      (APB2PERIPH_BASE + 0x2300) | ||||
| #define USART6_BASE                      (APB2PERIPH_BASE + 0x1400) | ||||
| #define USART1_BASE                      (APB2PERIPH_BASE + 0x1000) | ||||
| #define TMR8_BASE                        (APB2PERIPH_BASE + 0x0400) | ||||
| #define TMR1_BASE                        (APB2PERIPH_BASE + 0x0000) | ||||
| /* ahb bus base address */    | ||||
| #define OTGFS2_BASE                      (AHBPERIPH1_BASE + 0x20000) | ||||
| #define SDIO1_BASE                       (AHBPERIPH1_BASE + 0xC400) | ||||
| #define GPIOH_BASE                       (AHBPERIPH1_BASE + 0x1C00) | ||||
| #define GPIOG_BASE                       (AHBPERIPH1_BASE + 0x1800) | ||||
| #define GPIOF_BASE                       (AHBPERIPH1_BASE + 0x1400) | ||||
| #define GPIOE_BASE                       (AHBPERIPH1_BASE + 0x1000) | ||||
| #define GPIOD_BASE                       (AHBPERIPH1_BASE + 0x0C00) | ||||
| #define GPIOC_BASE                       (AHBPERIPH1_BASE + 0x0800) | ||||
| #define GPIOB_BASE                       (AHBPERIPH1_BASE + 0x0400) | ||||
| #define GPIOA_BASE                       (AHBPERIPH1_BASE + 0x0000) | ||||
| 
 | ||||
| #define DMA1_BASE                        (AHBPERIPH1_BASE + 0x6400) | ||||
| #define DMA1_CHANNEL1_BASE               (DMA1_BASE + 0x0008) | ||||
| #define DMA1_CHANNEL2_BASE               (DMA1_BASE + 0x001C) | ||||
| #define DMA1_CHANNEL3_BASE               (DMA1_BASE + 0x0030) | ||||
| #define DMA1_CHANNEL4_BASE               (DMA1_BASE + 0x0044) | ||||
| #define DMA1_CHANNEL5_BASE               (DMA1_BASE + 0x0058) | ||||
| #define DMA1_CHANNEL6_BASE               (DMA1_BASE + 0x006C) | ||||
| #define DMA1_CHANNEL7_BASE               (DMA1_BASE + 0x0080) | ||||
| 
 | ||||
| #define DMA1MUX_BASE                     (DMA1_BASE + 0x0104) | ||||
| #define DMA1MUX_CHANNEL1_BASE            (DMA1MUX_BASE) | ||||
| #define DMA1MUX_CHANNEL2_BASE            (DMA1MUX_BASE + 0x0004) | ||||
| #define DMA1MUX_CHANNEL3_BASE            (DMA1MUX_BASE + 0x0008) | ||||
| #define DMA1MUX_CHANNEL4_BASE            (DMA1MUX_BASE + 0x000C) | ||||
| #define DMA1MUX_CHANNEL5_BASE            (DMA1MUX_BASE + 0x0010) | ||||
| #define DMA1MUX_CHANNEL6_BASE            (DMA1MUX_BASE + 0x0014) | ||||
| #define DMA1MUX_CHANNEL7_BASE            (DMA1MUX_BASE + 0x0018) | ||||
| 
 | ||||
| #define DMA1MUX_GENERATOR1_BASE          (DMA1_BASE + 0x0120) | ||||
| #define DMA1MUX_GENERATOR2_BASE          (DMA1_BASE + 0x0124) | ||||
| #define DMA1MUX_GENERATOR3_BASE          (DMA1_BASE + 0x0128) | ||||
| #define DMA1MUX_GENERATOR4_BASE          (DMA1_BASE + 0x012C) | ||||
| 
 | ||||
| #define DMA2_BASE                        (AHBPERIPH1_BASE + 0x6600) | ||||
| #define DMA2_CHANNEL1_BASE               (DMA2_BASE + 0x0008) | ||||
| #define DMA2_CHANNEL2_BASE               (DMA2_BASE + 0x001C) | ||||
| #define DMA2_CHANNEL3_BASE               (DMA2_BASE + 0x0030) | ||||
| #define DMA2_CHANNEL4_BASE               (DMA2_BASE + 0x0044) | ||||
| #define DMA2_CHANNEL5_BASE               (DMA2_BASE + 0x0058) | ||||
| #define DMA2_CHANNEL6_BASE               (DMA2_BASE + 0x006C) | ||||
| #define DMA2_CHANNEL7_BASE               (DMA2_BASE + 0x0080) | ||||
| 
 | ||||
| #define DMA2MUX_BASE                     (DMA2_BASE + 0x0104) | ||||
| #define DMA2MUX_CHANNEL1_BASE            (DMA2MUX_BASE) | ||||
| #define DMA2MUX_CHANNEL2_BASE            (DMA2MUX_BASE + 0x0004) | ||||
| #define DMA2MUX_CHANNEL3_BASE            (DMA2MUX_BASE + 0x0008) | ||||
| #define DMA2MUX_CHANNEL4_BASE            (DMA2MUX_BASE + 0x000C) | ||||
| #define DMA2MUX_CHANNEL5_BASE            (DMA2MUX_BASE + 0x0010) | ||||
| #define DMA2MUX_CHANNEL6_BASE            (DMA2MUX_BASE + 0x0014) | ||||
| #define DMA2MUX_CHANNEL7_BASE            (DMA2MUX_BASE + 0x0018) | ||||
| 
 | ||||
| #define DMA2MUX_GENERATOR1_BASE          (DMA2_BASE + 0x0120) | ||||
| #define DMA2MUX_GENERATOR2_BASE          (DMA2_BASE + 0x0124) | ||||
| #define DMA2MUX_GENERATOR3_BASE          (DMA2_BASE + 0x0128) | ||||
| #define DMA2MUX_GENERATOR4_BASE          (DMA2_BASE + 0x012C) | ||||
| 
 | ||||
| #define EDMA_BASE                        (AHBPERIPH1_BASE + 0x6000) | ||||
| #define EDMA_STREAM1_BASE                (EDMA_BASE + 0x0010) | ||||
| #define EDMA_STREAM2_BASE                (EDMA_BASE + 0x0028) | ||||
| #define EDMA_STREAM3_BASE                (EDMA_BASE + 0x0040) | ||||
| #define EDMA_STREAM4_BASE                (EDMA_BASE + 0x0058) | ||||
| #define EDMA_STREAM5_BASE                (EDMA_BASE + 0x0070) | ||||
| #define EDMA_STREAM6_BASE                (EDMA_BASE + 0x0088) | ||||
| #define EDMA_STREAM7_BASE                (EDMA_BASE + 0x00A0) | ||||
| #define EDMA_STREAM8_BASE                (EDMA_BASE + 0x00B8) | ||||
| 
 | ||||
| #define EDMA_2D_BASE                     (EDMA_BASE + 0x00F4) | ||||
| #define EDMA_STREAM1_2D_BASE             (EDMA_2D_BASE + 0x0004) | ||||
| #define EDMA_STREAM2_2D_BASE             (EDMA_2D_BASE + 0x000C) | ||||
| #define EDMA_STREAM3_2D_BASE             (EDMA_2D_BASE + 0x0014) | ||||
| #define EDMA_STREAM4_2D_BASE             (EDMA_2D_BASE + 0x001C) | ||||
| #define EDMA_STREAM5_2D_BASE             (EDMA_2D_BASE + 0x0024) | ||||
| #define EDMA_STREAM6_2D_BASE             (EDMA_2D_BASE + 0x002C) | ||||
| #define EDMA_STREAM7_2D_BASE             (EDMA_2D_BASE + 0x0034) | ||||
| #define EDMA_STREAM8_2D_BASE             (EDMA_2D_BASE + 0x003C) | ||||
|                                           | ||||
| #define EDMA_LL_BASE                     (EDMA_BASE + 0x00D0) | ||||
| #define EDMA_STREAM1_LL_BASE             (EDMA_LL_BASE + 0x0004) | ||||
| #define EDMA_STREAM2_LL_BASE             (EDMA_LL_BASE + 0x0008) | ||||
| #define EDMA_STREAM3_LL_BASE             (EDMA_LL_BASE + 0x000C) | ||||
| #define EDMA_STREAM4_LL_BASE             (EDMA_LL_BASE + 0x0010) | ||||
| #define EDMA_STREAM5_LL_BASE             (EDMA_LL_BASE + 0x0014) | ||||
| #define EDMA_STREAM6_LL_BASE             (EDMA_LL_BASE + 0x0018) | ||||
| #define EDMA_STREAM7_LL_BASE             (EDMA_LL_BASE + 0x001C) | ||||
| #define EDMA_STREAM8_LL_BASE             (EDMA_LL_BASE + 0x0020) | ||||
| 
 | ||||
| #define EDMAMUX_BASE                     (EDMA_BASE + 0x0140) | ||||
| #define EDMAMUX_CHANNEL1_BASE            (EDMAMUX_BASE) | ||||
| #define EDMAMUX_CHANNEL2_BASE            (EDMAMUX_BASE + 0x0004) | ||||
| #define EDMAMUX_CHANNEL3_BASE            (EDMAMUX_BASE + 0x0008) | ||||
| #define EDMAMUX_CHANNEL4_BASE            (EDMAMUX_BASE + 0x000C) | ||||
| #define EDMAMUX_CHANNEL5_BASE            (EDMAMUX_BASE + 0x0010) | ||||
| #define EDMAMUX_CHANNEL6_BASE            (EDMAMUX_BASE + 0x0014) | ||||
| #define EDMAMUX_CHANNEL7_BASE            (EDMAMUX_BASE + 0x0018) | ||||
| #define EDMAMUX_CHANNEL8_BASE            (EDMAMUX_BASE + 0x001C) | ||||
| 
 | ||||
| #define EDMAMUX_GENERATOR1_BASE          (EDMA_BASE + 0x0160) | ||||
| #define EDMAMUX_GENERATOR2_BASE          (EDMA_BASE + 0x0164) | ||||
| #define EDMAMUX_GENERATOR3_BASE          (EDMA_BASE + 0x0168) | ||||
| #define EDMAMUX_GENERATOR4_BASE          (EDMA_BASE + 0x016C) | ||||
| 
 | ||||
| #define FLASH_REG_BASE                   (AHBPERIPH1_BASE + 0x3C00) | ||||
| #define CRM_BASE                         (AHBPERIPH1_BASE + 0x3800) | ||||
| #define CRC_BASE                         (AHBPERIPH1_BASE + 0x3000) | ||||
| #define SDIO2_BASE                       (AHBPERIPH2_BASE + 0x61000) | ||||
| #define DVP_BASE                         (AHBPERIPH2_BASE + 0x50000) | ||||
| #define OTGFS1_BASE                      (AHBPERIPH2_BASE + 0x00000) | ||||
| #endif | ||||
| 
 | ||||
| #if defined (AT32F437xx) | ||||
| /* apb1 bus base address */ | ||||
| #define UART8_BASE                       (APB1PERIPH_BASE + 0x7C00) | ||||
| #define UART7_BASE                       (APB1PERIPH_BASE + 0x7800) | ||||
| #define DAC_BASE                         (APB1PERIPH_BASE + 0x7400) | ||||
| #define PWC_BASE                         (APB1PERIPH_BASE + 0x7000) | ||||
| #define CAN2_BASE                        (APB1PERIPH_BASE + 0x6800) | ||||
| #define CAN1_BASE                        (APB1PERIPH_BASE + 0x6400) | ||||
| #define I2C3_BASE                        (APB1PERIPH_BASE + 0x5C00) | ||||
| #define I2C2_BASE                        (APB1PERIPH_BASE + 0x5800) | ||||
| #define I2C1_BASE                        (APB1PERIPH_BASE + 0x5400) | ||||
| #define UART5_BASE                       (APB1PERIPH_BASE + 0x5000) | ||||
| #define UART4_BASE                       (APB1PERIPH_BASE + 0x4C00) | ||||
| #define USART3_BASE                      (APB1PERIPH_BASE + 0x4800) | ||||
| #define USART2_BASE                      (APB1PERIPH_BASE + 0x4400) | ||||
| #define SPI3_BASE                        (APB1PERIPH_BASE + 0x3C00) | ||||
| #define SPI2_BASE                        (APB1PERIPH_BASE + 0x3800) | ||||
| #define WDT_BASE                         (APB1PERIPH_BASE + 0x3000) | ||||
| #define WWDT_BASE                        (APB1PERIPH_BASE + 0x2C00) | ||||
| #define ERTC_BASE                        (APB1PERIPH_BASE + 0x2800) | ||||
| #define TMR14_BASE                       (APB1PERIPH_BASE + 0x2000) | ||||
| #define TMR13_BASE                       (APB1PERIPH_BASE + 0x1C00) | ||||
| #define TMR12_BASE                       (APB1PERIPH_BASE + 0x1800) | ||||
| #define TMR7_BASE                        (APB1PERIPH_BASE + 0x1400) | ||||
| #define TMR6_BASE                        (APB1PERIPH_BASE + 0x1000) | ||||
| #define TMR5_BASE                        (APB1PERIPH_BASE + 0x0C00) | ||||
| #define TMR4_BASE                        (APB1PERIPH_BASE + 0x0800) | ||||
| #define TMR3_BASE                        (APB1PERIPH_BASE + 0x0400) | ||||
| #define TMR2_BASE                        (APB1PERIPH_BASE + 0x0000) | ||||
| /* apb2 bus base address */ | ||||
| #define I2S2EXT_BASE                     (APB2PERIPH_BASE + 0x7800) | ||||
| #define I2S3EXT_BASE                     (APB2PERIPH_BASE + 0x7C00) | ||||
| #define ACC_BASE                         (APB2PERIPH_BASE + 0x7400) | ||||
| #define TMR20_BASE                       (APB2PERIPH_BASE + 0x4C00) | ||||
| #define TMR11_BASE                       (APB2PERIPH_BASE + 0x4800) | ||||
| #define TMR10_BASE                       (APB2PERIPH_BASE + 0x4400) | ||||
| #define TMR9_BASE                        (APB2PERIPH_BASE + 0x4000) | ||||
| #define EXINT_BASE                       (APB2PERIPH_BASE + 0x3C00) | ||||
| #define SCFG_BASE                        (APB2PERIPH_BASE + 0x3800) | ||||
| #define SPI4_BASE                        (APB2PERIPH_BASE + 0x3400) | ||||
| #define SPI1_BASE                        (APB2PERIPH_BASE + 0x3000) | ||||
| #define ADC1_BASE                        (APB2PERIPH_BASE + 0x2000) | ||||
| #define ADC2_BASE                        (APB2PERIPH_BASE + 0x2100) | ||||
| #define ADC3_BASE                        (APB2PERIPH_BASE + 0x2200) | ||||
| #define ADCCOM_BASE                      (APB2PERIPH_BASE + 0x2300) | ||||
| #define USART6_BASE                      (APB2PERIPH_BASE + 0x1400) | ||||
| #define USART1_BASE                      (APB2PERIPH_BASE + 0x1000) | ||||
| #define TMR8_BASE                        (APB2PERIPH_BASE + 0x0400) | ||||
| #define TMR1_BASE                        (APB2PERIPH_BASE + 0x0000) | ||||
| /* ahb bus base address */    | ||||
| #define OTGFS2_BASE                      (AHBPERIPH1_BASE + 0x20000) | ||||
| #define SDIO1_BASE                       (AHBPERIPH1_BASE + 0xC400) | ||||
| #define EMAC_BASE                        (AHBPERIPH1_BASE + 0x8000) | ||||
| #define GPIOH_BASE                       (AHBPERIPH1_BASE + 0x1C00) | ||||
| #define GPIOG_BASE                       (AHBPERIPH1_BASE + 0x1800) | ||||
| #define GPIOF_BASE                       (AHBPERIPH1_BASE + 0x1400) | ||||
| #define GPIOE_BASE                       (AHBPERIPH1_BASE + 0x1000) | ||||
| #define GPIOD_BASE                       (AHBPERIPH1_BASE + 0x0C00) | ||||
| #define GPIOC_BASE                       (AHBPERIPH1_BASE + 0x0800) | ||||
| #define GPIOB_BASE                       (AHBPERIPH1_BASE + 0x0400) | ||||
| #define GPIOA_BASE                       (AHBPERIPH1_BASE + 0x0000) | ||||
| 
 | ||||
| #define DMA1_BASE                        (AHBPERIPH1_BASE + 0x6400) | ||||
| #define DMA1_CHANNEL1_BASE               (DMA1_BASE + 0x0008) | ||||
| #define DMA1_CHANNEL2_BASE               (DMA1_BASE + 0x001C) | ||||
| #define DMA1_CHANNEL3_BASE               (DMA1_BASE + 0x0030) | ||||
| #define DMA1_CHANNEL4_BASE               (DMA1_BASE + 0x0044) | ||||
| #define DMA1_CHANNEL5_BASE               (DMA1_BASE + 0x0058) | ||||
| #define DMA1_CHANNEL6_BASE               (DMA1_BASE + 0x006C) | ||||
| #define DMA1_CHANNEL7_BASE               (DMA1_BASE + 0x0080) | ||||
| 
 | ||||
| #define DMA1MUX_BASE                     (DMA1_BASE + 0x0104) | ||||
| #define DMA1MUX_CHANNEL1_BASE            (DMA1MUX_BASE) | ||||
| #define DMA1MUX_CHANNEL2_BASE            (DMA1MUX_BASE + 0x0004) | ||||
| #define DMA1MUX_CHANNEL3_BASE            (DMA1MUX_BASE + 0x0008) | ||||
| #define DMA1MUX_CHANNEL4_BASE            (DMA1MUX_BASE + 0x000C) | ||||
| #define DMA1MUX_CHANNEL5_BASE            (DMA1MUX_BASE + 0x0010) | ||||
| #define DMA1MUX_CHANNEL6_BASE            (DMA1MUX_BASE + 0x0014) | ||||
| #define DMA1MUX_CHANNEL7_BASE            (DMA1MUX_BASE + 0x0018) | ||||
| 
 | ||||
| #define DMA1MUX_GENERATOR1_BASE          (DMA1_BASE + 0x0120) | ||||
| #define DMA1MUX_GENERATOR2_BASE          (DMA1_BASE + 0x0124) | ||||
| #define DMA1MUX_GENERATOR3_BASE          (DMA1_BASE + 0x0128) | ||||
| #define DMA1MUX_GENERATOR4_BASE          (DMA1_BASE + 0x012C) | ||||
| 
 | ||||
| #define DMA2_BASE                        (AHBPERIPH1_BASE + 0x6600) | ||||
| #define DMA2_CHANNEL1_BASE               (DMA2_BASE + 0x0008) | ||||
| #define DMA2_CHANNEL2_BASE               (DMA2_BASE + 0x001C) | ||||
| #define DMA2_CHANNEL3_BASE               (DMA2_BASE + 0x0030) | ||||
| #define DMA2_CHANNEL4_BASE               (DMA2_BASE + 0x0044) | ||||
| #define DMA2_CHANNEL5_BASE               (DMA2_BASE + 0x0058) | ||||
| #define DMA2_CHANNEL6_BASE               (DMA2_BASE + 0x006C) | ||||
| #define DMA2_CHANNEL7_BASE               (DMA2_BASE + 0x0080) | ||||
| 
 | ||||
| #define DMA2MUX_BASE                     (DMA2_BASE + 0x0104) | ||||
| #define DMA2MUX_CHANNEL1_BASE            (DMA2MUX_BASE) | ||||
| #define DMA2MUX_CHANNEL2_BASE            (DMA2MUX_BASE + 0x0004) | ||||
| #define DMA2MUX_CHANNEL3_BASE            (DMA2MUX_BASE + 0x0008) | ||||
| #define DMA2MUX_CHANNEL4_BASE            (DMA2MUX_BASE + 0x000C) | ||||
| #define DMA2MUX_CHANNEL5_BASE            (DMA2MUX_BASE + 0x0010) | ||||
| #define DMA2MUX_CHANNEL6_BASE            (DMA2MUX_BASE + 0x0014) | ||||
| #define DMA2MUX_CHANNEL7_BASE            (DMA2MUX_BASE + 0x0018) | ||||
| 
 | ||||
| #define DMA2MUX_GENERATOR1_BASE          (DMA2_BASE + 0x0120) | ||||
| #define DMA2MUX_GENERATOR2_BASE          (DMA2_BASE + 0x0124) | ||||
| #define DMA2MUX_GENERATOR3_BASE          (DMA2_BASE + 0x0128) | ||||
| #define DMA2MUX_GENERATOR4_BASE          (DMA2_BASE + 0x012C) | ||||
| 
 | ||||
| #define EDMA_BASE                        (AHBPERIPH1_BASE + 0x6000) | ||||
| #define EDMA_STREAM1_BASE                (EDMA_BASE + 0x0010) | ||||
| #define EDMA_STREAM2_BASE                (EDMA_BASE + 0x0028) | ||||
| #define EDMA_STREAM3_BASE                (EDMA_BASE + 0x0040) | ||||
| #define EDMA_STREAM4_BASE                (EDMA_BASE + 0x0058) | ||||
| #define EDMA_STREAM5_BASE                (EDMA_BASE + 0x0070) | ||||
| #define EDMA_STREAM6_BASE                (EDMA_BASE + 0x0088) | ||||
| #define EDMA_STREAM7_BASE                (EDMA_BASE + 0x00A0) | ||||
| #define EDMA_STREAM8_BASE                (EDMA_BASE + 0x00B8) | ||||
| 
 | ||||
| #define EDMA_2D_BASE                     (EDMA_BASE + 0x00F4) | ||||
| #define EDMA_STREAM1_2D_BASE             (EDMA_2D_BASE + 0x0004) | ||||
| #define EDMA_STREAM2_2D_BASE             (EDMA_2D_BASE + 0x000C) | ||||
| #define EDMA_STREAM3_2D_BASE             (EDMA_2D_BASE + 0x0014) | ||||
| #define EDMA_STREAM4_2D_BASE             (EDMA_2D_BASE + 0x001C) | ||||
| #define EDMA_STREAM5_2D_BASE             (EDMA_2D_BASE + 0x0024) | ||||
| #define EDMA_STREAM6_2D_BASE             (EDMA_2D_BASE + 0x002C) | ||||
| #define EDMA_STREAM7_2D_BASE             (EDMA_2D_BASE + 0x0034) | ||||
| #define EDMA_STREAM8_2D_BASE             (EDMA_2D_BASE + 0x003C) | ||||
|                                           | ||||
| #define EDMA_LL_BASE                     (EDMA_BASE + 0x00D0) | ||||
| #define EDMA_STREAM1_LL_BASE             (EDMA_LL_BASE + 0x0004) | ||||
| #define EDMA_STREAM2_LL_BASE             (EDMA_LL_BASE + 0x0008) | ||||
| #define EDMA_STREAM3_LL_BASE             (EDMA_LL_BASE + 0x000C) | ||||
| #define EDMA_STREAM4_LL_BASE             (EDMA_LL_BASE + 0x0010) | ||||
| #define EDMA_STREAM5_LL_BASE             (EDMA_LL_BASE + 0x0014) | ||||
| #define EDMA_STREAM6_LL_BASE             (EDMA_LL_BASE + 0x0018) | ||||
| #define EDMA_STREAM7_LL_BASE             (EDMA_LL_BASE + 0x001C) | ||||
| #define EDMA_STREAM8_LL_BASE             (EDMA_LL_BASE + 0x0020) | ||||
| 
 | ||||
| #define EDMAMUX_BASE                     (EDMA_BASE + 0x0140) | ||||
| #define EDMAMUX_CHANNEL1_BASE            (EDMAMUX_BASE) | ||||
| #define EDMAMUX_CHANNEL2_BASE            (EDMAMUX_BASE + 0x0004) | ||||
| #define EDMAMUX_CHANNEL3_BASE            (EDMAMUX_BASE + 0x0008) | ||||
| #define EDMAMUX_CHANNEL4_BASE            (EDMAMUX_BASE + 0x000C) | ||||
| #define EDMAMUX_CHANNEL5_BASE            (EDMAMUX_BASE + 0x0010) | ||||
| #define EDMAMUX_CHANNEL6_BASE            (EDMAMUX_BASE + 0x0014) | ||||
| #define EDMAMUX_CHANNEL7_BASE            (EDMAMUX_BASE + 0x0018) | ||||
| #define EDMAMUX_CHANNEL8_BASE            (EDMAMUX_BASE + 0x001C) | ||||
| 
 | ||||
| #define EDMAMUX_GENERATOR1_BASE          (EDMA_BASE + 0x0160) | ||||
| #define EDMAMUX_GENERATOR2_BASE          (EDMA_BASE + 0x0164) | ||||
| #define EDMAMUX_GENERATOR3_BASE          (EDMA_BASE + 0x0168) | ||||
| #define EDMAMUX_GENERATOR4_BASE          (EDMA_BASE + 0x016C) | ||||
| 
 | ||||
| #define FLASH_REG_BASE                   (AHBPERIPH1_BASE + 0x3C00) | ||||
| #define CRM_BASE                         (AHBPERIPH1_BASE + 0x3800) | ||||
| #define CRC_BASE                         (AHBPERIPH1_BASE + 0x3000) | ||||
| #define SDIO2_BASE                       (AHBPERIPH2_BASE + 0x61000) | ||||
| #define DVP_BASE                         (AHBPERIPH2_BASE + 0x50000) | ||||
| #define OTGFS1_BASE                      (AHBPERIPH2_BASE + 0x00000) | ||||
| 
 | ||||
| #define EMAC_MAC_BASE                    (EMAC_BASE) | ||||
| #define EMAC_MMC_BASE                    (EMAC_BASE + 0x0100) | ||||
| #define EMAC_PTP_BASE                    (EMAC_BASE + 0x0700) | ||||
| #define EMAC_DMA_BASE                    (EMAC_BASE + 0x1000) | ||||
| #endif | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #include "at32f435_437_def.h" | ||||
| #include "at32f435_437_conf.h" | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
|  | @ -0,0 +1,75 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     system_at32f435_437.h | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    cmsis cortex-m4 system header file. | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| #ifndef __SYSTEM_AT32F435_437_H | ||||
| #define __SYSTEM_AT32F435_437_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /** @addtogroup CMSIS
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup AT32F435_437_system
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AT32F435_437_system_exported_variables 
 | ||||
|   * @{ | ||||
|   */ | ||||
| extern unsigned int system_core_clock; /*!< system clock frequency (core clock) */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AT32F435_437_system_exported_functions 
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| extern void SystemInit(void); | ||||
| extern void system_core_clock_update(void); | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
|  | @ -0,0 +1,179 @@ | |||
| /* | ||||
| ***************************************************************************** | ||||
| ** | ||||
| **  File        : AT32F437xM_FLASH.ld | ||||
| ** | ||||
| **  Abstract    : Linker script for AT32F437xM Device with | ||||
| **                4096KByte FLASH, 384KByte RAM | ||||
| ** | ||||
| **                Set heap size, stack size and stack location according | ||||
| **                to application requirements. | ||||
| ** | ||||
| **                Set memory bank area and size if external memory is used. | ||||
| ** | ||||
| **  Target      : Artery Tek AT32 | ||||
| ** | ||||
| **  Environment : Arm gcc toolchain | ||||
| ** | ||||
| ***************************************************************************** | ||||
| */ | ||||
| 
 | ||||
| /* Entry Point */ | ||||
| ENTRY(Reset_Handler) | ||||
| 
 | ||||
| /* Highest address of the user mode stack */ | ||||
| _estack = 0x20017FFF;    /* end of RAM */ | ||||
| 
 | ||||
| /* Generate a link error if heap and stack don't fit into RAM */ | ||||
| _Min_Heap_Size = 0x200;      /* required amount of heap  */ | ||||
| _Min_Stack_Size = 0x400; /* required amount of stack */ | ||||
| 
 | ||||
| _FullFirmwareSize = 300K ; | ||||
| _MetadataSize = 256 ; | ||||
| _FirmwareSize = _FullFirmwareSize - _MetadataSize ; | ||||
| _FirmwareBegin = 0x08000000; | ||||
| 
 | ||||
| _StorageSize = 16K; | ||||
| _StorageABegin = 0x0804B000; | ||||
| _StorageBBegin = 0x0804F000; | ||||
| 
 | ||||
| /* Specify the memory areas */ | ||||
| MEMORY | ||||
| { | ||||
|     FLASH (rx)                : ORIGIN = _FirmwareBegin, LENGTH = _FirmwareSize | ||||
|     META (rx)                 : ORIGIN = _FirmwareBegin + _FirmwareSize, LENGTH = _MetadataSize | ||||
| 
 | ||||
|     STORAGE_A (rx)              : ORIGIN = _StorageABegin, LENGTH = _StorageSize | ||||
|     STORAGE_B (rx)              : ORIGIN = _StorageBBegin, LENGTH = _StorageSize | ||||
| 
 | ||||
|     RAM (xrw)                 : ORIGIN = 0x20000000, LENGTH = 512K | ||||
| } | ||||
| 
 | ||||
| /* Define output sections */ | ||||
| SECTIONS | ||||
| { | ||||
|   /* The startup code goes first into FLASH */ | ||||
|   .isr_vector : | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     KEEP(*(.isr_vector)) /* Startup code */ | ||||
|     . = ALIGN(4); | ||||
|   } >FLASH | ||||
| 
 | ||||
|   .metaaaa : SUBALIGN(1) | ||||
|   { | ||||
|     KEEP(*(.meta_fw_crc)) | ||||
|     LONG(_FirmwareSize) ; /* word with firmware_size */ | ||||
|     KEEP(*(.meta_fw_name_size)) | ||||
|     KEEP(*(.meta_fw_name)) | ||||
|     KEEP(*(.meta_hw_name_size)) | ||||
|     KEEP(*(.meta_hw_name)) | ||||
|     . = ALIGN(256); | ||||
|   } >META | ||||
| 
 | ||||
|   /* The program code and other data goes into FLASH */ | ||||
|   .text : | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     *(.text)           /* .text sections (code) */ | ||||
|     *(.text*)          /* .text* sections (code) */ | ||||
|     *(.glue_7)         /* glue arm to thumb code */ | ||||
|     *(.glue_7t)        /* glue thumb to arm code */ | ||||
|     *(.eh_frame) | ||||
| 
 | ||||
|     KEEP (*(.init)) | ||||
|     KEEP (*(.fini)) | ||||
| 
 | ||||
|     . = ALIGN(4); | ||||
|     _etext = .;        /* define a global symbols at end of code */ | ||||
|   } >FLASH | ||||
| 
 | ||||
|   /* Constant data goes into FLASH */ | ||||
|   .rodata : | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     *(.rodata)         /* .rodata sections (constants, strings, etc.) */ | ||||
|     *(.rodata*)        /* .rodata* sections (constants, strings, etc.) */ | ||||
|     . = ALIGN(4); | ||||
|   } >FLASH | ||||
| 
 | ||||
|   .ARM.extab   : { *(.ARM.extab* .gnu.linkonce.armextab.*) } >FLASH | ||||
|   .ARM : { | ||||
|     __exidx_start = .; | ||||
|     *(.ARM.exidx*) | ||||
|     __exidx_end = .; | ||||
|   } >FLASH | ||||
| 
 | ||||
|   .preinit_array     : | ||||
|   { | ||||
|     PROVIDE_HIDDEN (__preinit_array_start = .); | ||||
|     KEEP (*(.preinit_array*)) | ||||
|     PROVIDE_HIDDEN (__preinit_array_end = .); | ||||
|   } >FLASH | ||||
|   .init_array : | ||||
|   { | ||||
|     PROVIDE_HIDDEN (__init_array_start = .); | ||||
|     KEEP (*(SORT(.init_array.*))) | ||||
|     KEEP (*(.init_array*)) | ||||
|     PROVIDE_HIDDEN (__init_array_end = .); | ||||
|   } >FLASH | ||||
|   .fini_array : | ||||
|   { | ||||
|     PROVIDE_HIDDEN (__fini_array_start = .); | ||||
|     KEEP (*(SORT(.fini_array.*))) | ||||
|     KEEP (*(.fini_array*)) | ||||
|     PROVIDE_HIDDEN (__fini_array_end = .); | ||||
|   } >FLASH | ||||
| 
 | ||||
|   /* used by the startup to initialize data */ | ||||
|   _sidata = LOADADDR(.data); | ||||
| 
 | ||||
|   /* Initialized data sections goes into RAM, load LMA copy after code */ | ||||
|   .data :  | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     _sdata = .;        /* create a global symbol at data start */ | ||||
|     *(.data)           /* .data sections */ | ||||
|     *(.data*)          /* .data* sections */ | ||||
| 
 | ||||
|     . = ALIGN(4); | ||||
|     _edata = .;        /* define a global symbol at data end */ | ||||
|   } >RAM AT> FLASH | ||||
| 
 | ||||
|   /* Uninitialized data section */ | ||||
|   . = ALIGN(4); | ||||
|   .bss : | ||||
|   { | ||||
|     /* This is used by the startup in order to initialize the .bss secion */ | ||||
|     _sbss = .;         /* define a global symbol at bss start */ | ||||
|     __bss_start__ = _sbss; | ||||
|     *(.bss) | ||||
|     *(.bss*) | ||||
|     *(COMMON) | ||||
| 
 | ||||
|     . = ALIGN(4); | ||||
|     _ebss = .;         /* define a global symbol at bss end */ | ||||
|     __bss_end__ = _ebss; | ||||
|   } >RAM | ||||
| 
 | ||||
|   /* User_heap_stack section, used to check that there is enough RAM left */ | ||||
|   ._user_heap_stack : | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     PROVIDE ( end = . ); | ||||
|     PROVIDE ( _end = . ); | ||||
|     . = . + _Min_Heap_Size; | ||||
|     . = . + _Min_Stack_Size; | ||||
|     . = ALIGN(4); | ||||
|   } >RAM | ||||
| 
 | ||||
|   /* Remove information from the standard libraries */ | ||||
|   /DISCARD/ : | ||||
|   { | ||||
|     libc.a ( * ) | ||||
|     libm.a ( * ) | ||||
|     libgcc.a ( * ) | ||||
|   } | ||||
| 
 | ||||
|   .ARM.attributes 0 : { *(.ARM.attributes) } | ||||
| } | ||||
|  | @ -0,0 +1,154 @@ | |||
| /* | ||||
| ***************************************************************************** | ||||
| ** | ||||
| **  File        : AT32F437xM_FLASH.ld | ||||
| ** | ||||
| **  Abstract    : Linker script for AT32F437xM Device with | ||||
| **                4096KByte FLASH, 384KByte RAM | ||||
| ** | ||||
| **                Set heap size, stack size and stack location according | ||||
| **                to application requirements. | ||||
| ** | ||||
| **                Set memory bank area and size if external memory is used. | ||||
| ** | ||||
| **  Target      : Artery Tek AT32 | ||||
| ** | ||||
| **  Environment : Arm gcc toolchain | ||||
| ** | ||||
| ***************************************************************************** | ||||
| */ | ||||
| 
 | ||||
| /* Entry Point */ | ||||
| ENTRY(Reset_Handler) | ||||
| 
 | ||||
| /* Highest address of the user mode stack */ | ||||
| _estack = 0x20017FFF;    /* end of RAM */ | ||||
| 
 | ||||
| /* Generate a link error if heap and stack don't fit into RAM */ | ||||
| _Min_Heap_Size = 0x200;      /* required amount of heap  */ | ||||
| _Min_Stack_Size = 0x400; /* required amount of stack */ | ||||
| 
 | ||||
| /* Specify the memory areas */ | ||||
| MEMORY | ||||
| { | ||||
| FLASH (rx)      : ORIGIN = 0x08000000, LENGTH = 4032K | ||||
| RAM (xrw)       : ORIGIN = 0x20000000, LENGTH = 512K | ||||
| } | ||||
| 
 | ||||
| /* Define output sections */ | ||||
| SECTIONS | ||||
| { | ||||
|   /* The startup code goes first into FLASH */ | ||||
|   .isr_vector : | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     KEEP(*(.isr_vector)) /* Startup code */ | ||||
|     . = ALIGN(4); | ||||
|   } >FLASH | ||||
| 
 | ||||
|   /* The program code and other data goes into FLASH */ | ||||
|   .text : | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     *(.text)           /* .text sections (code) */ | ||||
|     *(.text*)          /* .text* sections (code) */ | ||||
|     *(.glue_7)         /* glue arm to thumb code */ | ||||
|     *(.glue_7t)        /* glue thumb to arm code */ | ||||
|     *(.eh_frame) | ||||
| 
 | ||||
|     KEEP (*(.init)) | ||||
|     KEEP (*(.fini)) | ||||
| 
 | ||||
|     . = ALIGN(4); | ||||
|     _etext = .;        /* define a global symbols at end of code */ | ||||
|   } >FLASH | ||||
| 
 | ||||
|   /* Constant data goes into FLASH */ | ||||
|   .rodata : | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     *(.rodata)         /* .rodata sections (constants, strings, etc.) */ | ||||
|     *(.rodata*)        /* .rodata* sections (constants, strings, etc.) */ | ||||
|     . = ALIGN(4); | ||||
|   } >FLASH | ||||
| 
 | ||||
|   .ARM.extab   : { *(.ARM.extab* .gnu.linkonce.armextab.*) } >FLASH | ||||
|   .ARM : { | ||||
|     __exidx_start = .; | ||||
|     *(.ARM.exidx*) | ||||
|     __exidx_end = .; | ||||
|   } >FLASH | ||||
| 
 | ||||
|   .preinit_array     : | ||||
|   { | ||||
|     PROVIDE_HIDDEN (__preinit_array_start = .); | ||||
|     KEEP (*(.preinit_array*)) | ||||
|     PROVIDE_HIDDEN (__preinit_array_end = .); | ||||
|   } >FLASH | ||||
|   .init_array : | ||||
|   { | ||||
|     PROVIDE_HIDDEN (__init_array_start = .); | ||||
|     KEEP (*(SORT(.init_array.*))) | ||||
|     KEEP (*(.init_array*)) | ||||
|     PROVIDE_HIDDEN (__init_array_end = .); | ||||
|   } >FLASH | ||||
|   .fini_array : | ||||
|   { | ||||
|     PROVIDE_HIDDEN (__fini_array_start = .); | ||||
|     KEEP (*(SORT(.fini_array.*))) | ||||
|     KEEP (*(.fini_array*)) | ||||
|     PROVIDE_HIDDEN (__fini_array_end = .); | ||||
|   } >FLASH | ||||
| 
 | ||||
|   /* used by the startup to initialize data */ | ||||
|   _sidata = LOADADDR(.data); | ||||
| 
 | ||||
|   /* Initialized data sections goes into RAM, load LMA copy after code */ | ||||
|   .data :  | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     _sdata = .;        /* create a global symbol at data start */ | ||||
|     *(.data)           /* .data sections */ | ||||
|     *(.data*)          /* .data* sections */ | ||||
| 
 | ||||
|     . = ALIGN(4); | ||||
|     _edata = .;        /* define a global symbol at data end */ | ||||
|   } >RAM AT> FLASH | ||||
| 
 | ||||
|   /* Uninitialized data section */ | ||||
|   . = ALIGN(4); | ||||
|   .bss : | ||||
|   { | ||||
|     /* This is used by the startup in order to initialize the .bss secion */ | ||||
|     _sbss = .;         /* define a global symbol at bss start */ | ||||
|     __bss_start__ = _sbss; | ||||
|     *(.bss) | ||||
|     *(.bss*) | ||||
|     *(COMMON) | ||||
| 
 | ||||
|     . = ALIGN(4); | ||||
|     _ebss = .;         /* define a global symbol at bss end */ | ||||
|     __bss_end__ = _ebss; | ||||
|   } >RAM | ||||
| 
 | ||||
|   /* User_heap_stack section, used to check that there is enough RAM left */ | ||||
|   ._user_heap_stack : | ||||
|   { | ||||
|     . = ALIGN(4); | ||||
|     PROVIDE ( end = . ); | ||||
|     PROVIDE ( _end = . ); | ||||
|     . = . + _Min_Heap_Size; | ||||
|     . = . + _Min_Stack_Size; | ||||
|     . = ALIGN(4); | ||||
|   } >RAM | ||||
| 
 | ||||
|   /* Remove information from the standard libraries */ | ||||
|   /DISCARD/ : | ||||
|   { | ||||
|     libc.a ( * ) | ||||
|     libm.a ( * ) | ||||
|     libgcc.a ( * ) | ||||
|   } | ||||
| 
 | ||||
|   .ARM.attributes 0 : { *(.ARM.attributes) } | ||||
| } | ||||
|  | @ -0,0 +1,10 @@ | |||
| { | ||||
|   "cmake": { | ||||
|     "inc_dirs": [ | ||||
|       "inc" | ||||
|     ], | ||||
|     "srcs": [ | ||||
|       "src/**.c" | ||||
|     ] | ||||
|   } | ||||
| } | ||||
|  | @ -0,0 +1,178 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     system_at32f435_437.c | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    contains all the functions for cmsis cortex-m4 system source file | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup CMSIS
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup AT32F435_437_system
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #include "at32f435_437.h" | ||||
| 
 | ||||
| /** @addtogroup AT32F435_437_system_private_defines
 | ||||
|   * @{ | ||||
|   */ | ||||
| #ifndef VECT_TAB_OFFSET | ||||
| #define VECT_TAB_OFFSET                  0 /*!< vector table base offset field. this value must be a multiple of 0x200. */ | ||||
| #endif | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup AT32F435_437_system_private_variables
 | ||||
|   * @{ | ||||
|   */ | ||||
| unsigned int system_core_clock = HICK_VALUE; /*!< system clock frequency (core clock) */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup AT32F435_437_system_private_functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  setup the microcontroller system | ||||
|   *         initialize the flash interface. | ||||
|   * @note   this function should be used only after reset. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| void SystemInit(void) { | ||||
| #if defined (__FPU_USED) && (__FPU_USED == 1U) | ||||
|     SCB->CPACR |= ((3U << 10U * 2U) |         /* set cp10 full access */ | ||||
|                    (3U << 11U * 2U));       /* set cp11 full access */ | ||||
| #endif | ||||
| 
 | ||||
|     /* reset the crm clock configuration to the default reset state(for debug purpose) */ | ||||
|     /* set hicken bit */ | ||||
|     CRM->ctrl_bit.hicken = TRUE; | ||||
| 
 | ||||
|     /* wait hick stable */ | ||||
|     while (CRM->ctrl_bit.hickstbl != SET); | ||||
| 
 | ||||
|     /* hick used as system clock */ | ||||
|     CRM->cfg_bit.sclksel = CRM_SCLK_HICK; | ||||
| 
 | ||||
|     /* wait sclk switch status */ | ||||
|     while (CRM->cfg_bit.sclksts != CRM_SCLK_HICK); | ||||
| 
 | ||||
|     /* reset cfg register, include sclk switch, ahbdiv, apb1div, apb2div, adcdiv, clkout bits */ | ||||
|     CRM->cfg = 0; | ||||
| 
 | ||||
|     /* reset hexten, hextbyps, cfden and pllen bits */ | ||||
|     CRM->ctrl &= ~(0x010D0000U); | ||||
| 
 | ||||
|     /* reset pllms pllns pllfr pllrcs bits */ | ||||
|     CRM->pllcfg = 0x00033002U; | ||||
| 
 | ||||
|     /* reset clkout[3], usbbufs, hickdiv, clkoutdiv */ | ||||
|     CRM->misc1 = 0; | ||||
| 
 | ||||
|     /* disable all interrupts enable and clear pending bits  */ | ||||
|     CRM->clkint = 0x009F0000U; | ||||
| 
 | ||||
| #ifdef VECT_TAB_SRAM | ||||
|     SCB->VTOR = SRAM_BASE  | VECT_TAB_OFFSET;  /* vector table relocation in internal sram. */ | ||||
| #else | ||||
|     SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET;  /* vector table relocation in internal flash. */ | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  update system_core_clock variable according to clock register values. | ||||
|   *         the system_core_clock variable contains the core clock (hclk), it can | ||||
|   *         be used by the user application to setup the systick timer or configure | ||||
|   *         other parameters. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| void system_core_clock_update(void) { | ||||
|     uint32_t pll_ns = 0, pll_ms = 0, pll_fr = 0, pll_clock_source = 0, pllrcsfreq = 0; | ||||
|     uint32_t temp = 0, div_value = 0; | ||||
|     crm_sclk_type sclk_source; | ||||
| 
 | ||||
|     static const uint8_t sys_ahb_div_table[16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9}; | ||||
|     static const uint8_t pll_fr_table[6] = {1, 2, 4, 8, 16, 32}; | ||||
| 
 | ||||
|     /* get sclk source */ | ||||
|     sclk_source = crm_sysclk_switch_status_get(); | ||||
| 
 | ||||
|     switch (sclk_source) { | ||||
|         case CRM_SCLK_HICK: | ||||
|             if (((CRM->misc1_bit.hick_to_sclk) != RESET) && ((CRM->misc1_bit.hickdiv) != RESET)) | ||||
|                 system_core_clock = HICK_VALUE * 6; | ||||
|             else | ||||
|                 system_core_clock = HICK_VALUE; | ||||
|             break; | ||||
|         case CRM_SCLK_HEXT: | ||||
|             system_core_clock = HEXT_VALUE; | ||||
|             break; | ||||
|         case CRM_SCLK_PLL: | ||||
|             /* get pll clock source */ | ||||
|             pll_clock_source = CRM->pllcfg_bit.pllrcs; | ||||
| 
 | ||||
|             /* get multiplication factor */ | ||||
|             pll_ns = CRM->pllcfg_bit.pllns; | ||||
|             pll_ms = CRM->pllcfg_bit.pllms; | ||||
|             pll_fr = pll_fr_table[CRM->pllcfg_bit.pllfr]; | ||||
| 
 | ||||
|             if (pll_clock_source == CRM_PLL_SOURCE_HICK) { | ||||
|                 /* hick selected as pll clock entry */ | ||||
|                 pllrcsfreq = HICK_VALUE; | ||||
|             } else { | ||||
|                 /* hext selected as pll clock entry */ | ||||
|                 pllrcsfreq = HEXT_VALUE; | ||||
|             } | ||||
| 
 | ||||
|             system_core_clock = (pllrcsfreq * pll_ns) / (pll_ms * pll_fr); | ||||
|             break; | ||||
|         default: | ||||
|             system_core_clock = HICK_VALUE; | ||||
|             break; | ||||
|     } | ||||
| 
 | ||||
|     /* compute sclk, ahbclk frequency */ | ||||
|     /* get ahb division */ | ||||
|     temp = CRM->cfg_bit.ahbdiv; | ||||
|     div_value = sys_ahb_div_table[temp]; | ||||
|     /* ahbclk frequency */ | ||||
|     system_core_clock = system_core_clock >> div_value; | ||||
| } | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
|  | @ -0,0 +1,191 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     at32f435_437_conf.h | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    at32f435_437 config header file | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __AT32F435_437_CONF_H | ||||
| #define __AT32F435_437_CONF_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|   | ||||
| 
 | ||||
| /** @addtogroup AT32F435_periph_template
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup 435_Library_configuration Library_configuration
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| /**
 | ||||
|   * @brief in the following line adjust the value of high speed exernal crystal (hext) | ||||
|   * used in your application | ||||
|   * | ||||
|   * tip: to avoid modifying this file each time you need to use different hext, you | ||||
|   *      can define the hext value in your toolchain compiler preprocessor. | ||||
|   * | ||||
|   */ | ||||
| #if !defined  HEXT_VALUE | ||||
| #define HEXT_VALUE                       ((uint32_t)25000000) /*!< value of the high speed exernal crystal in hz */ | ||||
| #endif | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief in the following line adjust the high speed exernal crystal (hext) startup | ||||
|   * timeout value | ||||
|   */ | ||||
| #define HEXT_STARTUP_TIMEOUT             ((uint16_t)0x3000) /*!< time out for hext start up */ | ||||
| #define HICK_VALUE                       ((uint32_t)8000000) /*!< value of the high speed internal clock in hz */ | ||||
| 
 | ||||
| /* module define -------------------------------------------------------------*/ | ||||
| #define CRM_MODULE_ENABLED | ||||
| #define TMR_MODULE_ENABLED | ||||
| #define ERTC_MODULE_ENABLED | ||||
| #define GPIO_MODULE_ENABLED | ||||
| #define I2C_MODULE_ENABLED | ||||
| #define USART_MODULE_ENABLED | ||||
| #define PWC_MODULE_ENABLED | ||||
| #define CAN_MODULE_ENABLED | ||||
| #define ADC_MODULE_ENABLED | ||||
| #define DAC_MODULE_ENABLED | ||||
| #define SPI_MODULE_ENABLED | ||||
| #define EDMA_MODULE_ENABLED | ||||
| #define DMA_MODULE_ENABLED | ||||
| #define DEBUG_MODULE_ENABLED | ||||
| #define FLASH_MODULE_ENABLED | ||||
| #define CRC_MODULE_ENABLED | ||||
| #define WWDT_MODULE_ENABLED | ||||
| #define WDT_MODULE_ENABLED | ||||
| #define EXINT_MODULE_ENABLED | ||||
| #define SDIO_MODULE_ENABLED | ||||
| #define XMC_MODULE_ENABLED | ||||
| #define USB_MODULE_ENABLED | ||||
| #define ACC_MODULE_ENABLED | ||||
| #define MISC_MODULE_ENABLED | ||||
| #define QSPI_MODULE_ENABLED | ||||
| #define DVP_MODULE_ENABLED | ||||
| #define SCFG_MODULE_ENABLED | ||||
| #define EMAC_MODULE_ENABLED | ||||
| 
 | ||||
| /* includes ------------------------------------------------------------------*/ | ||||
| #ifdef CRM_MODULE_ENABLED | ||||
| #include "at32f435_437_crm.h" | ||||
| #endif | ||||
| #ifdef TMR_MODULE_ENABLED | ||||
| #include "at32f435_437_tmr.h" | ||||
| #endif | ||||
| #ifdef ERTC_MODULE_ENABLED | ||||
| #include "at32f435_437_ertc.h" | ||||
| #endif | ||||
| #ifdef GPIO_MODULE_ENABLED | ||||
| #include "at32f435_437_gpio.h" | ||||
| #endif | ||||
| #ifdef I2C_MODULE_ENABLED | ||||
| #include "at32f435_437_i2c.h" | ||||
| #endif | ||||
| #ifdef USART_MODULE_ENABLED | ||||
| #include "at32f435_437_usart.h" | ||||
| #endif | ||||
| #ifdef PWC_MODULE_ENABLED | ||||
| #include "at32f435_437_pwc.h" | ||||
| #endif | ||||
| #ifdef CAN_MODULE_ENABLED | ||||
| #include "at32f435_437_can.h" | ||||
| #endif | ||||
| #ifdef ADC_MODULE_ENABLED | ||||
| #include "at32f435_437_adc.h" | ||||
| #endif | ||||
| #ifdef DAC_MODULE_ENABLED | ||||
| #include "at32f435_437_dac.h" | ||||
| #endif | ||||
| #ifdef SPI_MODULE_ENABLED | ||||
| #include "at32f435_437_spi.h" | ||||
| #endif | ||||
| #ifdef DMA_MODULE_ENABLED | ||||
| #include "at32f435_437_dma.h" | ||||
| #endif | ||||
| #ifdef DEBUG_MODULE_ENABLED | ||||
| #include "at32f435_437_debug.h" | ||||
| #endif | ||||
| #ifdef FLASH_MODULE_ENABLED | ||||
| #include "at32f435_437_flash.h" | ||||
| #endif | ||||
| #ifdef CRC_MODULE_ENABLED | ||||
| #include "at32f435_437_crc.h" | ||||
| #endif | ||||
| #ifdef WWDT_MODULE_ENABLED | ||||
| #include "at32f435_437_wwdt.h" | ||||
| #endif | ||||
| #ifdef WDT_MODULE_ENABLED | ||||
| #include "at32f435_437_wdt.h" | ||||
| #endif | ||||
| #ifdef EXINT_MODULE_ENABLED | ||||
| #include "at32f435_437_exint.h" | ||||
| #endif | ||||
| #ifdef SDIO_MODULE_ENABLED | ||||
| #include "at32f435_437_sdio.h" | ||||
| #endif | ||||
| #ifdef XMC_MODULE_ENABLED | ||||
| #include "at32f435_437_xmc.h" | ||||
| #endif | ||||
| #ifdef ACC_MODULE_ENABLED | ||||
| #include "at32f435_437_acc.h" | ||||
| #endif | ||||
| #ifdef MISC_MODULE_ENABLED | ||||
| #include "at32f435_437_misc.h" | ||||
| #endif | ||||
| #ifdef EDMA_MODULE_ENABLED | ||||
| #include "at32f435_437_edma.h" | ||||
| #endif | ||||
| #ifdef QSPI_MODULE_ENABLED | ||||
| #include "at32f435_437_qspi.h" | ||||
| #endif | ||||
| #ifdef SCFG_MODULE_ENABLED | ||||
| #include "at32f435_437_scfg.h" | ||||
| #endif | ||||
| #ifdef EMAC_MODULE_ENABLED | ||||
| #include "at32f435_437_emac.h" | ||||
| #endif | ||||
| #ifdef DVP_MODULE_ENABLED | ||||
| #include "at32f435_437_dvp.h" | ||||
| #endif | ||||
| #ifdef USB_MODULE_ENABLED | ||||
| #include "at32f435_437_usb.h" | ||||
| #endif | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
|   /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
|  | @ -0,0 +1,175 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     at32f435_437_conf.h | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    at32f435_437 config header file | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __AT32F435_437_CONF_H | ||||
| #define __AT32F435_437_CONF_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|   | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief in the following line adjust the value of high speed exernal crystal (hext) | ||||
|   * used in your application | ||||
|   * tip: to avoid modifying this file each time you need to use different hext, you | ||||
|   *      can define the hext value in your toolchain compiler preprocessor. | ||||
|   */ | ||||
| #if !defined  HEXT_VALUE | ||||
| #define HEXT_VALUE                       ((uint32_t)8000000) /*!< value of the high speed exernal crystal in hz */ | ||||
| #endif | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief in the following line adjust the high speed exernal crystal (hext) startup | ||||
|   * timeout value | ||||
|   */ | ||||
| #define HEXT_STARTUP_TIMEOUT             ((uint16_t)0x3000) /*!< time out for hext start up */ | ||||
| #define HICK_VALUE                       ((uint32_t)8000000) /*!< value of the high speed internal clock in hz */ | ||||
| 
 | ||||
| /* module define -------------------------------------------------------------*/ | ||||
| #define CRM_MODULE_ENABLED | ||||
| #define TMR_MODULE_ENABLED | ||||
| #define ERTC_MODULE_ENABLED | ||||
| #define GPIO_MODULE_ENABLED | ||||
| #define I2C_MODULE_ENABLED | ||||
| #define USART_MODULE_ENABLED | ||||
| #define PWC_MODULE_ENABLED | ||||
| #define CAN_MODULE_ENABLED | ||||
| #define ADC_MODULE_ENABLED | ||||
| #define DAC_MODULE_ENABLED | ||||
| #define SPI_MODULE_ENABLED | ||||
| #define EDMA_MODULE_ENABLED | ||||
| #define DMA_MODULE_ENABLED | ||||
| #define DEBUG_MODULE_ENABLED | ||||
| #define FLASH_MODULE_ENABLED | ||||
| #define CRC_MODULE_ENABLED | ||||
| #define WWDT_MODULE_ENABLED | ||||
| #define WDT_MODULE_ENABLED | ||||
| #define EXINT_MODULE_ENABLED | ||||
| #define SDIO_MODULE_ENABLED | ||||
| #define XMC_MODULE_ENABLED | ||||
| #define USB_MODULE_ENABLED | ||||
| #define ACC_MODULE_ENABLED | ||||
| #define MISC_MODULE_ENABLED | ||||
| #define QSPI_MODULE_ENABLED | ||||
| #define DVP_MODULE_ENABLED | ||||
| #define SCFG_MODULE_ENABLED | ||||
| #define EMAC_MODULE_ENABLED | ||||
| 
 | ||||
| /* includes ------------------------------------------------------------------*/ | ||||
| #ifdef CRM_MODULE_ENABLED | ||||
| #include "at32f435_437_crm.h" | ||||
| #endif | ||||
| #ifdef TMR_MODULE_ENABLED | ||||
| #include "at32f435_437_tmr.h" | ||||
| #endif | ||||
| #ifdef ERTC_MODULE_ENABLED | ||||
| #include "at32f435_437_ertc.h" | ||||
| #endif | ||||
| #ifdef GPIO_MODULE_ENABLED | ||||
| #include "at32f435_437_gpio.h" | ||||
| #endif | ||||
| #ifdef I2C_MODULE_ENABLED | ||||
| #include "at32f435_437_i2c.h" | ||||
| #endif | ||||
| #ifdef USART_MODULE_ENABLED | ||||
| #include "at32f435_437_usart.h" | ||||
| #endif | ||||
| #ifdef PWC_MODULE_ENABLED | ||||
| #include "at32f435_437_pwc.h" | ||||
| #endif | ||||
| #ifdef CAN_MODULE_ENABLED | ||||
| #include "at32f435_437_can.h" | ||||
| #endif | ||||
| #ifdef ADC_MODULE_ENABLED | ||||
| #include "at32f435_437_adc.h" | ||||
| #endif | ||||
| #ifdef DAC_MODULE_ENABLED | ||||
| #include "at32f435_437_dac.h" | ||||
| #endif | ||||
| #ifdef SPI_MODULE_ENABLED | ||||
| #include "at32f435_437_spi.h" | ||||
| #endif | ||||
| #ifdef DMA_MODULE_ENABLED | ||||
| #include "at32f435_437_dma.h" | ||||
| #endif | ||||
| #ifdef DEBUG_MODULE_ENABLED | ||||
| #include "at32f435_437_debug.h" | ||||
| #endif | ||||
| #ifdef FLASH_MODULE_ENABLED | ||||
| #include "at32f435_437_flash.h" | ||||
| #endif | ||||
| #ifdef CRC_MODULE_ENABLED | ||||
| #include "at32f435_437_crc.h" | ||||
| #endif | ||||
| #ifdef WWDT_MODULE_ENABLED | ||||
| #include "at32f435_437_wwdt.h" | ||||
| #endif | ||||
| #ifdef WDT_MODULE_ENABLED | ||||
| #include "at32f435_437_wdt.h" | ||||
| #endif | ||||
| #ifdef EXINT_MODULE_ENABLED | ||||
| #include "at32f435_437_exint.h" | ||||
| #endif | ||||
| #ifdef SDIO_MODULE_ENABLED | ||||
| #include "at32f435_437_sdio.h" | ||||
| #endif | ||||
| #ifdef XMC_MODULE_ENABLED | ||||
| #include "at32f435_437_xmc.h" | ||||
| #endif | ||||
| #ifdef ACC_MODULE_ENABLED | ||||
| #include "at32f435_437_acc.h" | ||||
| #endif | ||||
| #ifdef MISC_MODULE_ENABLED | ||||
| #include "at32f435_437_misc.h" | ||||
| #endif | ||||
| #ifdef EDMA_MODULE_ENABLED | ||||
| #include "at32f435_437_edma.h" | ||||
| #endif | ||||
| #ifdef QSPI_MODULE_ENABLED | ||||
| #include "at32f435_437_qspi.h" | ||||
| #endif | ||||
| #ifdef SCFG_MODULE_ENABLED | ||||
| #include "at32f435_437_scfg.h" | ||||
| #endif | ||||
| #ifdef EMAC_MODULE_ENABLED | ||||
| #include "at32f435_437_emac.h" | ||||
| #endif | ||||
| #ifdef DVP_MODULE_ENABLED | ||||
| #include "at32f435_437_dvp.h" | ||||
| #endif | ||||
| #ifdef USB_MODULE_ENABLED | ||||
| #include "at32f435_437_usb.h" | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __AT32F435_437_CONF_H */ | ||||
| 
 | ||||
| 
 | ||||
|  | @ -0,0 +1,113 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     at32f435_437_clock.c | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    system clock config program | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* includes ------------------------------------------------------------------*/ | ||||
| #include "at32f435_437_clock.h" | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  system clock config program | ||||
|   * @note   the system clock is configured as follow: | ||||
|   *         - system clock        = (hext * pll_ns)/(pll_ms * pll_fr) | ||||
|   *         - system clock source = pll (hext) | ||||
|   *         - hext                = 8000000 | ||||
|   *         - sclk                = 250000000 | ||||
|   *         - ahbdiv              = 1 | ||||
|   *         - ahbclk              = 250000000 | ||||
|   *         - apb2div             = 2 | ||||
|   *         - apb2clk             = 125000000 | ||||
|   *         - apb1div             = 2 | ||||
|   *         - apb1clk             = 125000000 | ||||
|   *         - pll_ns              = 125 | ||||
|   *         - pll_ms              = 1 | ||||
|   *         - pll_fr              = 4 | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| void system_clock_config(void) | ||||
| { | ||||
|   /* enable pwc periph clock */ | ||||
|   crm_periph_clock_enable(CRM_PWC_PERIPH_CLOCK, TRUE); | ||||
| 
 | ||||
|   /* config ldo voltage */ | ||||
|   pwc_ldo_output_voltage_set(PWC_LDO_OUTPUT_1V3); | ||||
|   | ||||
|   /* set the flash clock divider */ | ||||
|   flash_clock_divider_set(FLASH_CLOCK_DIV_3); | ||||
|   | ||||
|   /* reset crm */ | ||||
|   crm_reset(); | ||||
| 
 | ||||
|   crm_clock_source_enable(CRM_CLOCK_SOURCE_HEXT, TRUE); | ||||
| 
 | ||||
|   /* wait till hext is ready */ | ||||
|   while(crm_hext_stable_wait() == ERROR) | ||||
|   { | ||||
|   } | ||||
| 
 | ||||
| #if defined PLL_NS | ||||
|     /* config pll clock resource */ | ||||
|     crm_pll_config(CRM_PLL_SOURCE_HEXT, PLL_NS, 1, CRM_PLL_FR_4); | ||||
| #endif | ||||
| 
 | ||||
| #if !defined PLL_NS | ||||
|     /* config pll clock resource */ | ||||
|     crm_pll_config(CRM_PLL_SOURCE_HEXT, 40, 1, CRM_PLL_FR_4); | ||||
| #endif | ||||
| 
 | ||||
|   /* enable pll */ | ||||
|   crm_clock_source_enable(CRM_CLOCK_SOURCE_PLL, TRUE); | ||||
| 
 | ||||
|   /* wait till pll is ready */ | ||||
|   while(crm_flag_get(CRM_PLL_STABLE_FLAG) != SET) | ||||
|   { | ||||
|   } | ||||
| 
 | ||||
|   /* config ahbclk */ | ||||
|   crm_ahb_div_set(CRM_AHB_DIV_1); | ||||
| 
 | ||||
|   /* config apb2clk */ | ||||
|   crm_apb2_div_set(CRM_APB2_DIV_2); | ||||
| 
 | ||||
|   /* config apb1clk */ | ||||
|   crm_apb1_div_set(CRM_APB1_DIV_2); | ||||
| 
 | ||||
|   /* enable auto step mode */ | ||||
|   crm_auto_step_mode_enable(TRUE); | ||||
| 
 | ||||
|   /* select pll as system clock source */ | ||||
|   crm_sysclk_switch(CRM_SCLK_PLL); | ||||
| 
 | ||||
|   /* wait till pll is used as system clock source */ | ||||
|   while(crm_sysclk_switch_status_get() != CRM_SCLK_PLL) | ||||
|   { | ||||
|   } | ||||
| 
 | ||||
|   /* disable auto step mode */ | ||||
|   crm_auto_step_mode_enable(FALSE); | ||||
| 
 | ||||
|   /* update system_core_clock global variable */ | ||||
|   system_core_clock_update(); | ||||
| } | ||||
|  | @ -0,0 +1,46 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     at32f435_437_clock.h | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    header file of clock program | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __AT32F435_437_CLOCK_H | ||||
| #define __AT32F435_437_CLOCK_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* includes ------------------------------------------------------------------*/ | ||||
| #include "at32f435_437.h" | ||||
| 
 | ||||
| /* exported functions ------------------------------------------------------- */ | ||||
| void system_clock_config(void); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
|  | @ -0,0 +1,148 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     at32f435_437_int.c | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    main interrupt service routines. | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* includes ------------------------------------------------------------------*/ | ||||
| #include "at32f435_437_int.h" | ||||
| 
 | ||||
|    | ||||
| /** @addtogroup AT32F437_periph_examples
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| /** @addtogroup 437_EMAC_tcp_server
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| /**
 | ||||
|   * @brief  this function handles nmi exception. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void NMI_Handler(void)
 | ||||
| //{
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles hard fault exception. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void HardFault_Handler(void)
 | ||||
| //{
 | ||||
|   /* go to infinite loop when hard fault exception occurs */ | ||||
| //  while(1)
 | ||||
| //  {
 | ||||
| //  }
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles memory manage exception. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void MemManage_Handler(void)
 | ||||
| //{
 | ||||
|   /* go to infinite loop when memory manage exception occurs */ | ||||
| //  while(1)
 | ||||
| //  {
 | ||||
| //  }
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles bus fault exception. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void BusFault_Handler(void)
 | ||||
| //{
 | ||||
|   /* go to infinite loop when bus fault exception occurs */ | ||||
| //  while(1)
 | ||||
| //  {
 | ||||
| //  }
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles usage fault exception. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void UsageFault_Handler(void)
 | ||||
| //{
 | ||||
|   /* go to infinite loop when usage fault exception occurs */ | ||||
| //  while(1)
 | ||||
| //  {
 | ||||
| //  }
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles svcall exception. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void SVC_Handler(void)
 | ||||
| //{
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles debug monitor exception. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void DebugMon_Handler(void)
 | ||||
| //{
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles pendsv_handler exception. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void PendSV_Handler(void)
 | ||||
| //{
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles systick handler. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| //void SysTick_Handler(void)
 | ||||
| //{
 | ||||
| //}
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  this function handles emac handler. | ||||
|   * @param  none | ||||
|   * @retval none | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
|  | @ -0,0 +1,58 @@ | |||
| /**
 | ||||
|   ************************************************************************** | ||||
|   * @file     at32f435_437_int.h | ||||
|   * @version  v2.0.4 | ||||
|   * @date     2021-12-31 | ||||
|   * @brief    header file of main interrupt service routines. | ||||
|   ************************************************************************** | ||||
|   *                       Copyright notice & Disclaimer | ||||
|   * | ||||
|   * The software Board Support Package (BSP) that is made available to  | ||||
|   * download from Artery official website is the copyrighted work of Artery.  | ||||
|   * Artery authorizes customers to use, copy, and distribute the BSP  | ||||
|   * software and its related documentation for the purpose of design and  | ||||
|   * development in conjunction with Artery microcontrollers. Use of the  | ||||
|   * software is governed by this copyright notice and the following disclaimer. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, | ||||
|   * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, | ||||
|   * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR | ||||
|   * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, | ||||
|   * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, | ||||
|   * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. | ||||
|   * | ||||
|   ************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __AT32F435_437_INT_H | ||||
| #define __AT32F435_437_INT_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* includes ------------------------------------------------------------------*/ | ||||
| #include "at32f435_437.h" | ||||
| 
 | ||||
| /* exported types ------------------------------------------------------------*/ | ||||
| /* exported constants --------------------------------------------------------*/ | ||||
| /* exported macro ------------------------------------------------------------*/ | ||||
| /* exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| void NMI_Handler(void); | ||||
| void HardFault_Handler(void); | ||||
| void MemManage_Handler(void); | ||||
| void BusFault_Handler(void); | ||||
| void UsageFault_Handler(void); | ||||
| void SVC_Handler(void); | ||||
| void DebugMon_Handler(void); | ||||
| void PendSV_Handler(void); | ||||
| void SysTick_Handler(void); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
|  | @ -0,0 +1,444 @@ | |||
| //
 | ||||
| // Created by xemon on 06.02.24.
 | ||||
| //
 | ||||
| _Noreturn void stop_it() { | ||||
|     while (1) { | ||||
|         asm("nop"); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| #define STOP_IT stop_it(); | ||||
| 
 | ||||
| 
 | ||||
| void WWDT_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void PVM_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TAMP_STAMP_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void ERTC_WKUP_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void FLASH_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CRM_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EXINT0_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EXINT1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EXINT2_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EXINT3_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EXINT4_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EDMA_Stream1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EDMA_Stream2_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EDMA_Stream3_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EDMA_Stream4_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EDMA_Stream5_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EDMA_Stream6_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EDMA_Stream7_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void ADC1_2_3_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CAN1_TX_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CAN1_RX0_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CAN1_RX1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CAN1_SE_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EXINT9_5_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR1_BRK_TMR9_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR1_OVF_TMR10_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR1_TRG_HALL_TMR11_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR1_CH_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR2_GLOBAL_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR3_GLOBAL_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR4_GLOBAL_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void I2C1_EVT_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void I2C1_ERR_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void I2C2_EVT_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void I2C2_ERR_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void SPI1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void SPI2_I2S2EXT_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| //void USART1_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| void USART2_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| //void USART3_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| void EXINT15_10_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void ERTCAlarm_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void OTGFS1_WKUP_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR8_BRK_TMR12_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR8_OVF_TMR13_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR8_TRG_HALL_TMR14_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR8_CH_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EDMA_Stream8_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void XMC_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void SDIO1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR5_GLOBAL_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void SPI3_I2S3EXT_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void UART4_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void UART5_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR6_DAC_GLOBAL_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR7_GLOBAL_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| //void DMA1_Channel1_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| //void DMA1_Channel2_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| //void DMA1_Channel3_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| //
 | ||||
| //void DMA1_Channel4_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| //void DMA1_Channel5_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| void EMAC_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void EMAC_WKUP_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CAN2_TX_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CAN2_RX0_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CAN2_RX1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void CAN2_SE_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void OTGFS1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| //void DMA1_Channel6_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| void DMA1_Channel7_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void USART6_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void I2C3_EVT_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void I2C3_ERR_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void OTGFS2_WKUP_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void OTGFS2_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DVP_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void FPU_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void UART7_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| //void UART8_IRQHandler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| void SPI4_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void QSPI2_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void QSPI1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DMAMUX_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void SDIO2_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void ACC_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR20_BRK_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR20_OVF_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR20_TRG_HALL_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void TMR20_CH_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DMA2_Channel1_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DMA2_Channel2_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DMA2_Channel3_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DMA2_Channel4_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DMA2_Channel5_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DMA2_Channel6_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void DMA2_Channel7_IRQHandler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| //void _estack() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| //void Reset_Handler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| void NMI_Handler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void HardFault_Handler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void MemManage_Handler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void BusFault_Handler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| void UsageFault_Handler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| //void SVC_Handler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| 
 | ||||
| void DebugMon_Handler() { | ||||
|     STOP_IT | ||||
| } | ||||
| 
 | ||||
| //void PendSV_Handler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
| //
 | ||||
| //void SysTick_Handler() {
 | ||||
| //    STOP_IT
 | ||||
| //}
 | ||||
|  | @ -0,0 +1,571 @@ | |||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file     startup_at32f435_437.s
 | ||||
|   * @version  v2.0.4
 | ||||
|   * @date     2021-12-31
 | ||||
|   * @brief    at32f435_437 devices vector table for gcc toolchain.
 | ||||
|   *           this module performs: | ||||
|   *           - set the initial sp | ||||
|   *           - set the initial pc == reset_handler, | ||||
|   *           - set the vector table entries with the exceptions isr address | ||||
|   *           - configure the clock system and the external sram to | ||||
|   *             be used as data memory (optional, to be enabled by user) | ||||
|   *           - branches to main in the c library (which eventually | ||||
|   *             calls main()). | ||||
|   *           after reset the cortex-m4 processor is in thread mode, | ||||
|   *           priority is privileged, and the stack is set to main. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
|   .syntax unified
 | ||||
|   .cpu cortex-m4 | ||||
|   .fpu softvfp
 | ||||
|   .thumb | ||||
| 
 | ||||
| .global  g_pfnVectors
 | ||||
| .global  Default_Handler
 | ||||
| 
 | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word  _sidata
 | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word  _sdata
 | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word  _edata
 | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word  _sbss
 | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word  _ebss
 | ||||
| /* stack used for SystemInit_ExtMemCtl; always internal RAM used */ | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first
 | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None
 | ||||
|  * @retval None
 | ||||
| */ | ||||
| 
 | ||||
|     .section  .text.Reset_Handler | ||||
|   .weak  Reset_Handler
 | ||||
|   .type  Reset_Handler, %function | ||||
| 
 | ||||
| 
 | ||||
| Reset_Handler: | ||||
|   movs  r1, #0 | ||||
|   b  LoopCopyDataInit | ||||
| 
 | ||||
| CopyDataInit: | ||||
|   ldr  r3, =_sidata | ||||
|   ldr  r3, [r3, r1] | ||||
|   str  r3, [r0, r1] | ||||
|   adds  r1, r1, #4 | ||||
| 
 | ||||
| LoopCopyDataInit: | ||||
|   ldr  r0, =_sdata | ||||
|   ldr  r3, =_edata | ||||
|   adds  r2, r0, r1 | ||||
|   cmp  r2, r3 | ||||
|   bcc  CopyDataInit | ||||
|   ldr  r2, =_sbss | ||||
|   b  LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
|   movs  r3, #0 | ||||
|   str  r3, [r2], #4 | ||||
| 
 | ||||
| LoopFillZerobss: | ||||
|   ldr  r3, = _ebss | ||||
|   cmp  r2, r3 | ||||
|   bcc  FillZerobss | ||||
| 
 | ||||
| /* Call the clock system intitialization function.*/ | ||||
|   bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|   bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
|   bl  main | ||||
|   bx  lr | ||||
| .size  Reset_Handler, .-Reset_Handler | ||||
| 
 | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an
 | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * @param  None
 | ||||
|  * @retval None
 | ||||
| */ | ||||
|     .section  .text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
|   b  Infinite_Loop | ||||
|   .size  Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex M3. Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| *  | ||||
| *******************************************************************************/ | ||||
|    .section  .isr_vector,"a",%progbits | ||||
|   .type  g_pfnVectors, %object | ||||
|   .size  g_pfnVectors, .-g_pfnVectors | ||||
| 
 | ||||
| 
 | ||||
| g_pfnVectors: | ||||
|   .word  _estack
 | ||||
|   .word  Reset_Handler
 | ||||
|   .word  NMI_Handler
 | ||||
|   .word  HardFault_Handler
 | ||||
|   .word  MemManage_Handler
 | ||||
|   .word  BusFault_Handler
 | ||||
|   .word  UsageFault_Handler
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  0
 | ||||
|   .word  SVC_Handler
 | ||||
|   .word  DebugMon_Handler
 | ||||
|   .word  0
 | ||||
|   .word  PendSV_Handler
 | ||||
|   .word  SysTick_Handler
 | ||||
|    | ||||
|   /* External Interrupts */ | ||||
|   .word  WWDT_IRQHandler                     /* Window Watchdog Timer                   */ | ||||
|   .word  PVM_IRQHandler                      /* PVM through EXINT Line detect           */ | ||||
|   .word  TAMP_STAMP_IRQHandler               /* Tamper and TimeStamps through the EXINT line */ | ||||
|   .word  ERTC_WKUP_IRQHandler                /* ERTC Wakeup through the EXINT line      */ | ||||
|   .word  FLASH_IRQHandler                    /* Flash                                   */ | ||||
|   .word  CRM_IRQHandler                      /* CRM                                     */ | ||||
|   .word  EXINT0_IRQHandler                   /* EXINT Line 0                            */ | ||||
|   .word  EXINT1_IRQHandler                   /* EXINT Line 1                            */ | ||||
|   .word  EXINT2_IRQHandler                   /* EXINT Line 2                            */ | ||||
|   .word  EXINT3_IRQHandler                   /* EXINT Line 3                            */ | ||||
|   .word  EXINT4_IRQHandler                   /* EXINT Line 4                            */ | ||||
|   .word  EDMA_Stream1_IRQHandler             /* EDMA Stream 1                           */ | ||||
|   .word  EDMA_Stream2_IRQHandler             /* EDMA Stream 2                           */ | ||||
|   .word  EDMA_Stream3_IRQHandler             /* EDMA Stream 3                           */ | ||||
|   .word  EDMA_Stream4_IRQHandler             /* EDMA Stream 4                           */ | ||||
|   .word  EDMA_Stream5_IRQHandler             /* EDMA Stream 5                           */ | ||||
|   .word  EDMA_Stream6_IRQHandler             /* EDMA Stream 6                           */ | ||||
|   .word  EDMA_Stream7_IRQHandler             /* EDMA Stream 7                           */ | ||||
|   .word  ADC1_2_3_IRQHandler                 /* ADC1 & ADC2 & ADC3                      */ | ||||
|   .word  CAN1_TX_IRQHandler                  /* CAN1 TX                                 */ | ||||
|   .word  CAN1_RX0_IRQHandler                 /* CAN1 RX0                                */ | ||||
|   .word  CAN1_RX1_IRQHandler                 /* CAN1 RX1                                */ | ||||
|   .word  CAN1_SE_IRQHandler                  /* CAN1 SE                                 */ | ||||
|   .word  EXINT9_5_IRQHandler                 /* EXINT Line [9:5]                        */ | ||||
|   .word  TMR1_BRK_TMR9_IRQHandler            /* TMR1 Brake and TMR9                     */ | ||||
|   .word  TMR1_OVF_TMR10_IRQHandler           /* TMR1 Overflow and TMR10                 */ | ||||
|   .word  TMR1_TRG_HALL_TMR11_IRQHandler      /* TMR1 Trigger and hall and TMR11         */ | ||||
|   .word  TMR1_CH_IRQHandler                  /* TMR1 Channel                            */ | ||||
|   .word  TMR2_GLOBAL_IRQHandler              /* TMR2                                    */ | ||||
|   .word  TMR3_GLOBAL_IRQHandler              /* TMR3                                    */ | ||||
|   .word  TMR4_GLOBAL_IRQHandler              /* TMR4                                    */ | ||||
|   .word  I2C1_EVT_IRQHandler                 /* I2C1 Event                              */ | ||||
|   .word  I2C1_ERR_IRQHandler                 /* I2C1 Error                              */ | ||||
|   .word  I2C2_EVT_IRQHandler                 /* I2C2 Event                              */ | ||||
|   .word  I2C2_ERR_IRQHandler                 /* I2C2 Error                              */ | ||||
|   .word  SPI1_IRQHandler                     /* SPI1                                    */ | ||||
|   .word  SPI2_I2S2EXT_IRQHandler             /* SPI2                                    */ | ||||
|   .word  USART1_IRQHandler                   /* USART1                                  */ | ||||
|   .word  USART2_IRQHandler                   /* USART2                                  */ | ||||
|   .word  USART3_IRQHandler                   /* USART3                                  */ | ||||
|   .word  EXINT15_10_IRQHandler               /* EXINT Line [15:10]                      */ | ||||
|   .word  ERTCAlarm_IRQHandler                /* RTC Alarm through EXINT Line            */ | ||||
|   .word  OTGFS1_WKUP_IRQHandler              /* OTGFS1 Wakeup from suspend              */ | ||||
|   .word  TMR8_BRK_TMR12_IRQHandler           /* TMR8 Brake and TMR12                    */ | ||||
|   .word  TMR8_OVF_TMR13_IRQHandler           /* TMR8 Overflow and TMR13                 */ | ||||
|   .word  TMR8_TRG_HALL_TMR14_IRQHandler      /* TMR8 Trigger and hall and TMR14         */ | ||||
|   .word  TMR8_CH_IRQHandler                  /* TMR8 Channel                            */ | ||||
|   .word  EDMA_Stream8_IRQHandler             /* EDMA Stream 8                           */ | ||||
|   .word  XMC_IRQHandler                      /* XMC                                     */ | ||||
|   .word  SDIO1_IRQHandler                    /* SDIO1                                   */ | ||||
|   .word  TMR5_GLOBAL_IRQHandler              /* TMR5                                    */ | ||||
|   .word  SPI3_I2S3EXT_IRQHandler             /* SPI3                                    */ | ||||
|   .word  UART4_IRQHandler                    /* UART4                                   */ | ||||
|   .word  UART5_IRQHandler                    /* UART5                                   */ | ||||
|   .word  TMR6_DAC_GLOBAL_IRQHandler          /* TMR6 & DAC                              */ | ||||
|   .word  TMR7_GLOBAL_IRQHandler              /* TMR7                                    */ | ||||
|   .word  DMA1_Channel1_IRQHandler            /* DMA1 Channel 1                          */ | ||||
|   .word  DMA1_Channel2_IRQHandler            /* DMA1 Channel 2                          */ | ||||
|   .word  DMA1_Channel3_IRQHandler            /* DMA1 Channel 3                          */ | ||||
|   .word  DMA1_Channel4_IRQHandler            /* DMA1 Channel 4                          */ | ||||
|   .word  DMA1_Channel5_IRQHandler            /* DMA1 Channel 5                          */ | ||||
|   .word  EMAC_IRQHandler                     /* EMAC                                    */ | ||||
|   .word  EMAC_WKUP_IRQHandler                /* EMAC Wakeup                             */ | ||||
|   .word  CAN2_TX_IRQHandler                  /* CAN2 TX                                 */ | ||||
|   .word  CAN2_RX0_IRQHandler                 /* CAN2 RX0                                */ | ||||
|   .word  CAN2_RX1_IRQHandler                 /* CAN2 RX1                                */ | ||||
|   .word  CAN2_SE_IRQHandler                  /* CAN2 SE                                 */ | ||||
|   .word  OTGFS1_IRQHandler                   /* OTGFS1                                  */ | ||||
|   .word  DMA1_Channel6_IRQHandler            /* DMA1 Channel 6                          */ | ||||
|   .word  DMA1_Channel7_IRQHandler            /* DMA1 Channel 7                          */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  USART6_IRQHandler                   /* USART6                                  */ | ||||
|   .word  I2C3_EVT_IRQHandler                 /* I2C3 Event                              */ | ||||
|   .word  I2C3_ERR_IRQHandler                 /* I2C3 Error                              */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  OTGFS2_WKUP_IRQHandler              /* OTGFS2 Wakeup from suspend              */ | ||||
|   .word  OTGFS2_IRQHandler                   /* OTGFS2                                  */ | ||||
|   .word  DVP_IRQHandler                      /* DVP                                     */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  FPU_IRQHandler                      /* FPU                                     */ | ||||
|   .word  UART7_IRQHandler                    /* UART7                                   */ | ||||
|   .word  UART8_IRQHandler                    /* UART8                                   */ | ||||
|   .word  SPI4_IRQHandler                     /* SPI4                                    */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  QSPI2_IRQHandler                    /* QSPI2                                   */ | ||||
|   .word  QSPI1_IRQHandler                    /* QSPI1                                   */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  DMAMUX_IRQHandler                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  0                                   /* Reserved                                */ | ||||
|   .word  SDIO2_IRQHandler                    /* SDIO2                                   */ | ||||
|   .word  ACC_IRQHandler                      /* ACC                                     */ | ||||
|   .word  TMR20_BRK_IRQHandler                /* TMR20 Brake                             */ | ||||
|   .word  TMR20_OVF_IRQHandler                /* TMR20 Overflow                          */ | ||||
|   .word  TMR20_TRG_HALL_IRQHandler           /* TMR20 Trigger and hall                  */ | ||||
|   .word  TMR20_CH_IRQHandler                 /* TMR20 Channel                           */ | ||||
|   .word  DMA2_Channel1_IRQHandler            /* DMA2 Channel 1                          */ | ||||
|   .word  DMA2_Channel2_IRQHandler            /* DMA2 Channel 2                          */ | ||||
|   .word  DMA2_Channel3_IRQHandler            /* DMA2 Channel 3                          */ | ||||
|   .word  DMA2_Channel4_IRQHandler            /* DMA2 Channel 4                          */ | ||||
|   .word  DMA2_Channel5_IRQHandler            /* DMA2 Channel 5                          */ | ||||
|   .word  DMA2_Channel6_IRQHandler            /* DMA2 Channel 6                          */ | ||||
|   .word  DMA2_Channel7_IRQHandler            /* DMA2 Channel 7                          */ | ||||
| 
 | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler.  | ||||
| * As they are weak aliases, any function with the same name will override  | ||||
| * this definition. | ||||
| *  | ||||
| *******************************************************************************/ | ||||
|    .weak      NMI_Handler
 | ||||
|    .thumb_set NMI_Handler,Default_Handler | ||||
|    | ||||
|    .weak      HardFault_Handler
 | ||||
|    .thumb_set HardFault_Handler,Default_Handler | ||||
|    | ||||
|    .weak      MemManage_Handler
 | ||||
|    .thumb_set MemManage_Handler,Default_Handler | ||||
|    | ||||
|    .weak      BusFault_Handler
 | ||||
|    .thumb_set BusFault_Handler,Default_Handler | ||||
| 
 | ||||
|    .weak      UsageFault_Handler
 | ||||
|    .thumb_set UsageFault_Handler,Default_Handler | ||||
| 
 | ||||
|    .weak      SVC_Handler
 | ||||
|    .thumb_set SVC_Handler,Default_Handler | ||||
| 
 | ||||
|    .weak      DebugMon_Handler
 | ||||
|    .thumb_set DebugMon_Handler,Default_Handler | ||||
| 
 | ||||
|    .weak      PendSV_Handler
 | ||||
|    .thumb_set PendSV_Handler,Default_Handler | ||||
| 
 | ||||
|    .weak      SysTick_Handler
 | ||||
|    .thumb_set SysTick_Handler,Default_Handler               | ||||
|    | ||||
|    .weak      WWDT_IRQHandler
 | ||||
|    .thumb_set WWDT_IRQHandler,Default_Handler       | ||||
| 
 | ||||
|    .weak      PVM_IRQHandler
 | ||||
|    .thumb_set PVM_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TAMP_STAMP_IRQHandler
 | ||||
|    .thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      ERTC_WKUP_IRQHandler
 | ||||
|    .thumb_set ERTC_WKUP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      FLASH_IRQHandler
 | ||||
|    .thumb_set FLASH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      CRM_IRQHandler
 | ||||
|    .thumb_set CRM_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EXINT0_IRQHandler
 | ||||
|    .thumb_set EXINT0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EXINT1_IRQHandler
 | ||||
|    .thumb_set EXINT1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EXINT2_IRQHandler
 | ||||
|    .thumb_set EXINT2_IRQHandler,Default_Handler  | ||||
| 
 | ||||
|    .weak      EXINT3_IRQHandler
 | ||||
|    .thumb_set EXINT3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EXINT4_IRQHandler
 | ||||
|    .thumb_set EXINT4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EDMA_Stream1_IRQHandler
 | ||||
|    .thumb_set EDMA_Stream1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EDMA_Stream2_IRQHandler
 | ||||
|    .thumb_set EDMA_Stream2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EDMA_Stream3_IRQHandler
 | ||||
|    .thumb_set EDMA_Stream3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EDMA_Stream4_IRQHandler
 | ||||
|    .thumb_set EDMA_Stream4_IRQHandler,Default_Handler  | ||||
| 
 | ||||
|    .weak      EDMA_Stream5_IRQHandler
 | ||||
|    .thumb_set EDMA_Stream5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EDMA_Stream6_IRQHandler
 | ||||
|    .thumb_set EDMA_Stream6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EDMA_Stream7_IRQHandler
 | ||||
|    .thumb_set EDMA_Stream7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      ADC1_2_3_IRQHandler
 | ||||
|    .thumb_set ADC1_2_3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      CAN1_TX_IRQHandler
 | ||||
|    .thumb_set CAN1_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      CAN1_RX0_IRQHandler
 | ||||
|    .thumb_set CAN1_RX0_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      CAN1_RX1_IRQHandler
 | ||||
|    .thumb_set CAN1_RX1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      CAN1_SE_IRQHandler
 | ||||
|    .thumb_set CAN1_SE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EXINT9_5_IRQHandler
 | ||||
|    .thumb_set EXINT9_5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR1_BRK_TMR9_IRQHandler
 | ||||
|    .thumb_set TMR1_BRK_TMR9_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR1_OVF_TMR10_IRQHandler
 | ||||
|    .thumb_set TMR1_OVF_TMR10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR1_TRG_HALL_TMR11_IRQHandler
 | ||||
|    .thumb_set TMR1_TRG_HALL_TMR11_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR1_CH_IRQHandler
 | ||||
|    .thumb_set TMR1_CH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR2_GLOBAL_IRQHandler
 | ||||
|    .thumb_set TMR2_GLOBAL_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR3_GLOBAL_IRQHandler
 | ||||
|    .thumb_set TMR3_GLOBAL_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR4_GLOBAL_IRQHandler
 | ||||
|    .thumb_set TMR4_GLOBAL_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      I2C1_EVT_IRQHandler
 | ||||
|    .thumb_set I2C1_EVT_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      I2C1_ERR_IRQHandler
 | ||||
|    .thumb_set I2C1_ERR_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      I2C2_EVT_IRQHandler
 | ||||
|    .thumb_set I2C2_EVT_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      I2C2_ERR_IRQHandler
 | ||||
|    .thumb_set I2C2_ERR_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      SPI1_IRQHandler
 | ||||
|    .thumb_set SPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      SPI2_I2S2EXT_IRQHandler
 | ||||
|    .thumb_set SPI2_I2S2EXT_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      USART1_IRQHandler
 | ||||
|    .thumb_set USART1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      USART2_IRQHandler
 | ||||
|    .thumb_set USART2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      USART3_IRQHandler
 | ||||
|    .thumb_set USART3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EXINT15_10_IRQHandler
 | ||||
|    .thumb_set EXINT15_10_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      ERTCAlarm_IRQHandler
 | ||||
|    .thumb_set ERTCAlarm_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      OTGFS1_WKUP_IRQHandler
 | ||||
|    .thumb_set OTGFS1_WKUP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR8_BRK_TMR12_IRQHandler
 | ||||
|    .thumb_set TMR8_BRK_TMR12_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR8_OVF_TMR13_IRQHandler
 | ||||
|    .thumb_set TMR8_OVF_TMR13_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR8_TRG_HALL_TMR14_IRQHandler
 | ||||
|    .thumb_set TMR8_TRG_HALL_TMR14_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR8_CH_IRQHandler
 | ||||
|    .thumb_set TMR8_CH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EDMA_Stream8_IRQHandler
 | ||||
|    .thumb_set EDMA_Stream8_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      XMC_IRQHandler
 | ||||
|    .thumb_set XMC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      SDIO1_IRQHandler
 | ||||
|    .thumb_set SDIO1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR5_GLOBAL_IRQHandler
 | ||||
|    .thumb_set TMR5_GLOBAL_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      SPI3_I2S3EXT_IRQHandler
 | ||||
|    .thumb_set SPI3_I2S3EXT_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      UART4_IRQHandler
 | ||||
|    .thumb_set UART4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      UART5_IRQHandler
 | ||||
|    .thumb_set UART5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR6_DAC_GLOBAL_IRQHandler
 | ||||
|    .thumb_set TMR6_DAC_GLOBAL_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR7_GLOBAL_IRQHandler
 | ||||
|    .thumb_set TMR7_GLOBAL_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA1_Channel1_IRQHandler
 | ||||
|    .thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA1_Channel2_IRQHandler
 | ||||
|    .thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA1_Channel3_IRQHandler
 | ||||
|    .thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA1_Channel4_IRQHandler
 | ||||
|    .thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA1_Channel5_IRQHandler
 | ||||
|    .thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EMAC_IRQHandler
 | ||||
|    .thumb_set EMAC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      EMAC_WKUP_IRQHandler
 | ||||
|    .thumb_set EMAC_WKUP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      CAN2_TX_IRQHandler
 | ||||
|    .thumb_set CAN2_TX_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      CAN2_RX0_IRQHandler  | ||||
|    .thumb_set CAN2_RX0_IRQHandler ,Default_Handler | ||||
| 
 | ||||
|    .weak      CAN2_RX1_IRQHandler  | ||||
|    .thumb_set CAN2_RX1_IRQHandler ,Default_Handler | ||||
| 
 | ||||
|    .weak      CAN2_SE_IRQHandler
 | ||||
|    .thumb_set CAN2_SE_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      OTGFS1_IRQHandler
 | ||||
|    .thumb_set OTGFS1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA1_Channel6_IRQHandler
 | ||||
|    .thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA1_Channel7_IRQHandler
 | ||||
|    .thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      USART6_IRQHandler
 | ||||
|    .thumb_set USART6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      I2C3_EVT_IRQHandler
 | ||||
|    .thumb_set I2C3_EVT_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      I2C3_ERR_IRQHandler
 | ||||
|    .thumb_set I2C3_ERR_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      OTGFS2_WKUP_IRQHandler
 | ||||
|    .thumb_set OTGFS2_WKUP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      OTGFS2_IRQHandler
 | ||||
|    .thumb_set OTGFS2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DVP_IRQHandler
 | ||||
|    .thumb_set DVP_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      FPU_IRQHandler
 | ||||
|    .thumb_set FPU_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      UART7_IRQHandler
 | ||||
|    .thumb_set UART7_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      UART8_IRQHandler
 | ||||
|    .thumb_set UART8_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      SPI4_IRQHandler
 | ||||
|    .thumb_set SPI4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      QSPI2_IRQHandler
 | ||||
|    .thumb_set QSPI2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      QSPI1_IRQHandler
 | ||||
|    .thumb_set QSPI1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMAMUX_IRQHandler  | ||||
|    .thumb_set DMAMUX_IRQHandler ,Default_Handler | ||||
| 
 | ||||
|    .weak      SDIO2_IRQHandler  | ||||
|    .thumb_set SDIO2_IRQHandler ,Default_Handler | ||||
| 
 | ||||
|    .weak      ACC_IRQHandler
 | ||||
|    .thumb_set ACC_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR20_BRK_IRQHandler
 | ||||
|    .thumb_set TMR20_BRK_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR20_OVF_IRQHandler
 | ||||
|    .thumb_set TMR20_OVF_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR20_TRG_HALL_IRQHandler
 | ||||
|    .thumb_set TMR20_TRG_HALL_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      TMR20_CH_IRQHandler
 | ||||
|    .thumb_set TMR20_CH_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA2_Channel1_IRQHandler
 | ||||
|    .thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA2_Channel2_IRQHandler
 | ||||
|    .thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA2_Channel3_IRQHandler
 | ||||
|    .thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA2_Channel4_IRQHandler
 | ||||
|    .thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA2_Channel5_IRQHandler
 | ||||
|    .thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA2_Channel6_IRQHandler
 | ||||
|    .thumb_set DMA2_Channel6_IRQHandler,Default_Handler | ||||
| 
 | ||||
|    .weak      DMA2_Channel7_IRQHandler
 | ||||
|    .thumb_set DMA2_Channel7_IRQHandler,Default_Handler | ||||
		Loading…
	
		Reference in New Issue