请问在stm32f10x_rcc.h头文件第500行左右#define 定义的数值成倍增加,为什么要这样定义

2019-10-15 05:13发布

#define RCC_APB2Periph_AFIO              ((uint32_t)0x00000001)
#define RCC_APB2Periph_GPIOA             ((uint32_t)0x00000004)
#define RCC_APB2Periph_GPIOB             ((uint32_t)0x00000008)
#define RCC_APB2Periph_GPIOC             ((uint32_t)0x00000010)
#define RCC_APB2Periph_GPIOD             ((uint32_t)0x00000020)
#define RCC_APB2Periph_GPIOE             ((uint32_t)0x00000040)
#define RCC_APB2Periph_GPIOF             ((uint32_t)0x00000080)
#define RCC_APB2Periph_GPIOG             ((uint32_t)0x00000100)
#define RCC_APB2Periph_ADC1              ((uint32_t)0x00000200)
#define RCC_APB2Periph_ADC2              ((uint32_t)0x00000400)
#define RCC_APB2Periph_TIM1              ((uint32_t)0x00000800)
#define RCC_APB2Periph_SPI1              ((uint32_t)0x00001000)
#define RCC_APB2Periph_TIM8              ((uint32_t)0x00002000)
#define RCC_APB2Periph_USART1            ((uint32_t)0x00004000)
#define RCC_APB2Periph_ADC3              ((uint32_t)0x00008000)
#define RCC_APB2Periph_TIM15             ((uint32_t)0x00010000)
#define RCC_APB2Periph_TIM16             ((uint32_t)0x00020000)
#define RCC_APB2Periph_TIM17             ((uint32_t)0x00040000)
#define RCC_APB2Periph_TIM9              ((uint32_t)0x00080000)
#define RCC_APB2Periph_TIM10             ((uint32_t)0x00100000)
#define RCC_APB2Periph_TIM11             ((uint32_t)0x00200000)

#define IS_RCC_APB2_PERIPH(PERIPH) ((((PERIPH) & 0xFFC00002) == 0x00) && ((PERIPH) != 0x00))
/**
  * @}
  */ 

/** @defgroup APB1_peripheral 
  * @{
  */

#define RCC_APB1Periph_TIM2              ((uint32_t)0x00000001)
#define RCC_APB1Periph_TIM3              ((uint32_t)0x00000002)
#define RCC_APB1Periph_TIM4              ((uint32_t)0x00000004)
#define RCC_APB1Periph_TIM5              ((uint32_t)0x00000008)
#define RCC_APB1Periph_TIM6              ((uint32_t)0x00000010)
#define RCC_APB1Periph_TIM7              ((uint32_t)0x00000020)
#define RCC_APB1Periph_TIM12             ((uint32_t)0x00000040)
#define RCC_APB1Periph_TIM13             ((uint32_t)0x00000080)
#define RCC_APB1Periph_TIM14             ((uint32_t)0x00000100)
#define RCC_APB1Periph_WWDG              ((uint32_t)0x00000800)
#define RCC_APB1Periph_SPI2              ((uint32_t)0x00004000)
#define RCC_APB1Periph_SPI3              ((uint32_t)0x00008000)
#define RCC_APB1Periph_USART2            ((uint32_t)0x00020000)
#define RCC_APB1Periph_USART3            ((uint32_t)0x00040000)
#define RCC_APB1Periph_UART4             ((uint32_t)0x00080000)
#define RCC_APB1Periph_UART5             ((uint32_t)0x00100000)
#define RCC_APB1Periph_I2C1              ((uint32_t)0x00200000)
#define RCC_APB1Periph_I2C2              ((uint32_t)0x00400000)
#define RCC_APB1Periph_USB               ((uint32_t)0x00800000)
#define RCC_APB1Periph_CAN1              ((uint32_t)0x02000000)
#define RCC_APB1Periph_CAN2              ((uint32_t)0x04000000)
#define RCC_APB1Periph_BKP               ((uint32_t)0x08000000)
#define RCC_APB1Periph_PWR               ((uint32_t)0x10000000)
#define RCC_APB1Periph_DAC               ((uint32_t)0x20000000)
#define RCC_APB1Periph_CEC               ((uint32_t)0x40000000)
 
#define IS_RCC_APB1_PERIPH(PERIPH) ((((PERIPH) & 0x81013600) == 0x00) && ((PERIPH) != 0x00))
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
5条回答
Admin
1楼-- · 2019-10-15 08:44
这些数字最后基本都是映射到寄存器的某个位进行运算。
有序的列出来,提高代码的可读性。。。。。
当然,你说你非得在代码里面去移位啥的,也可以。。。但是固件库当然不会这么做,代码可读性,规范性是很重要的
kt口
2楼-- · 2019-10-15 11:11
谢谢你的解答,懂了一点。但还有令我有点困惑的地方就是。
#define RCC_APB2Periph_AFIO              ((uint32_t)0x00000001)
#define RCC_APB2Periph_GPIOA             ((uint32_t)0x00000004)
*******
#define RCC_APB1Periph_TIM2              ((uint32_t)0x00000001)
#define RCC_APB1Periph_TIM3              ((uint32_t)0x00000002)
#define RCC_APB1Periph_TIM4              ((uint32_t)0x00000004)
上面的定义中,RCC_APB2Periph_AFIO 与 RCC_APB1Periph_TIM2 均定义为 ((uint32_t)0x00000001)
                      RCC_APB2Periph_GPIOA 与 RCC_APB1Periph_TIM4 均定义为 ((uint32_t)0x00000004)
我的理解是  数字相同没什么关系,只要在 RCC_APB2Periph  与 RCC_APB1Periph 的相对唯一就行了。这样理解行不。

还有就是这些数字是如何映射到寄存器的,映射到的寄存器是随机分配,还是有映射关系。(我猜是随机的)
映射到寄存器的机制是什么?

函数
3楼-- · 2019-10-15 14:06
 精彩回答 2  元偷偷看……
Pula
4楼-- · 2019-10-15 16:15
原因:
1)目的让“RCC_APB2_PERIPH(PERIPH) ((((PERIPH) & 0xFFC00002) == 0x00)“,RCC_APB1_PERIPH(PERIPH) ((((PERIPH) & 0x81013600) == 0x00) 这两个条件可以成立;
2)用APB2、APB1已有部件的数值可以导出:举例:对APB2的最低4位的全部取值分列如此:0001(1),0100(4),1000(8),这表明唯独第1位没有占据“1”,所以在0xFFC00002这个数值里最低4位即16进制的个位导出为“2”即二进制0010,所以APB2的所有部件之数据跟这个0010相与则必定为“0”, 其它16进制位的数据的导出与此同理。
xdzhang
5楼-- · 2019-10-15 18:16
本帖最后由 xdzhang 于 2017-2-4 18:27 编辑

原子哥的课里讲的很明白。是地址偏移量。

一周热门 更多>