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

相关文章

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu