网站大量收购闲置独家精品文档,联系QQ:2885784924

单片机内部主要功能模块工作原理及应用.ppt

单片机内部主要功能模块工作原理及应用.ppt

  1. 1、本文档共216页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
大连理工大学 电信学院 陈育斌 大连理工大学电信学院 陈育斌 第三章:单片机内部主要功能模块 工作原理及应用 本章主要内容: MCS-51单片机并行端口的结构特点; 定时/计数器、串行口的工作原理; “查询”及“中断”两种编程方法及对定时器、串行口进行编程。 本章目录 MCS-51单片机的8位并行输入输出端口 MCS-51单片机的定时/计数器 MCS-51单片机的串行接口 MCS-51的中断系统 3.2 8位并行输入输出端口 并行I/O端口是实现单片机与外部进行并行数据交换的通道。 MCS-51单片机的并行端口具备三种工作方式 通用I/O方式:直接与外部设备连接,实现数据的并行交换。常用于“最小系统”模式的设计; 总线方式:当系统要与外部ROM、RAM或ADC等器件进行连接时,采用类似于微机系统的三总线结构进行设计,部分端口承担总线的功能。此时系统称为“扩展系统”; 第二功能方式:由于引脚的限制,内部信号无法正常输入输出。因此借用I/O端口引脚作为内部信号通道也是一种不得已的方法。 当端口作为总线或第二功能时,就不能再做I/O。 MCS-51单片机的四个并行端口P0、P1、P2和P3都是具有输出锁存功能的“准双向”端口,这些锁存器的位置都在SFR中,其地址分别为:80H、90H、A0H 、B0H。 出于系统功能的考虑,在硬件设计上对端口功能都有不同的要求,所以它们又具有不同的结构和特点。 3.1.1 P0口 【特点】具有两种工作方式 “通用数据I/O双向端口”; “地址、数据复用总线” 。 在作为通用数据I/O端口时,具有较强的输出驱动能力 (8个TTL负载)。因输出是“开漏”结构,所以与MOS负载连接时,需要外接一个上拉电阻。 作为“地址、数据复用总线”使用时,P0口首先输出存储器的低八位地址信号,然后变为数据总线进行数据的输入输出,所以称“分时复用总线”(注意:此时P0口不能再作为通用I/O口)。 P0口的位结构图 硬件组成: 1,一个输出锁存器(D型触发器); 2,二个三态门(控制读引脚或读锁存器); 3,与门和MUX等元件组成的输出控制电路; 4,一对场效应晶体管FET构成的输出电路. P0口的工作原理 普通I/O模式下的输出与输入原理; 扩展(总线)方式下的工作原理 1. P0口的I/O操作(通用I/O端口) 在P0口作为通用I/O端口时,控制电路中的“控制”端为“0”电平: 此时多路开关MUX接入下方的锁存器的/Q端。 因与门的一个输入端为“0”,所以它使上端的FET截止。这就是P0口在做I/O口时输出为“漏极开路” 结构的原因。 (一)输出操作: MOV P0,A 数据经内总线送到锁存器的“D”端,经“/Q”端送场效管应输出极。 ①总线送“0”时:锁存器的/Q=1,使下端的FET导通(上面的FET截止),端口呈现“0”电平; ②总线送“1”时:锁存器/Q=“0”,使下端的FET截止,输出极的两个FET全部截止。在这种情况下,必须通过上拉电阻的作用使端口为高电平。 (二)输入操作 MOV A,P0 输入操作实际上有两种(参见结构图): ①读引脚:用于真正的外部数据输入的通道; ②读锁存器:在端口作输出时常使用的操作。 a.读引脚:当外部信号通过端口引脚输入时,读引脚上的电平实现信号的输入。如指令: MOV A,P0 ; A←P0 此时,单片机控制“读引脚”的三态门,使引脚处的外部电平经三态门送入内部总线。 读引脚操作前要事先向该端口写“1” 在端口电路中,可以发现一个问题: 端口在输入(读引脚)时,原来锁存器的状态可能要影响引脚电平的输入。如: 原来锁存器的状态为“0”态, 电路将不能正确读入.要解决的方法就是让下端的FET截止,即事先向端口写一个“1”。 请注意下面的一段程序: MOV P0,#0FFH ;0FFH送P0( “写1”) MOV A , P0 ;从P0口引脚输入数据到A 你能正确的分析出指令的操作吗? 上述指令执行后 P0=? b,读锁存器:端口作输出时的一种操作 在这种情况下, 读入的数据不是来自引脚,而是端口内部的锁存器的内容。 为什么端口作输出时还要读入操作? 当端口输出时(MOV P0,A) ,往往要再将前面输入的状态取回来,进行再处理然后重新输出。如: ORL P0,A 将P0口前次输出的数据与累加器A的内容相“或”后在送回P0口(输出)。此时P0口的数据是从锁存器中读回的,而不是从引脚输入。 上述的过程也称之谓“读——修改——写”操作。 凡是这种“

您可能关注的文档

文档评论(0)

wuyoujun92 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档