原创 单片机执行指令的过程

2006-12-18 17:27 3379 6 8 分类: MCU/ 嵌入式
单片机执行程序的过程,实际上就是执行我们所编制程序的过程。即逐条指令的过程。计算机每执行一条指令都可分为三个阶段进行。即取指令-----分析指令-----执行指令。

取指令的任务是:根据程序计数器PC中的值从程序存储器读出现行指令,送到指令寄存器。


分析指令阶段的任务是:将指令寄存器中的指令操作码取出后进行译码,分析其指令性质。如指令要求操作数,则寻找操作数地址。
计算机执行程序的过程实际上就是逐条指令地重复上述操作过程,直至遇到停机指令可循环等待指令。


一般计算机进行工作时,首先要通过外部设备把程序和数据通过输入接口电路和数据总线送入到存储器,然后逐条取出执行。但单片机中的程序一般事先我们都已通过写入器固化在片内或片外程序存储器中。因而一开机即可执行指令。


下面我们将举个实例来说明指令的执行过程:


开机时,程序计算器PC变为0000H。然后单片机在时序电路作用下自动进入执行程序过程。执行过程实际上就是取出指令(取


出存储器中事先存放的指令阶段)和执行指令(分析和执行指令)的循环过程。


例如执行指令:MOV A,#0E0H,其机器码为“74H E0H”,该指令的功能是把操作数E0H送入累加器,


0000H单元中已存放74H,0001H单元中已存放E0H。当单片机开始运行时,首先是进入取指阶段,其次序是:
1 程序计数器的内容(这时是0000H)送到地址寄存器;


2 程序计数器的内容自动加1(变为0001H);


3 地址寄存器的内容(0000H)通过内部地址总线送到存储器,以存储器中地址译码电跟,使地址为0000H的单元被选中;


4 CPU使读控制线有效;


5 在读命令控制下被选中存储器单元的内容(此时应为74H)送到内部数据总线上,因为是取指阶段,所以该内容通过数据总线被送到指令寄存器。


至此,取指阶段完成,进入译码分析和执行指令阶段。
由于本次进入指令寄存器中的内容是74H(操作码),以译码器译码后单片机就会知道该指令是要将一个数送到A累加器,而该数是在这个代码的下一个存储单元。所以,执行该指令还必须把数据(E0H)从存储器中取出送到CPU,即还要在存储器中取第二个字节。其过程与取指阶段很相似,只是此时PC已为0001H。指令译码器结合时序部件,产生74H操作码的微操作系列,使数字E0H从0001H单元取出。因为指令是要求把取得的数送到A累加器,所以取出的数字经内部数据总线进入A累加器,而不是进入指令寄存器。至此,一条指令的执行完毕。单片机中PC=0002H,PC在CPU每次向存储器取指或取数时自动加1,单片机又进入下一取指阶段。这一过程一直重复下去,直至收到暂停指令或循环等待指令暂停。CPU就是这样一条一条地执行指令,完成所有规定的功能。

PARTNER CONTENT

文章评论2条评论)

登录后参与讨论

用户72976 2007-1-1 21:38

谢谢博主

用户66632 2006-12-18 17:56

谢谢楼主!

相关推荐阅读
用户59365 2007-01-15 13:19
经典的键译程序
...
用户59365 2007-01-12 19:14
DSP与数据转换器协同工作所必须考虑的10大因素
假设您接到一项工作任务,设计一套由 DSP 与DAC与ADC等模拟器件组成的信号处理系统。如果您考虑到几个重要因素,工作就会非常简单。下面就来谈谈设计工作中应该考虑的这几个因素。详细了解应用类型第一步...
用户59365 2007-01-12 18:38
VoIP的基本传输过程简介
    通过因特网进行语音通信是一个非常复杂的系统工程,其应用面很广,因此涉及的技术也特别多,其中最根本的技术是VoIP (Voice over IP)技术,可以说,因特网语音通信是VoIP技术的一个...
用户59365 2007-01-10 20:25
方便显示器升级的复合型VGA编码器/解码器
较老式的计算机系统通过4根75Ω同轴电缆把RGB(三原色)视频和复合同步信号输送到150英尺外的RGB彩色监视器。如需升级,用于替换的VGA视频卡可直接驱动VGA监视器的内部端接部件带来的 75Ω负载...
用户59365 2007-01-10 19:38
多路输出反激电源交叉调整率
...
用户59365 2007-01-10 19:33
使用dsPIC30FMCU控制交流感应电机
...
EE直播间
更多
我要评论
2
6
关闭 站长推荐上一条 /3 下一条