实现类似51单片机的IO口位控制,GD32F103/105/407
#ifndef __SYS_H
#define __SYS_H
//位带操作,实现51类似的GPIO控制功能
//具体实现思想,参考<<CM3权威指南>>第五章(87页~92页).
//IO口操作宏定义
#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))
//IO口地址映射
/*GD32F407*/
//#define GPIOA_BASE (AHB1_BUS_BASE + 0x0000)
//#define GPIOB_BASE (AHB1_BUS_BASE + 0x0400)
//#define GPIOC_BASE (AHB1_BUS_BASE + 0x0800)
//#define GPIOD_BASE (AHB1_BUS_BASE + 0x0C00)
//#define GPIOE_BASE (AHB1_BUS_BASE + 0x1000)
//#define GPIOF_BASE (AHB1_BUS_BASE + 0x1400)
//#define GPIOG_BASE (AHB1_BUS_BASE + 0x1800)
//#define GPIOH_BASE (AHB1_BUS_BASE + 0x1C00)
//#define GPIOI_BASE (AHB1_BUS_BASE + 0x2000)
//#define GPIOA_ODR_Addr (GPIOA_BASE+20) //0x40020014
//#define GPIOB_ODR_Addr (GPIOB_BASE+20) //0x40020414
//#define GPIOC_ODR_Addr (GPIOC_BASE+20) //0x40020814
//#define GPIOD_ODR_Addr (GPIOD_BASE+20) //0x40020C14
//#define GPIOE_ODR_Addr (GPIOE_BASE+20) //0x40021014
//#define GPIOF_ODR_Addr (GPIOF_BASE+20) //0x40021414
//#define GPIOG_ODR_Addr (GPIOG_BASE+20) //0x40021814
//#define GPIOH_ODR_Addr (GPIOH_BASE+20) //0x40021C14
//#define GPIOI_ODR_Addr (GPIOI_BASE+20) //0x40022014
//#define GPIOA_IDR_Addr (GPIOA_BASE+16) //0x40020010
//#define GPIOB_IDR_Addr (GPIOB_BASE+16) //0x40020410
//#define GPIOC_IDR_Addr (GPIOC_BASE+16) //0x40020810
//#define GPIOD_IDR_Addr (GPIOD_BASE+16) //0x40020C10
//#define GPIOE_IDR_Addr (GPIOE_BASE+16) //0x40021010
//#define GPIOF_IDR_Addr (GPIOF_BASE+16) //0x40021410
//#define GPIOG_IDR_Addr (GPIOG_BASE+16) //0x40021810
//#define GPIOH_IDR_Addr (GPIOH_BASE+16) //0x40021C10
//#define GPIOI_IDR_Addr (GPIOI_BASE+16) //0x40022010
/*GD32F103/105*/
#define GPIOA_BASE (APB2_BUS_BASE + 0x0800)
#define GPIOB_BASE (APB2_BUS_BASE + 0x0C00)
#define GPIOC_BASE (APB2_BUS_BASE + 0x1000)
#define GPIOD_BASE (APB2_BUS_BASE + 0x1400)
#define GPIOE_BASE (APB2_BUS_BASE + 0x1800)
#define GPIOF_BASE (APB2_BUS_BASE + 0x1C00)
#define GPIOG_BASE (APB2_BUS_BASE + 0x2000)
#define GPIOA_ODR_Addr (GPIOA_BASE+12) //0x4001080C
#define GPIOB_ODR_Addr (GPIOB_BASE+12) //0x40010C0C
#define GPIOC_ODR_Addr (GPIOC_BASE+12) //0x4001100C
#define GPIOD_ODR_Addr (GPIOD_BASE+12) //0x4001140C
#define GPIOE_ODR_Addr (GPIOE_BASE+12) //0x4001180C
#define GPIOF_ODR_Addr (GPIOF_BASE+12) //0x40011A0C
#define GPIOG_ODR_Addr (GPIOG_BASE+12) //0x40011E0C
#define GPIOA_IDR_Addr (GPIOA_BASE+8) //0x40010808
#define GPIOB_IDR_Addr (GPIOB_BASE+8) //0x40010C08
#define GPIOC_IDR_Addr (GPIOC_BASE+8) //0x40011008
#define GPIOD_IDR_Addr (GPIOD_BASE+8) //0x40011408
#define GPIOE_IDR_Addr (GPIOE_BASE+8) //0x40011808
#define GPIOF_IDR_Addr (GPIOF_BASE+8) //0x40011A08
#define GPIOG_IDR_Addr (GPIOG_BASE+8) //0x40011E08
//IO口操作,只对单一的IO口!
//确保n的值小于16!
#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) //输入
#endif