【可编程串行接口8251A】:用处、内部结构、各引脚的解释、工作方式

本文主要是介绍【可编程串行接口8251A】:用处、内部结构、各引脚的解释、工作方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

8251A的作用

微机内部的数据传送方式为并行方式。
若外设采用串行方式,则微机与外设之间需加串行接口。
串行接口基本功能就是:输入数据时,进行串/并转换;输出数据时,进行并/串转换。
Intel8251A是一种可编程的通用同步/异步接收发送器


8251A的内部结构+各引脚的解释

在这里插入图片描述

各引脚的解释:

在这里插入图片描述
在这里插入图片描述
A1即代表C/#D

在这里插入图片描述


工作方式

8251A在工作前要先对其进行初始化,即:

对8251A写入方式控制字,以确定其工作方式;
写入操作命令字,以确定其动作过程。

(1)方式控制字

方式控制字用来决定8251A工作在同步还是异步方式,并确定各种工作方式的数据格式。

在这里插入图片描述

(2)命令字

在这里插入图片描述

(3)状态字

在这里插入图片描述

(4)8251A的方式字和命令字的使用

8251A的方式字、命令字和状态字之间的关系:
向8251A写入方式字和命令字时,需要按一定的顺序:复位→方式字→命令字。

(5)8251A初始化的约定

复位后,用奇地址写入的值送模式寄存器
若为同步模式,接着往奇地址端口输出的字节为同步字符
此后,除复位命令,往奇地址写入的值将送到控制寄存器,往偶地址端口写入的值送到数据输出寄存器
在这里插入图片描述


例子

【确定方式控制字】1:某异步通信中,其数据格式为: 1位起始位,1位停止位,7位数据位,奇校验,波特率系数为16

在这里插入图片描述

A应该是1011?


【确定方式控制字】2:在同步通信中, 设帧数据格式为:字符长度8位,同步且内同步,偶校验

在这里插入图片描述

A应该是1011?


【确定命令字】:某异步通信中,要求8251A内部复位,允许接收,允许发送,全部错误标志复位

在这里插入图片描述


例:若要检查8251A的发送器是否准备好,则可用下列程序段实现

在这里插入图片描述


例:若要检查接收是否发生错误,则可用下列程序段实现

在这里插入图片描述


例 :8086CPU利用8251A作串行接口实现与CRT终端间的串行传送

8251A作为8086CPU与CRT终端间的接口如图所示。
ALE信号有效时,将CPU送来的地址锁存。
地址线A0接C/D端用于选择8251A的数据口或控制口。
波特率发生器输出频率为76.8KHz,向8251A提供规定的收/发时钟(RXC和TXC)
由于8251A输入输出都是TTL电平,而CRT是RS-232电平,所以要通过1488及1489进行电平转换
在这里插入图片描述

在这里插入图片描述


实现代码:

在这里插入图片描述
在这里插入图片描述

这篇关于【可编程串行接口8251A】:用处、内部结构、各引脚的解释、工作方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/424578

相关文章

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

详解Java中三种状态机实现方式来优雅消灭 if-else 嵌套

《详解Java中三种状态机实现方式来优雅消灭if-else嵌套》这篇文章主要为大家详细介绍了Java中三种状态机实现方式从而优雅消灭if-else嵌套,文中的示例代码讲解详细,感兴趣的小伙伴可以跟... 目录1. 前言2. 复现传统if-else实现的业务场景问题3. 用状态机模式改造3.1 定义状态接口3