#define SDA_DIR_REG *(__IO uint32_t *)SDA_MOD_OFFSET 分析: *(__IOuint16_t *) (((uint32_t)0x60020000) ) (((uint32_t)0x60020000))是32位的IO地址(物理地址,硬件上設(shè)定的,不可修改) *(__IO uint16_t*)是讀取該地址的參數(shù)值,其值為16位參數(shù)。 將存儲器定義為一種數(shù)據(jù)結(jié)構(gòu),然后定義一個指向結(jié)構(gòu)體的指針。 typedef struct { __IO uint32_t MODER; /*!< GPIO port mode register, Address offset: 0x00 */ __IO uint32_t OTYPER; /*!< GPIO port output type register, Address offset: 0x04 */ __IO uint32_t OSPEEDR; /*!< GPIO port output speed register, Address offset: 0x08 */ __IO uint32_t PUPDR; /*!< GPIO port pull-up/pull-down register, Address offset: 0x0C */ __IO uint32_t IDR; /*!< GPIO port input data register, Address offset: 0x10 */ __IO uint32_t ODR; /*!< GPIO port output data register, Address offset: 0x14 */ __IO uint16_t BSRRL; /*!< GPIO port bit set/reset low register, Address offset: 0x18 */ __IO uint16_t BSRRH; /*!< GPIO port bit set/reset high register, Address offset: 0x1A */ __IO uint32_t LCKR; /*!< GPIO port configuration lock register, Address offset: 0x1C */ __IO uint32_t AFR[2]; /*!< GPIO alternate function registers, Address offset: 0x20-0x24 */ } GPIO_TypeDef;
#define PERIPH_BASE ((uint32_t)0x40000000) #define AHB1PERIPH_BASE (PERIPH_BASE 0x00020000) #define GPIOC_BASE (AHB1PERIPH_BASE 0x0800) #define GPIOC ((GPIO_TypeDef *)GPIOC_BASE) 大家看著上面的代碼應(yīng)該很熟悉,這就是我在ST給的標(biāo)準(zhǔn)外設(shè)庫中復(fù)制的,這也是CMSIS標(biāo)準(zhǔn)的驅(qū)動發(fā)方式。 typedef struct{ uint8 LCD_CMD;//用于LCD命令操作 uint8 LCD_DATA;//用于LCD數(shù)據(jù)操作} LCD_TypeDef;#define LCD_BASE ((uint32_t)(0x60000000 | 0x0000FFFF))#define LCD ((LCD_TypeDef *) LCD_BASE) 詳解如下: |
|