单元二MCS51单片机内部结构_第1页
单元二MCS51单片机内部结构_第2页
单元二MCS51单片机内部结构_第3页
单元二MCS51单片机内部结构_第4页
单元二MCS51单片机内部结构_第5页
已阅读5页,还剩34页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、mcs-51单片机内部结构单片机内部结构2.1 2.1 任务一任务一 单灯受控闪烁单灯受控闪烁2.1.1 2.1.1 硬件电路与工作原理硬件电路与工作原理2.1.2 2.1.2 控制程序控制程序2.1.3 2.1.3 源程序编辑、编译、下载源程序编辑、编译、下载2.1.4 2.1.4 相关知识相关知识返回主目录 org 0000hljmp mainorg 0003hclr 20h.0retiorg 000bhljmp delay main: setb 20h.0mov tmod,#01h mov tl0,#00h mov th0,#4chmov b,#20 setb it0 setb ea s

2、etb ex0org、end等等伪指令将在核伪指令将在核心模块的单元心模块的单元三、四中详细三、四中详细讲解讲解 setb et0setb px0mov p1,#00h setb tr0begin:jb 20h.0,showmov b,#250 cjne b,#00,$ mov a,p1 cpl a mov p1,a ; sjmp begindelay:mov tl0,#00h mov th0,#4chdjnz b,loopmov b,#20loop:retiend任务中假设单片任务中假设单片机外接的石英晶机外接的石英晶体振荡器的频率体振荡器的频率为为11.0592mhz 1.1.打开打开“伟

3、福伟福”模拟仿真软件进行程序的编辑、编译。模拟仿真软件进行程序的编辑、编译。 1 1、正确选择单片机类型、正确选择单片机类型87518751或或80318031 2 2、正确选择编译器伟福编译器、正确选择编译器伟福编译器 3 3、选择模拟仿真功能、选择模拟仿真功能 4 4、打开或新建文件进行编辑、打开或新建文件进行编辑 5 5、编译、编译2.2.打开打开“ispisp下载软件下载软件”将目标文件下载到将目标文件下载到isp-4isp-4实验开发实验开发板上的板上的at89s51at89s51单片机芯片,观察程序运行结果。单片机芯片,观察程序运行结果。 1 1、编译成功后打开下载软件、编译成功后

4、打开下载软件 2 2、选择好单片机、选择好单片机8989s51s51并测试并测试 3 3、打开伟福、打开伟福60006000编译生成的编译生成的. .binbin或或. .hexhex文件文件 4 4、选择自动写完成擦除、写、读、校验过程、选择自动写完成擦除、写、读、校验过程 5 5、观看运行结果、观看运行结果 从刚才的任务中,我们看到发光二极管随着程序的运从刚才的任务中,我们看到发光二极管随着程序的运行,有规律的闪动,那么,现在我们来看看单片机是怎样行,有规律的闪动,那么,现在我们来看看单片机是怎样将程序中运行的结果送给发光二极管的。将程序中运行的结果送给发光二极管的。 原来,原来,89s5

5、1单片机上有单片机上有4组组8位位i/o口:口:p0、p1、p2和和p3口,口,p1、p2和和p3为准双向口,为准双向口,p0口则为双向三态输入口则为双向三态输入输出口,他们在单片机中,主要承担了和单片机外部设备输出口,他们在单片机中,主要承担了和单片机外部设备打交道的任务,下面我们分别介绍这几个打交道的任务,下面我们分别介绍这几个i/o口:口: p0口除了作普通口除了作普通的的i/o口,直接口,直接和外部设备打交和外部设备打交道外道外;还用作片还用作片外总线的地址总外总线的地址总线线ab0-ab7的低的低八位、数据总线。八位、数据总线。 p2口除了作普通口除了作普通的的i/o口,直接口,直接

6、和外部设备打交和外部设备打交道外道外;还用作片还用作片外总线的地址总外总线的地址总线的高八位地址线的高八位地址线线ab8-ab15 注意:注意:p0口在作输出入口使用时,由于它无内部上拉电阻,为口在作输出入口使用时,由于它无内部上拉电阻,为了在口线上输出高电平并具有一定的驱动能力,必须外接上拉了在口线上输出高电平并具有一定的驱动能力,必须外接上拉电阻。作输入口使用时,为了防止口锁存器对输入口线的输入电阻。作输入口使用时,为了防止口锁存器对输入口线的输入信号造成影响,必须先往口锁存器写信号造成影响,必须先往口锁存器写1。同理,。同理,p2口作输入时,口作输入时,也必须先往口锁存器写也必须先往口锁

