8251A的模式字、控制字和状态字

        8251A内部有一个8位的模式寄存器,用来设置工作模式;一个8位的控制寄存器,控制8251A的工作;一个8位的状态寄存器,反映8251A的工作状态。

                                                     ​​​​​​​                ​​​​​​​                      图1  8251A引脚图

 

                                                                   ​​​​​​​        ​​​​​​​              图2  8251A内部结构框图 

一、8251A的模式字

        对8251A进行初始化时,模式字(异步模式)是按照模式寄存器的格式来设置的,模式寄存器的格式如图3所示。图中说明了8251A工作在同步模式和异步模式两种情况下,模式寄存器各数位的含义。当模式寄存器最低两位为0时,8251A便工作在同步模式,此时,最高位决定了同步字符的数目;如果模式寄存器的两个最低位不全为0,则8251A就进入异步模式。

        在同步模式中,接收和发送的波特率(即移位寄存器的移位率)分别和TxC引脚、RxC引脚上的输入时钟的频率相等。但是在异步模式中,要用模式寄存器中的两个最低位来确定波特率因子,此时,模式寄存器的第2、3位用来指出每个字符所对应的数据位的数目,第4位用来指出是否用校验位,第5位则用来指出校验类型是奇校验还是偶校验。在异步模式中,用两个最高有效位指出停止位的数目;但在同步模式中,第6位用来决定引脚SYNDET是作为输入还是输出,第7位则用来指出同步字符的数目。

 

                ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​                                图3   8251A模式字格式(异步模式)

二、8251A控制字

        对8251A进行初始化时,控制字是按照控制寄存器的格式写入的。控制寄存器的格式如图4所示。

        控制寄存器的第0位为输出允许信号,只有将这一位设置为1,才能使数据从8251A接口往外设传输。第2位为输入允许信号,在CPU从8251A接口接收数据前,先要使此位为1。第1位DTR是和引脚DTR有直接联系的,引脚DTR通常和调制解调器的CD引脚相连,当CPU将控制寄存器的DTR位设置为1时,便使DTR引脚变为低电平,从而通知调制解调器,CPU已经准备就绪。第3位为1使引脚TxD变为低电平,于是,输出一个空白字符。第4位置1将清除状态寄存器中所有的出错指示位。第5位用来设置发送请求,如果将RTS引脚通过外部电路和MODEM的CA引脚相连,那么,第5位置1会使RTS引脚输出低电平,而使CA引脚得到一个高电平,从而使MODEM获得一个发送请求。第6位使8251A复位从而重新进入初始化流程。第7位只用在内同步模式,当为1时,8251A便会对同步字符进行检索。

                 ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​                ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​图4   8251A控制字格式

三、8251A状态字

        当需要检测8251A的工作状态时,经常要用到状态字。状态字是存放在状态寄存器中的。图5为8251A状态寄存器的格式。

        状态寄存器的第1、2、6位分别与8251A引脚RxRDY、TxE、SYNDET上的信号有关,第0位TxRDY为1用来指出当前数据输出缓冲器为空,这里要注意的一点是状态位TxRDY和引脚TxRDY上的信号不同,状态位TxRDY不受输入信号CTS和控制位TxEN的影响。而引脚TxRDY必须在数据输出缓冲器空、CTS引脚为低电平且TxEN位为1时,才为1,即TxRDY为1的条件为:数据缓冲区空且CTS为低电平且TxEN位为1。

        状态位RxRDY为1指出接口中已经接收到一个字符。通信程序中可以对TxRDY或RxRDY进行查询,来实现对8251A数据发送过程和接收过程的控制。当CPU往8251A数据端口写入一个字符以后,状态位TxRDY会自动清0,当CPU从8251A数据端口读取一个字符时,状态位RxRDY会自动清0。状态寄存器的第2位TxE为1时,指出当前输出移位寄存器空,正等待输出缓冲寄存器送一个字符过来。状态寄存器的第3、4、5位分别作为奇/偶校验错误指示、覆盖错(又叫做超越错)指示和帧格式错指示,当数据传输过程中产生其中某种类型的错误时,相应的出错指示位被置为1。

                                                                                            图5   8251A状态字

  • 6
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1、设计要求基于小脚丫FPGA开发板和四位数码管实现数时钟的设计,要求: 1)采用FPGA+按键+四位数码管实现数时钟功能; 2)时间显示格式:XX:XX:XX (时:分:秒),采用24小时制; 3)四位数码管显示时分秒,可以通过按键控制选择显示时分界面还是分秒界面。 4)通过按键设定初始时间。 5)设置在整点12点时,通过蜂鸣器响示意整点报时。蜂鸣器响维持大概5S; 2、硬件连接FPGA的系统时钟来自于小脚丫FPGA开发板配置的24MHz时钟晶振,连接FPGA的C1引脚。 本设计用到五个个按键K1~K5,硬件设计如图1所示,五个按键分别连接到FPGA的B8、C8、A10、A11和A12引脚。 图1. 按键硬件设计 本设计用到一个蜂鸣器来示意整点报时,硬件设计如图1所示,蜂鸣器连接到FPGA的B2引脚。 图2. 蜂鸣器硬件设计 本设计用到四位数码管来显示时间,四位数码管用两个74HC595驱动,硬件设计如图1所示,74HC595的串行时钟SCK、并行时钟RCK和串行数据DIN分别连接到FPGA的N2、M1和K1引脚上。 图3. 数码管驱动74HC595硬件设计 3、工作原理1)使用计数器做分频处理,得到周期为1秒的脉冲信号; 2)使用三个8bit的BCD码表示时钟、分钟、秒钟的值,其中高4bit表示值的十位,低4bit表示值的个位; 3)正常运行时,每来一个1S脉冲信号个位加1,个位满10清零同时十位加1,当秒钟满60清零同时分钟个位加1,依次进行...直到23:59:59的下一刻全部清零; 4)按键K5,模式调节,设计共分4中模式(分秒显示、分秒调节、时分显示、时分调节),按动K5依次切换模式; 5)按键K2,时间调节,当数时钟在时针调节、分针调节或秒针调节模式时,按动K2调节对应时间位; 6)在调时分和调分秒两个状态,可以通过K4和K2键分别左移右移要调整的位,要调整的位会通过对应位的闪烁来示意。通过K4和 K2左右移动选择好要调整的位以后,就可以通过K1和K3来增大或调小对应的位; 4、代码设计为了实现所需要的功能,我们将整个设计划分不同的模块,如图4所示。 图4. 数时钟程序设计框架 4.1五位按键消抖模块 图5. 五位按键消抖模块 Ø输入:五位的按键电平信息输入 Ø输出:五位消抖后的脉冲输出 Ø功能:将按键按下一次的电平信号,经过消抖后变成一个维持一个时钟周期的脉冲信号; Ø原理: 图6. 按键抖动特性 FPGA过20ms检测按键是否按下,存储检测到的值,并且按位取反与前一个20ms检测的值相与,得到一个值,如果为1,则判断按键按下,否则则无按下。 图7. FPGA按键的理解示意图 4.2电子表显示控制模块。 图8. 电子表显示控制模块 Ø输入:五位的按键脉冲 Ø输出:十六位的BCD码输出,每四个代表一个十进制数; Ø原理:四位的位闪烁控制信号。某一位为一代表这位对应的数码管的一位进行闪烁显示。(在调整状态下,会让当前调整的哪一位进行闪烁。正常显示状态下seg_flash_data全为零); Ø功能:主要就是一个状态机,通过检查输入的按键信息,进行显示状态切换,时间调整。四个状态分别为:显示分秒,调分秒,时分显示,调时分;当K5按键按下(key_pulse[4])时依次跳转,如图9所示。 图 9. 数时钟状态控制设计 4.3数码管译码模块 图10. 数码管译码模块 Ø输入:四位的BCD码数据 Ø输出:八位的七段数码数据 Ø功能:一个case语句,将输入的四位BCD码转化为七段数码数据; Ø原理:数码管分为共阳极数码管和共阴极数码管。共阳数码管是指将所有发光二极管的阳极接到一起形成公共阳极(COM)的数码管,共阳极(COM)需接+5V才能使其工作。共阴数码管是指将所有发光二极管的阴极接到一起形成公共阴极(COM)的数码,共阴极(COM)需接GND才能使其工作。小脚丫拓展板上的数码管如下图所示: 图11. 数码管内部电路 共阴极数码管: 位选为低电平(即0)选中数码管;各段选为高电平(即接+5V时)选中各数码段;由0到f的编码为: 4.4四位数码管显示控制模块。 图12. 数码管显示控制模块 Ø输入:四个八位的七段数码管数据和位闪烁控制信号seg_flash_data. Ø输出:需要串行输出给74HC595的十六位数据; Ø功能:模块就是循环的将四位七段数码数据,组合一个十六位的输出数据; 4.5 74HC595驱动功能模块 图13. 74HC595驱动功能模块 Ø输入:十六位的位选段选数据。 1)duan_wei_data[13:0]分别对应: 2)[ X,X,H+,H-,DIG4,DIG3,DIG2,DIG1,DP,G,F,E,D,C,B,A] ; Ø输出:SPI接口输出,串行输出十六位位选段选信号; Ø
### 回答1: 8255A是一种I/O接口芯片,其中的C口是一个8位输出端口,可以通过控制控制C口的输出状态。要实现循环点亮8只发光二极管,可以按照以下步骤操作: 1. 将8255A的C口配置为输出模式。 2. 定义一个8位的计数器,用于循环控制发光二极管的点亮。 3. 编写程序,通过置位/复位控制控制C口的输出状态,使得每次只有一个发光二极管点亮,并且按照一定的顺序循环点亮。 4. 在每次循环中更新计数器的值,以控制下一次点亮的发光二极管。 具体实现方式可以参考8255A的数据手册或者相关的编程教程。需要注意的是,8255A的C口输出电流较小,需要使用适当的驱动电路来驱动发光二极管,否则可能无法正常工作。 ### 回答2: 8255A是一款通用的I/O接口芯片,其中的C口可以连接8只发光二极管进行控制。通过设置置位和复位控制来循环点亮发光二极管。 置位/复位控制是一个8位的二进制数,每位代表一个发光二极管的控制信号。当某一位的控制信号为1时,对应的发光二极管处于点亮状态;当控制信号为0时,对应的发光二极管处于熄灭状态。 通过循环设置置位/复位控制的不同组合,可以实现8只发光二极管的循环点亮。例如,可以先将第一只发光二极管点亮,其他发光二极管熄灭;然后将第二只发光二极管点亮,其他发光二极管熄灭;以此类推,依次循环控制每一只发光二极管的状态。 具体实现的步骤如下: 1. 将8255A芯片与发光二极管连接,将C口的8个引脚分别连接到8只发光二极管的阳极(或阴极)。 2. 编程设置置位/复位控制,将控制信号按照循环点亮的顺序进行设置。 3. 将置位/复位控制送入8255A的控制寄存器,使其生效。 4. 循环执行上述的步骤2和步骤3,以实现对8只发光二极管的循环点亮控制。 通过8255A的C口连接8只发光二极管,并通过置位/复位控制的设置来循环点亮发光二极管,可以实现各种有趣的灯光效果,例如跑马灯效果、呼吸灯效果等。同时,也可以根据实际需要来设计不同的灯光显示模式。 ### 回答3: 8255A是一种常用的并行接口芯片,具有3个口线和一个控制寄存器。其中,C口是其中的一个口线,可以用来控制8只发光二极管的点亮和熄灭。 在连接发光二极管之前,我们需要首先配置8255A的C口为输出模式。这可以通过设置控制寄存器来实现。控制寄存器是一个8位的寄存器,其中的5个位用来设置C口的工作模式。将这些位设置为相应的值,就可以将C口配置为输出模式。 一旦C口配置为输出模式后,我们可以使用置位/复位控制来循环地点亮发光二极管。置位和复位控制分别是控制寄存器的高节和低节,每个节都是8位。每个位代表一个发光二极管的状态,当位的状态为1时,对应的发光二极管点亮,状态为0时则熄灭。 通过不断调整置位/复位控制的值,我们可以实现发光二极管的循环点亮。比如,可以先将第一个发光二极管的位设置为1,其余的位设置为0,这样第一个发光二极管就会点亮。然后,将第一个发光二极管的位设置为0,第二个发光二极管的位设置为1,这样第二个发光二极管就会点亮,以此类推。 通过不断循环改变置位/复位控制的值,我们就可以实现8只发光二极管的循环点亮。这种方式可以用于灯光效果的展示、数据的显示等应用中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

New_Teen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值