《例说51单片机(C语言版)(第3版)》——1-4 MCS-51的时序分析与复位

本节书摘来异步社区《例说51单片机(C语言版)(第3版)》一书中的第1章,第1.4节,作者:张义和,王敏男,许宏昌,余春长,更多章节内容可以访问云栖社区“异步社区”公众号查看

1-4 MCS-51的时序分析与复位

例说51单片机(C语言版)(第3版)
在本单元里将介绍8x51的复位(RESET)与时序分析。

1-4-1 时序分析

时钟脉冲是微型计算机系统的基本信号,在1-2节里,我们曾经简单地介绍了8x51的时钟脉冲。不管是采用内部的振荡电路,或由外部的时钟脉冲产生电路提供的时钟脉冲,这个时钟脉冲将成为整个系统运行的根据。89C51的额定时钟脉冲为0到24MHz,表示只要不超过24MHz即可。而89S51的额定时钟脉冲为0到33MHz,表示只要不超过33MHz就不会有问题。当我们在设计电路时,是不是要使用其最高的频率呢?当然不是这样。若时钟脉冲的频率太高,可能会导致程序复杂、使用的CPU资源增大,“延迟函数”就是最明显的例子。

通常我们会挑选一个常用、容易买到(且便宜)的石英振荡晶体,而且程序不必刻意修改就能兼容,这里挑选最常用的12MHz时钟脉冲。

如图1-21所示为12MHz时钟脉冲的时序图,一个机器周期由6个状态周期(S1到S6)所构成,每个状态周期包括两个时钟脉冲(即P1、P2)。对于12MHz的时钟脉冲而言,一个脉冲的周期为1/12μs,一个机器周期包含12个时钟脉冲,也就是1μs。

在8x51的111条指令里,除了执行乘法与除法指令需要4个机器周期外,其余指令都能在1个或2个机器周期执行完毕。尽管如此,有些指令的长度为1B,有些为2B,还有少数指令为3B。对于不同的指令,CPU如何读取与执行呢?在此将结合图1-21简要说明。首先是地址锁存使能引脚ALE,每个机器周期送出两个脉冲(分别是在S1及S4时),以锁存P0输出的地址(A0~A7),CPU将进行读取存储器的动作。对于不同的指令类型,其动作分别说明如下。

1个机器周期、1B的指令,如CLR C指令,在S1时读取指令,在S6时执行完毕;而在S4时读取下条指令,但并不使用它,直到下个机器周期的S1时再重新读取下条指令。
1个机器周期、2B的指令,如INC direct指令,在S1时读取指令,在S4时读取第二个byte,在S6时执行完毕。在下个机器周期的S1时读取下条指令,以此类推。
2个机器周期、1B的指令,如RET指令,在S1时读取指令,而在S4及下个机器周期的S1、S4时分别读取下条指令,由于指令尚未执行完毕,所以这三个阶段的指令读取都会被放弃。直到第二个机器周期的S6,指令执行完毕后,CPU才会在第三个机器周期的S1重新读取下条指令,才是有效的读取。

cd0023a9356a81f31ad03ca58908c3497e724af1

另外一种2个机器周期、1B的指令为存取外部存储器数据的指令,即MOVX指令。同样在第一个机器周期的S1时读取指令,而在S4时读取下条指令,当然也会被放弃。在S5时P0送出的A0到A7地址将被放入锁存器,而S6到下个机器周期的S3之间,由P0进行外部存储器的数据存取。由于进行外部存储器的存取,第二个机器周期的S1与S4并不进行读取指令的动作,直到第三个机器周期的S1时,才会重新读取下条指令。

1-4-2 复位

对于微型计算机系统而言,复位是一项很重要的归零动作。而8x51的复位是将高电平加到RESET引脚(第9脚)上,时间超过两个机器周期以上,也就是2μs。一般手动按8x51系统里的RESET按钮开关都会超过2μs,换言之,只要按RESET按钮,就一定会使系统复位。当系统复位时,CPU内部寄存器将回归初始状态(如表1-6所示),程序将从0000H处开始执行。

