打印
[菜农助学交流]

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

[复制链接]
楼主: plc_avr
手机看帖
扫描二维码
随时随地手机跟帖
21
hotpower| | 2011-11-7 15:32 | 只看该作者 回帖奖励 |倒序浏览
mcu对特殊寄存器或IO口操作效率高的原因主要在它们各自的指令集中体现,一条指令也可能对其操作。故主频远低于ARM的MCU可能要比ARM更快也不是奇怪的事情。所以ARM的优势不在于对特殊寄存器的操作即控制,优势可能在于管理或计算等。新唐用快速IO的方法估计是不错,甚至是无奈的选择。即用寄存器寻址替代位域的寻址。

使用特权

评论回复
22
hotpower| | 2011-11-7 15:32 | 只看该作者
mcu对特殊寄存器或IO口操作效率高的原因主要在它们各自的指令集中体现,一条指令也可能对其操作。故主频远低于ARM的MCU可能要比ARM更快也不是奇怪的事情。所以ARM的优势不在于对特殊寄存器的操作即控制,优势可能在于管理或计算等。新唐用快速IO的方法估计是不错,甚至是无奈的选择。即用寄存器寻址替代位域的寻址。

使用特权

评论回复
23
hotpower| | 2011-11-7 15:32 | 只看该作者
mcu对特殊寄存器或IO口操作效率高的原因主要在它们各自的指令集中体现,一条指令也可能对其操作。故主频远低于ARM的MCU可能要比ARM更快也不是奇怪的事情。所以ARM的优势不在于对特殊寄存器的操作即控制,优势可能在于管理或计算等。新唐用快速IO的方法估计是不错,甚至是无奈的选择。即用寄存器寻址替代位域的寻址。

使用特权

评论回复
24
hotpower| | 2011-11-7 15:34 | 只看该作者
晕,连发三帖

使用特权

评论回复
25
hotpower| | 2011-11-7 17:54 | 只看该作者
我看了新版本将I2C和EBI及GCR的有关名称改动了,晕。而且有些库函数的名称也调整了。

使用特权

评论回复
26
hotpower| | 2011-11-8 07:44 | 只看该作者
今天看看具体改动了什么,估计只是结构名称的局部改动,搞不清为何要这样。

使用特权

评论回复
27
plc_avr|  楼主 | 2011-11-8 08:28 | 只看该作者
好的,我在把dataflash当EEPROM,还在翻资料,呵呵。

使用特权

评论回复
28
hotpower| | 2011-11-8 09:52 | 只看该作者
ARM系列好像都没有eeprom

使用特权

评论回复
29
菜鸟同学| | 2011-11-23 14:03 | 只看该作者
库函数就是MS的MFC,不支持,不好用!

使用特权

评论回复
30
X-Hawk| | 2011-11-23 22:19 | 只看该作者
红杏就是MS的WTL, 犀利无累赘!

使用特权

评论回复
31
hotpower| | 2011-11-24 01:04 | 只看该作者
红杏就是MS的WTL, 犀利无累赘!
X-Hawk 发表于 2011-11-23 22:19


不错比酒鬼和老师暴力的头文件还是有差距的~~~
不错红杏比较通用,可以C/C++

使用特权

评论回复
32
plc_avr|  楼主 | 2011-11-24 06:16 | 只看该作者
请大叔有空时升级一下红杏,呵呵。

使用特权

评论回复
33
plc_avr|  楼主 | 2011-11-24 06:18 | 只看该作者
M0有人说差的要死,我不信,偏偏用M0来玩,M0相当给力!AVR准备停用之.........

使用特权

评论回复
34
hotpower| | 2011-11-24 07:06 | 只看该作者
M0有人说差的要死,我不信,偏偏用M0来玩,M0相当给力!AVR准备停用之.........
plc_avr 发表于 2011-11-24 06:18


好的,我准备将nuc1xx和m05x分开,因为新唐估计还有其他的M0产品。
兼容是有好处但可能坏处也不小。

使用特权

评论回复
35
hotpower| | 2011-11-24 07:34 | 只看该作者
本帖最后由 hotpower 于 2011-11-24 07:54 编辑
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需要折腾半天才得到控制寄存器物理地址。

使用特权

评论回复
36
youxin2004| | 2011-11-24 08:34 | 只看该作者
支持一下喜欢较真的大侠

使用特权

评论回复
37
strang| | 2011-11-25 20:58 | 只看该作者
强烈支持HOT大叔和烈火哥!向你们学习了。。。

使用特权

评论回复
38
watch186| | 2011-11-26 09:29 | 只看该作者
很神奇  顶一下
学着用寄存器

使用特权

评论回复
39
mcs8098| | 2011-12-20 12:44 | 只看该作者
:lol

使用特权

评论回复
40
s8906041| | 2011-12-31 16:20 | 只看该作者
天呀!效能也差太多了吧,真的需要學一下寄存器怎麼使用

使用特权

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

本版积分规则