7、存器写1。 p1口只用作普通口只用作普通输入输出口输入输出口注意:注意:和和p0、p2口一样,为防止口锁存器对输入口线造成影响,口一样,为防止口锁存器对输入口线造成影响,p1口作输入时,也必须先往口锁存器写口作输入时,也必须先往口锁存器写1。 p3口除了作普口除了作普通的通的i/o口(功口(功能和能和p1口一样)口一样)直接和外部设直接和外部设备打交道外备打交道外;还还具有第二功能。具有第二功能。 p3.0 串行输入口串行输入口(rxd) p3.1串行输出口串行输出口(txd) p3.2 外中断外中断0(int0) p3.3 外中断外中断1(int1) p3.5 定时定时/计数器计数器1的外部

8、输入口的外部输入口(t1) p3.6 外部数据存储器写选通外部数据存储器写选通(wr) p3.4 定时定时/计数器计数器0的外部输入口的外部输入口(t0) p3.7 外部数据存储器读选通外部数据存储器读选通(rd) 从前面的任务中,我们还看到要控制灯闪烁,必须编制从前面的任务中,我们还看到要控制灯闪烁,必须编制程序,还必须将控制灯的相关数据预先存储,那么,在单片程序,还必须将控制灯的相关数据预先存储,那么,在单片机中的程序和数据是怎样保存的?原来,在单片机内部有程机中的程序和数据是怎样保存的?原来,在单片机内部有程序存储器和数据存储器,如果内部程序存储器和数据存储器序存储器和数据存储器,如果内

9、部程序存储器和数据存储器的容量不够的话,还可以在单片机外部为它扩展,最大我们的容量不够的话,还可以在单片机外部为它扩展,最大我们可以将程序存储器空间总容量扩大到可以将程序存储器空间总容量扩大到64k,将数据存储器在,将数据存储器在片外再单独扩展片外再单独扩展64k,这样,以,这样,以89s51为例,数据存储器的总为例,数据存储器的总容量可达容量可达64k(片外)(片外)128字节(片内)。字节(片内)。 mcs-51单片机的存储器组织结构,采用典型的哈佛结构,单片机的存储器组织结构,采用典型的哈佛结构,即程序存储器和数据存储器完全独立,拥有各自的寻址系统,即程序存储器和数据存储器完全独立,拥有

