原创 STM8与汇编语言(2)

2010-5-18 15:25 7523 5 6 分类: MCU/ 嵌入式

                     


                   STM8与汇编语言(2<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


 


第一次打开STM8的手册时发现,CPU中的寄存器只有6个,即AXYSPPCCC。这几个寄存器,看上去特象早年苹果机使用的微处理器6502。在眼下都是多寄存器的RISC潮流下,不知ST推出的这种CPU架构有什么意图?这样的芯片能否与Microchip或者AtmelRISC结构的MCU竞争呢?在此我无意做评论,我只想了解这颗芯片。


通过仔细研究,我发现由于STM8采用了32位宽度的程序存储器结构,使得大部分的指令都能在一个周期内取出,并且采用了哈佛结构和流水线,相当多的指令也都是单周期完成的。这样的话,虽然CPUCISC架构的,但也基本上达到了单周期指令的效果,就像手册上说的,CPU的性能达到了20MISP24MHZ。就这一点来说,我个人感觉STM8还真不错。


举个例子来说,如果我们要完成内存中的28位无符号数相加,结果还保存到内存中,用C语言描述成:


unsigned char a,b,c;


c = a + b;


这一段程序,用STM8汇编可以写成如下代码:


LD    A, $1000      


ADD  A, $1001       


LD    $1002, A


这里假设a,b,c3个变量分别存储在内存中,地址为1000,10011002。从STM8的手册上可以查到,这3条指令都是单周期的,完成一个加法,只需要3个时钟周期,可见STM8CPU执行速度还是相当快的。


在这种传统的所谓CISC架构中,我特别关心累加器A与内存的访问速度,因为如果累加器与内存的访问速度是单周期的话,实际上我们就可以将内存当寄存器来看,这样写程序时就相当于拥有了一个大的寄存器阵列,或者说我们也就没必要再去考虑变量在内存中还是在寄存器中。也正是因为这一点,我对STM8越来越感兴趣了。


 


 


                                      2010330

文章评论1条评论)

登录后参与讨论

用户1186605 2014-9-27 14:36

认同
相关推荐阅读
用户1203741 2012-04-24 12:00
STM32L开发经验之一
STM32L开发经验之一   这2天在调试单位的一个电路板,电路板的核心芯片是ST公司的STM32L152,在进行系统时钟源切换时发现一个问题:当选择系统时钟源为外接振荡器HSE时,有时对...
用户1203741 2011-09-01 22:32
液晶显示器FP71G+不亮的维修
液晶显示器FP71不亮的维修 有一台液晶显示器,型号是FP71G+,开机后不亮。上网查找了一些信息,据说此款显示器出现这种现象多半都是高压有问题,而且还指出了大部分问题都出现那对三极管上(型号为570...
用户1203741 2010-09-19 16:06
算法优化的重要性
                    算法优化的重要性 前些日子,在开发一个单片机的产品时,遇到这么一个问题,就是要将一个无符号的16位数,乘以1.2288后,再赋给另一个无符号的16位数。用C语言...
用户1203741 2010-08-19 16:56
STM8的C语言编程(14)-- PWM
                STM8的C语言编程(14)-- PWM 在单片机应用系统中,也常常会用到PWM信号输出,例如电机转速的控制。现在很多高档的单片机也都集成了PWM功能模块,方便用户的应...
用户1203741 2010-08-16 10:02
STM8的C语言编程(13)-- 蜂鸣器
                 STM8的C语言编程(13)-- 蜂鸣器 蜂鸣器是现在单片机应用系统中很常见的,常用于实现报警功能。为此STM8特别集成了蜂鸣器模块,应用起来非常方便。在应用蜂鸣器模...
用户1203741 2010-08-13 09:10
STM8的C语言编程(12)-- AD转换
                                       STM8的C语言编程(12)-- AD转换 在许多的单片机应用系统中,都需要A/D转换器,将模拟量转换成数字量。在STM8...
我要评论
1
5
关闭 站长推荐上一条 /2 下一条