123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- #ifndef __SYS_H
- #define __SYS_H
- #include "STM32F10X.h"
- #define SYSTEM_SUPPORT_UCOS 0
-
-
- #define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
- #define MEM_ADDR(addr) *((volatile unsigned long *)(addr))
- #define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum))
- #define GPIOA_ODR_Addr (GPIOA_BASE+12)
- #define GPIOB_ODR_Addr (GPIOB_BASE+12)
- #define GPIOC_ODR_Addr (GPIOC_BASE+12)
- #define GPIOD_ODR_Addr (GPIOD_BASE+12)
- #define GPIOE_ODR_Addr (GPIOE_BASE+12)
- #define GPIOF_ODR_Addr (GPIOF_BASE+12)
- #define GPIOG_ODR_Addr (GPIOG_BASE+12)
- #define GPIOA_IDR_Addr (GPIOA_BASE+8)
- #define GPIOB_IDR_Addr (GPIOB_BASE+8)
- #define GPIOC_IDR_Addr (GPIOC_BASE+8)
- #define GPIOD_IDR_Addr (GPIOD_BASE+8)
- #define GPIOE_IDR_Addr (GPIOE_BASE+8)
- #define GPIOF_IDR_Addr (GPIOF_BASE+8)
- #define GPIOG_IDR_Addr (GPIOG_BASE+8)
-
- #define PAout(n) BIT_ADDR(GPIOA_ODR_Addr,n)
- #define PAin(n) BIT_ADDR(GPIOA_IDR_Addr,n)
- #define PBout(n) BIT_ADDR(GPIOB_ODR_Addr,n)
- #define PBin(n) BIT_ADDR(GPIOB_IDR_Addr,n)
- #define PCout(n) BIT_ADDR(GPIOC_ODR_Addr,n)
- #define PCin(n) BIT_ADDR(GPIOC_IDR_Addr,n)
- #define PDout(n) BIT_ADDR(GPIOD_ODR_Addr,n)
- #define PDin(n) BIT_ADDR(GPIOD_IDR_Addr,n)
- #define PEout(n) BIT_ADDR(GPIOE_ODR_Addr,n)
- #define PEin(n) BIT_ADDR(GPIOE_IDR_Addr,n)
- #define PFout(n) BIT_ADDR(GPIOF_ODR_Addr,n)
- #define PFin(n) BIT_ADDR(GPIOF_IDR_Addr,n)
- #define PGout(n) BIT_ADDR(GPIOG_ODR_Addr,n)
- #define PGin(n) BIT_ADDR(GPIOG_IDR_Addr,n)
- #define GPIO_A 0
- #define GPIO_B 1
- #define GPIO_C 2
- #define GPIO_D 3
- #define GPIO_E 4
- #define GPIO_F 5
- #define GPIO_G 6
- #define FTIR 1
- #define RTIR 2
-
- #define JTAG_SWD_DISABLE 0X02
- #define SWD_ENABLE 0X01
- #define JTAG_SWD_ENABLE 0X00
- void Stm32_Clock_Init(u8 PLL);
- void Sys_Soft_Reset(void);
- void Sys_Standby(void);
- void MY_NVIC_SetVectorTable(u32 NVIC_VectTab, u32 Offset);
- void MY_NVIC_PriorityGroupConfig(u8 NVIC_Group);
- void MY_NVIC_Init(u8 NVIC_PreemptionPriority,u8 NVIC_SubPriority,u8 NVIC_Channel,u8 NVIC_Group);
- void Ex_NVIC_Config(u8 GPIOx,u8 BITx,u8 TRIM);
- void JTAG_Set(u8 mode);
- void WFI_SET(void);
- void INTX_DISABLE(void);
- void INTX_ENABLE(void);
- void MSR_MSP(u32 addr);
- #endif
|