找回密码
 注册
关于网站域名变更的通知
查看: 514|回复: 4
打印 上一主题 下一主题

单片机 时间周期、机器周期、指令周期详解

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2021-1-19 10:35 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
本帖最后由 行者~ABC 于 2021-1-19 11:00 编辑 9 b) e- a, G# H5 F7 x! j
( n2 E  [: C0 {+ N2 {5 `4 `+ F
单片机 时间周期、机器周期、指令周期详解0 z9 j# K! {# k, e  {' L& r
时钟周期
( A, I( E5 S" v+ o9 ]  J4 s       时钟周期也称为振荡周期,定义为时钟脉冲的倒数(时钟周期就是单片机外接晶振的倒数,例如12M的晶振,它的时钟周期就是1/12us),是计算机中的最基本的、最小的时间单位。
2 v9 b, i2 k& q8 |% a# X/ h" _% `       在一个时钟周期内,CPU仅完成一个最基本的动作。时钟脉冲是计算机的基本工作脉冲,控制着计算机的工作节奏。时钟频率越高,工作速度就越快。
" o: @* ~5 d8 |" E4 ?% I% f       8051单片机把一个时钟周期定义为一个节拍(用P表示),二个节拍定义为一个状态周期(用S表示)。

8 L. H3 g- S$ H8 Q机器周期) z  z% s6 }+ ^( I7 b1 h' F2 X
       计算机中,常把一条指令的执行过程划分为若干个阶段,每一个阶段完成一项工作。每一项工作称为一个基本操作,完成一个基本操作所需要的时间称为机器周期。8051系列单片机的一个机器周期由6S周期(状态周期)组成。 一个S周期=2个节拍(P),所以8051单片机的一个机器周期=6个状态周期=12个时钟周期。
$ h' B. d  S5 ~, L- P& r       例如外接24M晶振的单片机,他的一个机器周期=12/24M 秒;
9 |* u4 _6 g! m  k; S* L
指令周期
( c/ g6 B5 t, W; a+ i2 `: o+ i6 |    执行一条指令所需要的时间,一般由若干个机器周期组成。指令不同,所需的机器周期也不同。
# o  m4 l* ?: r0 }% f: e3 Y" D, i补充其他几个周期:
3 A: a( f& `% f; e. C; `3 s  y时钟周期:处理操作的最基本单位。(CPU的主频)
( v& \# ]; I7 v存储周期:也就是一个访存指令周期。
) |+ C: }8 c0 K* t1 P指令周期、机器周期和时钟周期之间的关系:指令周期通常用若干个机器周期表示,而机器周期时间又包含有若干个时钟周期。
         51为例,晶振22.1184M,时钟周期(晶振周期)就是(1/22.1184)μs,一个机器周期包含12个时钟周期,一个机器周期就是0.5425μs。一个机器周期一般是一条指令花费的时间,也有些是2个机器周期的指令,DJNZ,就是双周期指令,所以指令周期为0.5425μs但不是所有机器周期都等于12个时钟周期的。
         PIC单片机的时钟经过内部分频,实际的工作频率为晶振频率的四分之一,同时指令的执行采用流水线方式,大部分的指令的执行时间是一个周期,所以在用4MHz的晶振时,指令执行的最大速度为1MIPS,即指令周期为1微秒。

* ?& {  H9 C2 P* o
6 @( ^; ?) v! T% v0 R
时钟周期也称为振荡周期,定义为时钟脉冲的倒数(可以这样来理解,时钟周期就是单片机外接晶振的倒数,例如12M的晶振,它的时间周期就是1/12 us),是计算机中最基本的、最小的时间单位。
* v& s; X% L" i
在一个时钟周期内,CPU仅完成一个最基本的动作。对于某种单片机,若采用了1MHZ的时钟频率,则时钟周期为1us;若采用4MHZ的时钟频率,则时钟周期为250us。由于时钟脉冲是计算机的基本工作脉冲,它控制着计算机的工作节奏(使计算机的每一步都统一到它的步调上来)。显然,对同一种机型的计算机,时钟频率越高,计算机的工作速度就越快。但是,由于不同的 计算机硬件 电路和器件的不完全相同,所以其所需要的时钟周频率范围也不一定相同。我们学习的 8051单片机 的时钟范围是1.2MHz-12MHz
& u- {2 j0 g. O

1 y3 ]' U' i3 e: l' {/ P
8051单片机中把一个时钟周期定义为一个节拍(用P表示),二个节拍定义为一个状态周期(用S表示)。
0 t3 f0 z1 a( [4 s3 p
( U  }" y  o" L$ Z% o' ]6 x
机器周期! R4 \6 O  t) z# P, a/ b) _& [
- |/ \# E1 ~. _' I. G4 m
在计算机中,为了便于管理,常把一条指令的执行过程划分为若干个阶段,每一阶段完成一项工作。例如,取指令、存储器读、存储器写等,这每一项工作称为一个基本操作。完成一个基本操作所需要的时间称为机器周期。一般情况下,一个机器周期由若干个S周期(状态周期)组成。8051系列单片机的一个机器周期同6S周期(状态周期)组成。前面已说过一个时钟周期定义为一个节拍(用P表示),二个节拍定义为一个状态周期(用S表示),8051单片机的机器周期由6个状态周期组成,也就是说一个机器周期=6个状态周期=12个时钟周期。$ v1 T, ?0 ]" ~; T& Y3 V7 l, C  J

/ [! Z3 K& i0 _: S  F; c3 _
指令周期$ j0 s. h. H6 |7 \0 [
) M0 [0 `, @* W# p! l8 ]( K4 W
指令周期是执行一条指令所需要的时间,一般由若干个机器周期组成。指令不同,所需的机器周期数也不同。对于一些简单的的单字节指令,在取指令周期中,指令取出到指令寄存器后,立即译码执行,不再需要其它的机器周期。对于一些比较复杂的指令,例如转移指令、乘法指令,则需要两个或者两个以上的机器周期。
通常含一个机器周期的指令称为单周期指令,包含两个机器周期的指令称为双周期指令。
. P5 ]  m: \0 |4 i/ M$ R
- d$ Q2 R3 @+ K% Q3 x" Q4 ~

该用户从未签到

2#
发表于 2021-1-19 11:01 | 只看该作者
周期和时钟频率有关系
  • TA的每日心情
    开心
    2023-5-15 15:14
  • 签到天数: 1 天

    [LV.1]初来乍到

    3#
    发表于 2021-1-19 11:05 | 只看该作者
    时钟周期讲的比较详细
  • TA的每日心情
    开心
    2023-5-15 15:25
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
    发表于 2021-1-19 14:26 | 只看该作者
    都和外部的晶振有关系
  • TA的每日心情
    开心
    2023-5-15 15:25
  • 签到天数: 1 天

    [LV.1]初来乍到

    5#
    发表于 2021-1-19 14:27 | 只看该作者
    同时跟晶振的频率有关系,晶振评率越高,周期越快,周期=1/频率
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-6-22 18:52 , Processed in 0.093750 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表