新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > MCS-51单片机的指令时序

MCS-51单片机的指令时序

作者:时间:2012-11-03来源:网络收藏

时序是用定时单位来描述的,的时序单位有四个,它们分别是节拍、状态、机器周期和指令周期,接下来我们分别加以说明。

  • 节拍与状态:
    我们把振荡脉冲的周期定义为节拍(为方便描述,用P表示),振荡脉冲经过二分频后即得到整个工作系统的时钟信号,把时钟信号的周期定义为状态(用S表示),这样一个状态就有两个节拍,前半周期相应的节拍我们定义为1(P1),后半周期对应的节拍定义为2(P2)。
  • 机器周期:
    有固定的机器周期,规定一个机器周期有6个状态,分别表示为S1-S6,而一个状态包含两个节拍,那么一个机器周期就有12个节拍,我们可以记着S1P1、S1P2……S6P1、S6P2,一个机器周期共包含12个振荡脉冲,即机器周期就是振荡脉冲的12分频,显然,如果使用6MHz的时钟频率,一个机器周期就是2us,而如使用12MHz的时钟频率,一个机器周期就是1us。
  • 指令周期:
    执行一条指令所需要的时间称为指令周期,的指令有单字节、双字节和三字节的,所以它们的指令周期不尽相同,也就是说它们所需的机器周期不相同,可能包括一到四个不等的机器周期(这些内容,我们将在下面的章节中加以说明)。

MCS-51的
MCS-51指令系统中,按它们的长度可分为单字节指令、双字节指令和三字节指令。执行这些指令需要的时间是不同的,也就是它们所需的机器周期是不同的,有下面几种形式:

  • 单字节指令单机器周期
  • 单字节指令双机器周期
  • 双字节指令单机器周期
  • 双字节指令双机器周期
  • 三字节指令双机器周期
  • 单字节指令四机器周期(如单字节的乘除法指令)

下图是MCS-51系列图:


MCS-51单片机的指令时序


上图是单周期和双周期取指及执行时序,图中的ALE脉冲是为了锁存地址的选通信号,显然,每出现一次该信号即进行一次读指令操作。从时序图中可看出,该信号是时钟频率6分频后得到,在一个机器周期中,ALE信号两次有效,第一次在S1P2和S2P1期间,第二次在S4P2和S5P1期间。
接下来我们分别对几个典型的加以说明。

  • 单字节单周期指令:
    单字节单周期指令只进行一次读指令操作,当第二个ALE信号有效时,PC并不加1,那么读出的还是原指令,属于一次无效的读操作。
  • 双字节单周期指令:
    这类指令两次的ALE信号都是有效的,只是第一个ALE信号有效时读的是操作码,第二个ALE信号有效时读的是操作数。
  • 单字节双周期指令:
    两个机器周期需进行四读指令操作,但只有一次读操作是有效的,后三次的读操作均为无效操作。
    单字节双周期指令有一种特殊的情况,象MOVX这类指令,执行这类指令时,先在ROM中读取指令,然后对外部数据存储器进行读或写操作,头一个机器周期的第一次读指令的操作码为有效,而第二次读指令操作则为无效的。在第二个指令周期时,则访问外部数据存储器,这时,ALE信号对其操作无影响,即不会再有读指令操作动作。

上页的时序图中,我们只描述了指令的读取状态,而没有画出指令执行时序,因为每条指令都包含了具体的操作数,而操作数类型种类繁多,这里不便列出,有兴趣的读者可参阅有关书籍。


上一页 1 2 下一页

评论


相关推荐

技术专区

关闭