10708264d80ecc7ea073ad932f0c3deb5b9cf275
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
第1章 轻松看mcs-51 1 1-1 微型计算机与单片机 2 1-2 8051基础知识 2 1-2-1 8x51的结构 2 1-2-2 89c51/89s51的封装与引脚 3 1-2-3 89s51的基本电路 6 1-2-4 mcs-51系列 8 1-2-5 关于atmel的51系列 10 1-3 认识mcs-51的存储器结构 11 1-3-1 程序存储器 11 1-3-2 数据存储器 12 1-3-3 特殊功能寄存器 14 1-4 mcs-51时序分析复位 18 1-4-1 时序分析 18 1-4-2 复位 19 1-5 mcs-51的开发流程与工具 20 1-5-1 传统开发工具 21 1-5-2 altium designer电路设计软件 22 1-5-3 keil mvision3集成开发环境 23 1-5-4 89s51的在线刻录功能 23 .1-6 实例演练 24 1-7 实时练习 31 第2章 认识mvision3与keil c 33 2-1 mvision3环境简介 34 2-1-1 认识mvision3环境 34 2-1-2 项目管理与选项 37 2-1-3 认识调试/仿真环境 39 2-1-4 外围操作 40 2-2 keil c语言的基本结构 43 2-3 变量、常数与数据类型 47 2-3-1 数据类型 47 2-3-2 变量名称与保留字 49 2-3-3 变量的作用范围 50 2-4 存储器的形式与模式 50 2-4-1 存储器的形式 51 2-4-2 存储器的模式 52 2-5 keil c的运算符 53 2-6 keil c的流程控制 57 2-6-1 循环指令 57 2-6-2 选择指令 60 2-6-3 跳转指令 62 2-7 数组与指针 63 2-7-1 数组 63 2-7-2 指针 64 2-8 函数与中断子程序 64 2-8-1 函数 65 2-8-2 中断子程序 65 2-9 keil c的预处理命令 66 2-10 实时练习 67 第3章 输出端口的应用 69 3-1 认识mcs-51的输入/输出端口 70 3-2 输出电路设计 72 3-2-1 驱动led 72 3-2-2 驱动蜂鸣器 73 3-2-3 驱动继电器 74 3-2-4 驱动固态继电器 75 3-2-5 驱动七段led数码管 76 3-3 实例演练 78 3-3-1 驱动蜂鸣器实验 78 3-3-2 驱动继电器实验 81 3-3-3 霹雳灯实例演练 83 3-3-4 驱动七段led数码管实验 85 3-4 实时练习 87 第4章 输入口的应用 89 4-1 认识mcs-51的输入口 90 4-2 输入设备与输入电路设计 90 4-2-1 输入设备 90 4-2-2 输入电路设计 93 4-2-3 抖动与去抖动 95 4-3 实例演练 97 4-3-1 拨码开关控制 97 4-3-2 按钮开关控制 99 4-3-3 按钮切换式控制 100 4-3-4 按钮开关应用 102 4-3-5 bcd拨码开关 104 4-3-6 多个按钮开关 106 4-3-7 按钮开关放开后动作 111 4-4 实时练习 113 第5章 输入/输出端口的高级应用 115 5-1 键盘扫描 116 5-1-1 键盘扫描原理 118 5-1-2 4×4键盘程序分析 120 5-1-3 认识mm74c922/mm74c923 122 5-2 七段led数码显示管扫描 124 5-2-1 认识七段led数码管模块 125 5-2-2 认识7447/7448 128 5-2-3 认识74138/74139 131 5-3 静态显示与动态显示 132 5-3-1 使用bcd译码器 133 5-3-2 直接驱动 135 5-3-3 使用扫描译码器 136 5-3-4 闪烁 137 5-3-5 交替显示 138 5-3-6 飞入 139 5-3-7 跑马灯 141 5-4 实例演练 142 5-4-1 4位数七段led数码管 142 5-4-2 直接驱动七段led数码管 145 5-4-3 跑马灯 148 5-4-4 4×4键盘与七段led数码管 150 5-4-5 mm74c922 153 5-5 实时练习 154 第6章 中断的应用 156 6-1 认识mcs-51的中断 157 6-1-1 mcs-51的中断 157 6-1-2 中断使能寄存器ie 158 6-1-3 中断优先级寄存器ip 159 6-1-4 定时器/计数器控制寄存器tcon 160 6-1-5 中断向量 160 6-1-6 中断的应用 160 6-2 中断子程序的仿真 161 6-3 实例演练 162 6-3-1 外部中断int0 162 6-3-2 外部中断int1 164 6
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值