打印
[Cortex-M0技术交流]

关于ARM位指令效率不如MCU位指令效率的革命道理

[复制链接]
1814|9
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
hotpower|  楼主 | 2011-11-24 07:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 hotpower 于 2011-11-24 07:53 编辑

M0 GPIO用库和寄存器方式控制IO翻转速度对比,速度差近12倍!

M0有人说差的要死,我不信,偏偏用M0来玩,M0相当给力!AVR准备停用之.........
plc_avr 发表于 2011-11-24 06:18


实际ARM的指令集已经决定了它操控GPIO显然远不如MCU,因为MCU指令中已经多方考虑了对GPIO的位操作。

而ARM是通用的MCU,例如其核,NXP有M0,Nuvoton有M0,可能还有其他的M0.
那么这些厂家的M0的GPIO物理地址的分配不可能一样,故指令中不可能对GPIO进行操作,特别是位操作。

可能从汇编语言中看出,MCU可以对位操作,但是C语言实际没有真正意义的位操作。
而我们用的MCU开发平台由于是针对某些芯片的,故编译器可以识别出实现约定好的位操作。


再可以从红杏上看出,它由结构、联合、位域及枚举组成,我们需要的位操作实际是用位域替代的,是寄存器的&=~,|=等“位”操作。

故红杏在一般MCU上应用显然要效率低下,而在ARM上使用,由于通用性不支持真正的位,故红杏的效率将和理论分析的一样,即对ARM的访问,红杏的架构是最正确的。
所以可以看出在ARM用结构来描述特殊寄存器阵列是很好甚至是最好的选择。

但是由于ARM是32位的,但指令可能是16位或32位的,故32位/16位指令集中不可能包含寄存器的32位地址或立即数。所以必须通过间接寻址即指针来访问。

故特殊寄存器的物理地址必须在指令语句的附近存放,即所谓的“文字池”。

所以ARM要想操作GPIO的一位,必须做工作:
1. 在附近的文字池中取出GPIO地址,如GPIOA
2. 得到某控制寄存器,如GPIOA.xxx
3. 对GPIOA.xxx进行“位操作”,如&=~或|=

故ARM操作GPIO指令效率肯定不如MCU,这是天生的而非某厂家的不足。

新唐为了提高其访问GPIO的效率,简化了俺说的上述3条基本步骤,用寄存器替代位。
即用空间换速度。一个位就占用一个寄存器地址。
即一个GPIO的位将占用32位的ARM寄存器地址。

ARM快速操作GPIO的一位,必须改进工作:
1. 在附近的文字池中取出GPIO地址,如GPIOA
2. 得到某控制寄存器为某位,如GPIOA.bitxxx

特别注意标题的“指令效率”,假若在应用ARM远比MCU主频快,那么运行效率可能比MCU要快。

注意“指令效率”和“运行效率”的不同。前者菜农阐述了ARM通用带来的低下,后者倍频换取了提高。
例如MCU的主频(指令周期)一般在几兆以内,而ARM一般可以倍频到几十兆。
MCU访问一般需要一条指令几个指令周期,而ARM指令效率低下需要多条指令,但是由于速度快运行可能远远超过MCU。
特别注意,当ARM连续访问GPIO某寄存器的不同位时,由于只需在第1次访问时从文字池取寄存器地址外,编译器将会优化后面的连续访问,即不再需要在文字池取地址,
故访问速度要加快。即访问位的速度是不一样的。

大家可以看到:
MCU控制GPIO只需要一条指令几个字节(操作码+操作数)
ARM需要折腾半天才得到控制寄存器物理地址。

相关帖子

沙发
Ryanhsiung| | 2011-11-24 08:12 | 只看该作者
这个知道。
关于 “M0 GPIO用库和寄存器方式控制IO翻转速度对比,速度差近12倍! ”
若想用库函数有闲太慢的朋友们,可以自己添加一些I0口底层库函数,并且将函数定义__inline内联,
这样库的操作速度就不会比寄存器操作慢了

使用特权

评论回复
板凳
youxin2004| | 2011-11-24 08:25 | 只看该作者
还从来没有这么深入研究过,受教了

使用特权

评论回复
地板
cecwxf| | 2011-11-24 08:40 | 只看该作者
学习 这个得顶

使用特权

评论回复
5
crazylinuxer| | 2011-11-24 09:18 | 只看该作者
新的见解!第一次听说,不过蛮有道理。

使用特权

评论回复
6
plc_avr| | 2011-11-24 09:58 | 只看该作者
顶起来。。。

使用特权

评论回复
7
Metalor| | 2011-11-24 09:59 | 只看该作者
确实操作位太不方便

使用特权

评论回复
8
weshiluwei6| | 2011-11-24 10:04 | 只看该作者
不错啊支持大叔啊

使用特权

评论回复
9
Swallow_0322| | 2011-11-24 10:38 | 只看该作者
大叔又开始革命道理了,悉心聆听...

使用特权

评论回复
10
hotpower|  楼主 | 2011-11-25 18:11 | 只看该作者
俺只是讲点革命的道理~~~

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

个人签名:[url=http://www.21ic.com/tools/HotWC3_V1.23.html]

1460

主题

21619

帖子

506

粉丝