10、各自的寻址系统,包括片内数据存储器与片外数据存储器都拥有自己独立的寻包括片内数据存储器与片外数据存储器都拥有自己独立的寻址系统。址系统。 0 0f ff ff ff fh h0 0f ff ff fh h1earom 外外部部0earom 内内部部h0000 程序存储器程序存储器1000h1000hh00000 00 08 80 0h hram内内部部0 00 0f ff fh h能寄存器特殊功0 0f ff ff ff fh h)(外部外部k64ram 数据存储器数据存储器h00000 00 07 7f fh h用途:用途: 存放程序及程序运行时所需的常数。存放程序及程序运行时所需的常数。寻

11、址范围:寻址范围:00000000h ffffh h ffffh 容量容量6464kbkb,即地址长度:即地址长度:1616位位 1ea ,寻址内部寻址内部rom;说明说明:当当pc值超过片内值超过片内rom容量时会自动转向容量时会自动转向 外部存储器外部存储器空间。空间。0ea ,寻址外部寻址外部rom。 ea说明说明:8031单片机单片机必须接低电平。必须接低电平。程序存储器中程序存储器中6 6个具有特殊含义的单元个具有特殊含义的单元 0000h 系统复位,系统复位,pc指向此处;指向此处; 0003h 外部中断外部中断0入口入口 000bh t0溢出中断入口溢出中断入口 0013h 外中

12、断外中断1入口入口 001bh t1溢出中断入口溢出中断入口 0023h 串口中断入口串口中断入口用途:用途:存放程序执行的中间结果和过程数据的存放程序执行的中间结果和过程数据的 。物理上分为两大区域:物理上分为两大区域: 00h 7fh即即128b用户用户ram区。区。 80h ffh即特殊功能寄存器区。即特殊功能寄存器区。组组通通用用寄寄存存器器区区第第0组组通通用用寄寄存存器器区区第第1组组通通用用寄寄存存器器区区第第2组组通通用用寄寄存存器器区区第第3)(位位地地址址位位寻寻址址区区fh7h00区区用用户户ramh00h08/h07h10/fh0h18/h17h20/fh1h30/fh

13、2fh7r0、r1、r2、r3、r4、r5、r6、r7即可位寻址,又可字节寻址即可位寻址,又可字节寻址数据缓冲区、堆栈区、工作数据缓冲区、堆栈区、工作单元单元位寻址区(位寻址区(20h2fh)16个字节。个字节。16*8=128位,每一位都有一个位地址,范围为:位,每一位都有一个位地址,范围为:00h7fh,位地址区也可作为一般的用户位地址区也可作为一般的用户ram使用。使用。单单元元地地址址位位地地址址eh2fh2h20h21h77fh7h76eh7h75dh7h74ch7h73bh7h72ah7h71h79h70h78h07fh0h06eh0h05dh0h04ch0h03bh0h02ah0

14、h01h09h00h08 寄存器寄存器 位地址位地址/ /位定义位定义 地址地址 f7f7 f6f6 f5f5 f4f4 f3f3 f2f2 f1f1 f0f0 b b f0hf0h e7e7 e6e6 e5e5 e4e4 e3e3 e2e2 e1e1 e0e0 accacc e0e0 d7d7 d6d6 d5d5 d4d4 d3d3 d2d2 d1d1 d0d0 pswpsw cycy acac f0f0 rs1rs1 rs0rs0 ovov / / p p d0hd0h bfbf bebe bdbd bcbc bbbb baba b9b9 b8b8 ipip b8hb8h b7b7 b6b

15、6 b5b5 b4b4 b3b3 b2b2 b1b1 b0b0 p3p3 p3.7p3.7 p3.6p3.6 p3.5p3.5 p3.p3.4 4 p3.3p3.3 p3.2p3.2 p3.1p3.1 p3.0p3.0 b0hb0h ieie a8ha8h a7a7 a6a6 a5a5 a4a4 a3a3 a2a2 a1a1 a0a0 p2p2 p2.7p2.7 p2.6p2.6 p2.5p2.5 p2.4p2.4 p2.3p2.3 p2.2p2.2 p2.1p2.1 p2.0p2.0 a0ha0h sbufsbuf 9999h h 程序计数器在物理上是独立的,它不属于特殊内部数据程序计数器在

16、物理上是独立的,它不属于特殊内部数据存储器块中。存储器块中。 pc是一个是一个16位的计数器,由两个八位寄存器位的计数器,由两个八位寄存器pch和和pcl组成,用于存放一条要执行的指令地址,寻址范围为组成,用于存放一条要执行的指令地址,寻址范围为64kb,pc有自动加有自动加1功能,即完成了一条指令的执行后,其内容自功能,即完成了一条指令的执行后,其内容自动加动加1。 pc本身并没有地址,因而不可寻址,用户无法对它进行本身并没有地址,因而不可寻址,用户无法对它进行读写,但是可以通过转移、调用、返回等指令改变其内容,读写,但是可以通过转移、调用、返回等指令改变其内容,以控制程序的执行顺序。以控制

17、程序的执行顺序。 累加器累加器a是一个最常用的专用寄存器,大部分单操是一个最常用的专用寄存器,大部分单操作指令的一个操作数取自累加器,很多双操作数指令中作指令的一个操作数取自累加器,很多双操作数指令中的一个操作数也取自累加器。的一个操作数也取自累加器。 加、减、乘、除法运算的指令,运算结果都存放于加、减、乘、除法运算的指令,运算结果都存放于累加器累加器a或寄存器或寄存器b中。中。 大部分的数据操作都会通过累加器大部分的数据操作都会通过累加器a进行,它形象进行,它形象于一个数据运输中转站,在数据传送过程中,任何两个于一个数据运输中转站,在数据传送过程中,任何两个不能直接实现数据的传送单元之间,通

18、过累加器不能直接实现数据的传送单元之间,通过累加器a中转,中转,都能送达目的。都能送达目的。 在乘除法指令中,乘法指令中的两个操作数分别取自在乘除法指令中,乘法指令中的两个操作数分别取自累加器累加器a和寄存器和寄存器b,其结果存放于,其结果存放于ab寄存器对中。除法寄存器对中。除法指令中,被除数取自累加器指令中,被除数取自累加器a,除数取自寄存器,除数取自寄存器b,结果商,结果商存放于累加器存放于累加器a,余数存放于寄存器,余数存放于寄存器b中。中。 位序位序psw.7psw.6psw.5psw.4psw.3psw.2psw.1psw.0位标志位标志cyacf0rs1rs0ov-pcy 进位进

19、位/借位标志;位累加器。借位标志;位累加器。ac 辅助进辅助进/借位标志;用于十进制调整。借位标志;用于十进制调整。f0 用户定义标志位;软件置位用户定义标志位;软件置位/清零。清零。ov 溢出标志;溢出标志; 硬件置位硬件置位/清零。清零。p 奇偶标志;奇偶标志;a中中1的个数为奇数的个数为奇数 p = 1;否则否则 p = 0。 数据指针为数据指针为16位寄存器,编程时,既可以按位寄存器,编程时,既可以按16位寄存位寄存器来使用,也可以按两个器来使用,也可以按两个8位寄存器来使用,即高位字节位寄存器来使用,即高位字节寄存器寄存器dph和低位字节和低位字节dpl。 dptr主要是用来保存主要

20、是用来保存16位地址,当对位地址,当对64kb外部数据存外部数据存储器寻址时,可作为间址寄存器使用,此时,使用如下两储器寻址时,可作为间址寄存器使用,此时,使用如下两条指令:条指令: movx a, dptr movx dptr, a 在访问程序存储器时,在访问程序存储器时,dptr可用来作基址寄存器,可用来作基址寄存器,采用基址采用基址+变址寻址方式访问程序存储器,这条指令常用变址寻址方式访问程序存储器,这条指令常用于读取程序存储器内的表格数据。于读取程序存储器内的表格数据。 movc a, a+dptr指明栈顶元指明栈顶元素的地址,素的地址,8位,可软件位,可软件设置初值,设置初值,复位时

21、复位时sp = 07h。 i/o口寄存器口寄存器p0、p1、p2和和p3分别是分别是mcs-51单片机的四单片机的四组组i/o口锁存器。口锁存器。 mcs-51单片机中有两个单片机中有两个16位的定时位的定时/计数器计数器t0和和t1,它,它们由四个们由四个8位寄存器组成的,两个位寄存器组成的,两个16位定时位定时/计数器却是完计数器却是完全独立的。我们可以单独对这四个寄存器进行寻址,但不全独立的。我们可以单独对这四个寄存器进行寻址,但不能把能把t0和和t1当作当作16位寄存来使用。位寄存来使用。 tmod寄存器是一个专用寄存器,用于控制两个定时寄存器是一个专用寄存器,用于控制两个定时计数器的

22、工作方式,计数器的工作方式,tmod可以用字节传送指令设置其内可以用字节传送指令设置其内容,但不能位寻址容,但不能位寻址 。 知道了单片机通过知道了单片机通过i/o口与外设打交道,也知道了单片口与外设打交道,也知道了单片机的程序与数据如何保存,到底单片机是如何运行程序的?机的程序与数据如何保存,到底单片机是如何运行程序的?原来单片机和其他微机一样,也拥有一个中央处理器原来单片机和其他微机一样,也拥有一个中央处理器(cpu)。)。 它通过单片机的内部总线,将单片机内部的各个部分:它通过单片机的内部总线,将单片机内部的各个部分:程序存储器程序存储器(rom)、数据存储器、数据存储器(ram)、定时

23、、定时/计数器、并行计数器、并行接口、串行接口和中断系统等联系在一起接口、串行接口和中断系统等联系在一起 。内部总线有三种内部总线有三种 数据总线:专门用来传送数据信息数据总线:专门用来传送数据信息 。地址总线:专门用来传送地址信息,选中各操作单元。地址总线:专门用来传送地址信息,选中各操作单元。 控制总线:专门用来传送控制总线:专门用来传送cpu各种控制命令,以便各种控制命令,以便cpu统一指挥协调工作。完成程序所要执行的各种功能。统一指挥协调工作。完成程序所要执行的各种功能。 cpu执行程序一般包括两个主要过程执行程序一般包括两个主要过程 第一,就是从程序存储器中取出指令,指令的地址由第一

24、,就是从程序存储器中取出指令,指令的地址由pc指针提供。指针提供。 第二,就是执指过程,取出的指令代码首先被送到第二,就是执指过程,取出的指令代码首先被送到cpu中控制器中的指令寄存器,再通过指令译码器译码变成各中控制器中的指令寄存器,再通过指令译码器译码变成各种电信号,从而实现指令的各种功能。种电信号,从而实现指令的各种功能。 执行执行 取指令取指令 分析分析 现在我们知道了单片机怎样取指、执指,即怎样运行程现在我们知道了单片机怎样取指、执指,即怎样运行程序了。那么怎样才能保证序了。那么怎样才能保证cpu有序的工作?这就必须提到单有序的工作?这就必须提到单片机的两个非常重要的外围电路:单片机

25、的时钟电路和复位片机的两个非常重要的外围电路:单片机的时钟电路和复位电路。电路。 pin19: 时钟时钟xtal1脚,片脚,片内振荡电路的输内振荡电路的输入端。入端。pin18: 时钟时钟xtal2脚,片脚,片内振荡电路的输内振荡电路的输出端。出端。【振荡周期振荡周期】:单片机外接石英晶体振荡器的周期。如外:单片机外接石英晶体振荡器的周期。如外接石英晶体的频率若为接石英晶体的频率若为12mhz,这其振荡周期就是,这其振荡周期就是1/12微微秒。秒。【状态周期状态周期】:单片机完成一个最基本的动作所需的时间:单片机完成一个最基本的动作所需的时间周期。如扫描一次定时器周期。如扫描一次定时器t0引脚

26、状态所需要的时间。一个引脚状态所需要的时间。一个状态周期状态周期2个振荡周期。个振荡周期。【机器周期机器周期】:单片机完成一次完整的具有一定功能的动:单片机完成一次完整的具有一定功能的动作所需的时间周期。如一次完整的读操作或写操作对应的作所需的时间周期。如一次完整的读操作或写操作对应的时间。一个机器周期时间。一个机器周期6个状态周期。个状态周期。【指令周期指令周期】: 执行完某条指令所需要的时间周期,一般执行完某条指令所需要的时间周期,一般需要需要14个机器周期,如个机器周期,如mul ab指令是四机器周期指令。指令是四机器周期指令。一个指令周期一个指令周期14个机器周期。个机器周期。ale2

27、s6s2s6s3s4s5s3s4s5s1s1s一个机器周期一个机器周期p1 p2p1 p22s1s6s1s单字节单周期指令例:inc a读操作码读操作码)读下一个操作码(丢弃读下一个操作码(丢弃3s4s5s单周期单字节指令时序单周期单字节指令时序 单片机工作时,除了需要时钟支持外,还必须有一个初单片机工作时,除了需要时钟支持外,还必须有一个初始状态,即单片机的复位状态。复位不改变始状态,即单片机的复位状态。复位不改变ram(包括工(包括工作寄存器作寄存器r0-r7)的状态,)的状态,89s51的初始态如下表:的初始态如下表: pin9: reset复位复位信号脚,当信号脚,当89s51通通电,

28、时钟电路开始电,时钟电路开始工作,在工作,在reset引引脚上出现脚上出现24个时钟个时钟周期以上的高电平,周期以上的高电平,系统即初始复位。系统即初始复位。特殊功能寄存器特殊功能寄存器初始态初始态特殊功能寄存器特殊功能寄存器初始态初始态acc00hb00hpsw00hsp07hdph00hth000hdpl00htl000hipxxx00000bth100hie0 xx00000btl100htmod00htcon00hsconxxxxxxxxbsbuf00hp0-p31111111bpcon0 xxxxxxxb 在前面的任务中,我们还看到一个现象,只要按一下在前面的任务中,我们还看到一个现象,只要按一下s1键,发光管的闪动就停止键,发光管的闪动就停止5秒,这就相当于打断了原来既秒,这就相当于打断了原来既定的工作,等到定的工作,等到5秒延时一到,又恢复原来的工作。这就象秒延时一到,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论