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

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

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
本帖最后由 行者~ABC 于 2021-1-19 11:00 编辑
+ F; M. ^5 O+ @) {. b
2 T1 P# i2 G! I8 \3 J) X单片机 时间周期、机器周期、指令周期详解
# s  e8 ]& z; m5 Z; Q( h: W
时钟周期
" U5 q1 _7 W) \$ \       时钟周期也称为振荡周期,定义为时钟脉冲的倒数(时钟周期就是单片机外接晶振的倒数,例如12M的晶振,它的时钟周期就是1/12us),是计算机中的最基本的、最小的时间单位。9 E) O* p0 C' v0 g9 U$ B  D1 z
       在一个时钟周期内,CPU仅完成一个最基本的动作。时钟脉冲是计算机的基本工作脉冲,控制着计算机的工作节奏。时钟频率越高,工作速度就越快。2 k8 X- ^1 e5 k) u
       8051单片机把一个时钟周期定义为一个节拍(用P表示),二个节拍定义为一个状态周期(用S表示)。
; J9 `; e" k6 C
机器周期5 a/ L) g* F5 _& B2 q, S* \
       计算机中,常把一条指令的执行过程划分为若干个阶段,每一个阶段完成一项工作。每一项工作称为一个基本操作,完成一个基本操作所需要的时间称为机器周期。8051系列单片机的一个机器周期由6S周期(状态周期)组成。 一个S周期=2个节拍(P),所以8051单片机的一个机器周期=6个状态周期=12个时钟周期。
( c6 m% n. `) ]       例如外接24M晶振的单片机,他的一个机器周期=12/24M 秒;

; B5 j7 Z8 e( f, G指令周期
8 K5 F$ L2 M5 y3 p; X1 @    执行一条指令所需要的时间,一般由若干个机器周期组成。指令不同,所需的机器周期也不同。
4 p' b, v! c* Y补充其他几个周期:, a9 H3 l# [* q; O+ U/ m$ ~% ^" N
时钟周期:处理操作的最基本单位。(CPU的主频) + J: K# E: b* j
存储周期:也就是一个访存指令周期。
5 }' m$ V* U) V. D指令周期、机器周期和时钟周期之间的关系:指令周期通常用若干个机器周期表示,而机器周期时间又包含有若干个时钟周期。
         51为例,晶振22.1184M,时钟周期(晶振周期)就是(1/22.1184)μs,一个机器周期包含12个时钟周期,一个机器周期就是0.5425μs。一个机器周期一般是一条指令花费的时间,也有些是2个机器周期的指令,DJNZ,就是双周期指令,所以指令周期为0.5425μs但不是所有机器周期都等于12个时钟周期的。
         PIC单片机的时钟经过内部分频,实际的工作频率为晶振频率的四分之一,同时指令的执行采用流水线方式,大部分的指令的执行时间是一个周期,所以在用4MHz的晶振时,指令执行的最大速度为1MIPS,即指令周期为1微秒。

3 ~" p3 E6 d/ S. o" B% N* K& Y$ H# c
时钟周期也称为振荡周期,定义为时钟脉冲的倒数(可以这样来理解,时钟周期就是单片机外接晶振的倒数,例如12M的晶振,它的时间周期就是1/12 us),是计算机中最基本的、最小的时间单位。

# w8 B' p0 z  N9 \5 A% O4 p& L
在一个时钟周期内,CPU仅完成一个最基本的动作。对于某种单片机,若采用了1MHZ的时钟频率,则时钟周期为1us;若采用4MHZ的时钟频率,则时钟周期为250us。由于时钟脉冲是计算机的基本工作脉冲,它控制着计算机的工作节奏(使计算机的每一步都统一到它的步调上来)。显然,对同一种机型的计算机,时钟频率越高,计算机的工作速度就越快。但是,由于不同的 计算机硬件 电路和器件的不完全相同,所以其所需要的时钟周频率范围也不一定相同。我们学习的 8051单片机 的时钟范围是1.2MHz-12MHz
& O3 X4 C" C; E. X% ^+ }

& }% A: y- V5 y7 y5 j
8051单片机中把一个时钟周期定义为一个节拍(用P表示),二个节拍定义为一个状态周期(用S表示)。
, Y% g5 ]% g' d7 W0 p+ b6 {

( o, I5 Z; ^" d
机器周期0 m. X9 F2 s5 O, d1 H( Q2 p

  K/ h9 [' D1 r
在计算机中,为了便于管理,常把一条指令的执行过程划分为若干个阶段,每一阶段完成一项工作。例如,取指令、存储器读、存储器写等,这每一项工作称为一个基本操作。完成一个基本操作所需要的时间称为机器周期。一般情况下,一个机器周期由若干个S周期(状态周期)组成。8051系列单片机的一个机器周期同6S周期(状态周期)组成。前面已说过一个时钟周期定义为一个节拍(用P表示),二个节拍定义为一个状态周期(用S表示),8051单片机的机器周期由6个状态周期组成,也就是说一个机器周期=6个状态周期=12个时钟周期。
( I: e$ q) O- S  Z- I

; V2 v% ?, `" m7 o. m$ l" d) K- W
指令周期  `; B" U! T/ E$ o/ v! T
% Q  L- P8 U" P% z! }" `
指令周期是执行一条指令所需要的时间,一般由若干个机器周期组成。指令不同,所需的机器周期数也不同。对于一些简单的的单字节指令,在取指令周期中,指令取出到指令寄存器后,立即译码执行,不再需要其它的机器周期。对于一些比较复杂的指令,例如转移指令、乘法指令,则需要两个或者两个以上的机器周期。
通常含一个机器周期的指令称为单周期指令,包含两个机器周期的指令称为双周期指令。
6 `: S0 G: I  O. l! D+ w) n& v( L

* ?% L; u/ m4 b& X% z$ M

该用户从未签到

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-10-26 03:26 , Processed in 0.140625 second(s), 23 queries , Gzip On.

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

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

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