8253的结构及其各引脚功能

2023-10-29 14:59
文章标签 功能 结构 引脚 8253

本文主要是介绍8253的结构及其各引脚功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1. 数据总线缓冲器
    • (1) 结构
    • (2) 引脚
  • 2. 读写控制逻辑
    • (1) 结构
    • (2) 引脚
  • 3. 计数器
    • (1) 结构
    • (2) 引脚
  • 4. 控制字寄存器
    • (1) 结构
    • (2) 引脚

在这里插入图片描述

在这里插入图片描述

1. 数据总线缓冲器

外设与CPU总线交换数据的通道。

(1) 结构

  • 一个8位双向三态缓冲器

(2) 引脚

  • D 7 ∼ D 0 D_7 \sim D_0 D7D0:CPU向8253写入数据的通道。直接与CPU的数据总线相连。

2. 读写控制逻辑

CPU通过总线控制8253的功能的部件

(1) 结构

(2) 引脚

  • C S ‾ \overline{CS} CS:片选信号。由地址总线经I/O端口译码电路产生。

  • R D ‾ \overline{RD} RD:有效时,CPU读取所选定的计数器通道中的内容。

  • W R ‾ \overline{WR} WR:有效时,CPU正在将计数初值写入所选中的计数通道中或者将控制字写入控制字的寄存器种。

  • A 1 A 0 A_1A_0 A1A0:地址总线的后两位。

A 1 A 0 A_1A_0 A1A0选中
00通道0
01通道1
10通道2
11控制字寄存器端口

引脚直接与CPU相连

3. 计数器

8253真正发挥功能的部件

(1) 结构

每个计时器都含由

  • 一个8位控制字寄存器。接收来自控制字寄存器的数据,规定该计时器的工作方式。没有地址
  • 一个16位计数初值寄存器。接收来自数据总线的数据,作为计数的初始值。有地址。
  • 一个计数器执行部件
  • 一个输出锁存器

端口地址就是三个计数初值寄存器的地址。

(2) 引脚

C L K 0 ∼ C L K 2 CLK_0 \sim CLK_2 CLK0CLK2:时钟脉冲输入端

O U T 0 ∼ O U T 2 OUT_0 \sim OUT_2 OUT0OUT2:时钟脉冲输出端

G A T E 0 ∼ G A T E 2 GATE_0 \sim GATE_2 GATE0GATE2:门控脉冲输入端

在这里插入图片描述

4. 控制字寄存器

决定8253工作方式

(1) 结构

  • 一个8位的寄存器。存放来自数据总线的控制字,然后根据 D 7 D 6 D_7D_6 D7D6,把该控制字送到相应计数器的控制字寄存器。

(2) 引脚

在这里插入图片描述

通常采用的是二进制计数
方式2和3的未知位统统用0


A 1 A 0 A_1A_0 A1A0 D 7 D 6 D_7D_6 D7D6的区别:

  • A 1 A 0 A_1A_0 A1A0在CPU通过地址总线选择端口时有用。
  • D 7 D 6 D_7D_6 D7D6在控制字寄存器决定将已有的控制字给谁时有用。

这篇关于8253的结构及其各引脚功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

基于Java和FFmpeg实现视频压缩和剪辑功能

《基于Java和FFmpeg实现视频压缩和剪辑功能》在视频处理开发中,压缩和剪辑是常见的需求,本文将介绍如何使用Java结合FFmpeg实现视频压缩和剪辑功能,同时去除数据库操作,仅专注于视频处理,需... 目录引言1. 环境准备1.1 项目依赖1.2 安装 FFmpeg2. 视频压缩功能实现2.1 主要功

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

Java实现TXT文件导入功能的详细步骤

《Java实现TXT文件导入功能的详细步骤》在实际开发中,很多应用场景需要将用户上传的TXT文件进行解析,并将文件中的数据导入到数据库或其他存储系统中,本文将演示如何用Java实现一个基本的TXT文件... 目录前言1. 项目需求分析2. 示例文件格式3. 实现步骤3.1. 准备数据库(假设使用 mysql

Springboot项目登录校验功能实现

《Springboot项目登录校验功能实现》本文介绍了Web登录校验的重要性,对比了Cookie、Session和JWT三种会话技术,分析其优缺点,并讲解了过滤器与拦截器的统一拦截方案,推荐使用JWT... 目录引言一、登录校验的基本概念二、HTTP协议的无状态性三、会话跟android踪技术1. Cook