先定义了 “片上外设”基地址 PERIPH_BASE,接着在 PERIPH_BASE 上 加入各个总线的地址偏移,得到 APB1、APB2 总线的地址 APB1PERIPH_BASE、 APB2PERIPH_BASE,在其之上加入外设地址的偏移,得到 GPIOA-G 的外设地址,最后在 外设地址上加入各寄存器的地址偏移,得到特定寄存器的地址。一旦有了具体地址,就可 以用指...
GPIOA_BASE是寄存器的基地址 和GPIOA有关的寄存器有很多,比如ODR、IDR。加12是计算出ODR的偏移。也就是GPIOA_ODR寄存器的地址
此预处理将GPIOA变成GPIO_typedef 类型的结构体指针,默认指向了GPIOA的基地址首。在调用->指向不同结构体成员时,指针就会根据成员变量类型的大小跳不同的步进,进而访问到不同的成员地址,对不同成员地址(其实就是GPIO的各功能寄存器)赋值处理就完成操作GPIO。这是我最近理解结构体指针的感悟。
这是宏定义,是预编译命令。即,在正式编译程序前,先做字符串替代,替代完毕再编译。例如:define GPIOA ((GPIO_TypeDef *) GPIOA_BASE)预编译命令 说,凡后面程序中出现 GPIOA 的地方,把 GPIOA 换成:((GPIO_TypeDef *) GPIOA_BASE) 后再编译。后面的 #define 命令 类似。例如...
#define GPIOA ((GPIO_TypeDef*)GPIOA_BASE) 1)GPIOA_BASE被强制转换为地 址,空间以GPIO_TypeDef的 类型进行 构建,首址为GPIOA_BASE,空间内有成员,之间依各自固有类型顺序分配相应空间; 2)GPIOA宏展开,即为紧跟其后的具体内容,这样它就是一个指针了:指向以GPIOA_BASE为首址的结构体空间。所以您给出GPIOA...
这是一个逻辑判断,判断外设起始地址是否是GPIOA的基地址。PERIPH通常是外设数据结构;&(PERIPH)就是取外设结构的首地址,(u32*)是强制转换外设结构首地址为U32类型;再*就是取外设结构的前32bit数据;==就是把这个32bit数据和GPIOA的基地址做比较。
将GPIOB_BASE强转为GPIO_TypeDef 类型的指针
查看GPIOC的定义如下:#define GPIOC ((GPIO_TypeDef *) GPIOC_BASE)GPIOC_BASE是GPIOC模块的起始地址.GPIO_TypeDef 是一结构体,如下.typedef struct{vu32 CRL;vu32 CRH;vu32 IDR;vu32 ODR;vu32 BSRR;vu32 BRR;vu32 LCKR;} GPIO_TypeDef;
GPIOC_BASE是GPIOC模块的起始地址.GPIO_TypeDef 是一结构体,如下.typedef struct{vu32 CRL;vu32 CRH;vu32 IDR;vu32 ODR;vu32 BSRR;vu32 BRR;vu32 LCKR;} GPIO_TypeDef; 扫码下载作业帮搜索答疑一搜即得 答案解析 查看更多优质解析 解答一 举报 typedef struct{vu32 CRL;vu32 CRH;vu32 IDR;vu32 ODR;vu...
PORTA_BASE:0x4000.4000(假设是采用APB),GPIO_O_DATA是:0x00000000,对应的管脚GPIO_PIN_7的地址...