金牌会员
 
- 积分
- 1010
- 金钱
- 1010
- 注册时间
- 2016-4-6
- 在线时间
- 234 小时
|
5金钱
1. 目前在项目中,由于对代码执行速度有较高的要求,在编写程序时,用了原子哥的模板SYSTEM文件夹,对此在操作IO的时候使用了PAout(1)操作,我看了这个操作是采用以下方式:
[mw_shl_code=c,true]#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口地址映射
#define GPIOA_ODR_Addr (GPIOA_BASE+20) //0x40020014[/mw_shl_code]
即采用了移位运算,也就是相当于这里用了运算符操作。
还有一种方式是采用HAL库函数的读写,直接调用函数:[mw_shl_code=c,true]HAL_GPIO_WritePin(GPIOA GPIO_LED1, GPIO_PIN_SET);[/mw_shl_code]
个人还是比较喜欢原子哥的位带操作。通俗易懂。但是对于操作速度,我我想知道这两种操作方式那种速度更快。
2. 还有一个疑问就是,对于STM32执行一条C语言语句的时间计算。就单纯的一条i++语句,该怎么计算,配置频率为180Mhz. 能不能直接像51单片机一样计算,用1/180Mhz = 0.0056us = 5.6ns * 12 = 67.2ns 这样计算?
|
最佳答案
查看完整内容[请看2#楼]
一般来讲,操作寄存器都是要比库函数要快一些。使用库函数的时候,因为需要调用函数,要进行保护现场、PC装入等操作,退出函数的时候也要进行现场恢复、PC恢复的操作,占用了比较多的时间。
而使用寄存器的时候,虽然宏定义中也是有一大串加加减减移位逻辑与或非的操作,但最终这些都是常数,编译器在编译的时候会根据程序代码的实际情况把结果计算出来,写入在最终的程序中,实际执行的时候可能就只有一个逻辑与或非的操作和一个 ...
|