目录

51单片机的串口并没有配置FIFO硬件,故收发数据时只能一字节一字节地收发。最近接触了FIFO(先进先出)的硬件缓存,这样串口的配置就更多了一个维度。

以CH58x系列单片机为例,在CH583的手册中(笔者手头的是CH582m的板子,与CH583用法一致,只有部分硬件不同),有关于串口和FIFO配置的说明。具体应用可以查看笔者关于串口透传的一篇随笔。

9.3.1 波特率计算
1)计算串口内部基准时钟 Fuart,设置 R8_UARTx_DIV 寄存器,最大值 127,通常写入 1。
2)计算波特率,设置 R16_UARTx_DL 寄存器。 波特率公式 =Fsys * 2 / R8_UARTx_DIV / 16 / R16_UARTx_DL。    //通过GetSysClock()这个函数获得主频

9.3.2 串口发送
串口发送的“THR 寄存器空”中断 UART_II_THR_EMPTY 是指当前发送 FIFO 空。
当读取 IIR 寄存器后,该中断被清除,或者当向 THR 写入下一个数据后,该中断也能被清除。     //IIR:中断识别寄存器 THR:发送保存寄存器
如果仅仅是向 THR写入 一个字节,那么由于该字节很快被转移到发送移位寄存器 TSR 中开始发送,所以很快会再次产生发送 THR 寄存器空中断的请求,此时可以写入下一个准备发送的数据。
当 TSR 寄存器中的数据被全部移出 后,串口发送才真正完成,此时 LSR 寄存器的 RB_LSR_TX_ALL_EMP 位变为 1 有效。      //TSR:发送移位寄存器
在中断触发方式下,当收到串口发送保持寄存器 THR 空的中断后,如果已使能 FIFO,那么可以向 THR 寄存器及 FIFO 一次写入最多 8 字节,然后控制器会按顺序自动发送;
如果禁止 FIFO,那么一 次只能写入一个字节;        //使能FIFO后,向THR写入的数据先存放于FIFO中,自动以此发送,一次可以写入多个字节
如果没有数据需要发送,那么可以直接退出(之前读取 IIR 时已经自动清除中断)。
在查询方式下,可以根据 LSR 寄存器的 RB_LSR_TX_FIFO_EMP 位判断发送 FIFO 是否为空,当此位 为 1 则可以向 THR 寄存器及 FIFO 写入数据,如果使能 FIFO,那么一次可以写入最多 8 个字节。
也可读取 R8_UARTx_TFC 寄存器判断当前 FIFO 中待发送的剩余数据个数,如果不等于8,则可继 续向 FIFO 中写入待发送数据,这种方式可以节约填充时间。

9.3.3 串口接收      //假设设置FIFO设置为7个字节的缓存
串口接收数据可用中断 UART_II_RECV_RDY 是指接收 FIFO 中的已有数据字节数已经到或超过由FCR 寄存器的 RB_FCR_FIFO_TRIG 设置选择的 FIFO 触发点。        //FIFO中的数据达到了设定的7个字节,会触发_RECV_RDY ,若取出这7个字节,FIFO中会空
当从 RBR 读取数据使 FIFO 字数低于 FIFO 触发点时,该中断被清除。      //RBR:接收缓存寄存器
串口接收数据超时中断 UART_II_RECV_TOUT 是指接收 FIFO 中至少有一个字节的数据,
并且从上一次串口接收到数据和从上一次被系统取走数据开始,已经等待了相当于接收 4 个数据的时间。      //这里的“4”个数据的时间与FIFO触发设置的“4”字节无关,注意:FIFO中要留有一个数据进行比较,该标志才能有效
当再次接收到一个新的数据后,该中断被清除,或者当单片读取一次 RBR 寄存器后,该中断也能被清除。      //接收到新数据或者读取RBR后,超时标志位清除
当接收FIFO全空时, LSR寄存器的RB_LSR_DATA_RDY位为0,当接收FIFO中有数据时, RB_LSR_DATA_RDY 位为 1 有效。      //LSR:线路状态寄存器 _RDY标志位为1时有效,表示FIFO中有数据
在中断触发方式下,当收到串口接收数据超时的中断后,可以读取 R8_UARTx_RFC 寄存器查询当前 FIFO 中剩余数据计数,直接读取全部数据,     //超时中断后,判断为没有数据了,一次全部读取FIFO中的数据或者不断查询LSR的标志位不断读取
或者不断查询 LSR 寄存器的 RB_LSR_DATA_RDY,如果 此位有效则读数据,直到此位无效。
当收到串口接收数据可用的中断后,可以先从 RBR 寄存器一次性读取 RB_FCR_FIFO_TRIG 设定字节个数的数据,     //收到可用中断后,可以从_TRIG寄存器读取设定字节的个数,亦可以结合_RDY和_RFC读取所有数
或者也可以根据 RB_LSR_DATA_RDY 位和 R8_UARTx_RFC 寄存器读取当前 FIFO 中所有数据。
在查询方式下,可以根据 LSR 寄存器的 RB_LSR_DATA_RDY 位判断接收 FIFO 是否为空,或读取 R8_UARTx_RFC 寄存器获取当前 FIFO 中数据计数,来获取串口接收的所有数据。

//以下为串口1初始化函数

void u1_init()
{
  uint32_t x;   /* 配置串口1:先配置IO口模式,再配置串口 */
  GPIOA_SetBits(GPIO_Pin_9); //先将PA9置位为高
  GPIOA_ModeCfg(GPIO_Pin_8, GPIO_ModeIN_PU); // RXD-配置上拉输入
  GPIOA_ModeCfg(GPIO_Pin_9, GPIO_ModeOut_PP_5mA); // TXD-配置推挽输出,注意要先让IO口输出高电平   x = 10 * GetSysClock() / 8 / 115200; //串口1定为115200波特率
  x = (x + 5) / 10; //整型运算中四舍五入
  R16_UART1_DL = (uint16_t)x; //给波特率寄存器赋值   R8_UART1_FCR = (2 << 6) | RB_FCR_TX_FIFO_CLR | RB_FCR_RX_FIFO_CLR | RB_FCR_FIFO_EN;
      //FIFO控制寄存器配置,10左移6位:触发点4字节;收发FIFO数据都清空;FIFO使能
  R8_UART1_LCR = RB_LCR_WORD_SZ; //线路控制寄存器配置,选择串口数据长度
  R8_UART1_IER = RB_IER_TXD_EN | RB_IER_RECV_RDY | RB_IER_LINE_STAT; //中断使能控制器配置,TX引脚输出使能;接收中断使能;接收线路状态中断使能
  R8_UART1_MCR |= RB_MCR_INT_OE; //调制解调器控制寄存器配置,允许串口的中断请求输出
  R8_UART1_DIV = 1; //用于波特率配置,参考手册中的公式   PFIC_EnableIRQ(UART1_IRQn); //中断注册 } //下为中断服务函数 __INTERRUPT
__HIGH_CODE
void UART1_IRQHandler(void)
{
  volatile uint8_t i;   switch(UART1_GetITFlag())
  {
    //略掉一个case分支     case UART_II_RECV_RDY: // 数据达到设置触发点
      for(i = 0; i != trigB-1; i++)//若要能够走到_TOUT的case分支,这里需要留一个字节数据,故这里为trigB-1(FIFO触发字节-1)
      {
        RxBuff[i] = UART1_RecvByte();
        UART1_SendByte(RxBuff[i]);
      }
      break;     case UART_II_RECV_TOUT: // 接收超时,暂时一帧数据接收完成
      i = UART1_RecvString(RxBuff);
      UART1_SendString(RxBuff, i);
      break;     //略掉几个case分支     default:
      break;
  }
}

带有FIFO硬件缓存的串口的更多相关文章

  1. ogre3D学习基础4 -- 网格工具与硬件缓存

    三.网格工具(Mesh) 1.导出器(Exporters)--- 用于从模型生成器中得到数据并且导入到OGRE中去. 导出器是指通过3D模型工具的插件写成网格数据和骨骼动画的文件格式可以在OGRE中被 ...

  2. 基于Verilog的带FIFO写入缓冲的串口发送接口封装

    一.模块框图及基本思路 tx_module:串口发送的核心模块,详细介绍请参照前面的“基于Verilog的串口发送实验” fifo2tx_module:当fifo不为空时,读取fifo中的数据并使能发 ...

  3. 基于Verilog的带FIFO输出缓冲的串口接收接口封装

    一.模块框图及基本思路 rx_module:串口接收的核心模块,详细介绍请见“基于Verilog的串口接收实验” rx2fifo_module:rx_module与rx_fifo之间的控制模块,其功能 ...

  4. Go -- FIFO类(缓存淘汰算法)(转)

    1 FIFO 1.1. 原理 按照“先进先出(First In,First Out)”的原理淘汰数据. 1.2. 实现 FIFO队列,具体实现如下: 1. 新访问的数据插入FIFO队列尾部,数据在FI ...

  5. 带发送FIFO缓冲的RX232串口发送以及把众多文件变成“黑匣子”用于其它工程的调用

    如果需要发送端不断地接收新的数据,而发送端的数据传输率低就需要一个缓冲器FIFO来缓冲数据.当你为别人做项目只是想实现功能而不想让自己的代码让别人看到,想保护自己的算法时,你可以用以下的方法.我使用的 ...

  6. 硬件设计之串口收发器---ISO1050 (现行) 隔离式 5V CAN 收发器

    http://www.ti.com.cn/product/cn/iso1050 http://www.deyisupport.com/question_answer/dsp_arm/sitara_ar ...

  7. 【STM32H7教程】第30章 STM32H7的USART应用之八个串口FIFO实现

    完整教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=86980 第30章       STM32H7的USART应用之八个串口 ...

  8. 读取缓存模拟----FIFO

    本例是模拟缓存的存储和读取. 存储:使用一个Map来存放,key是文件名,值为缓存对象 读取:返回相应的key对应的缓存.(如果缓存被修改,就重新加载缓存,再从缓存Map中读取相应缓存) 测试类:每2 ...

  9. LPC2478中断控制器以及串口详解

    LPC2478的中断系统 LPC2478使用的是ARM PrimeCell向量中断控制器,一共支持32个中断向量,处于AHB空间便于系统快速访问,在中断向量的硬件优先级上还有一层可以用户自己设计的软件 ...

  10. W7500P硬件TCP/IP+硬件物理层PHY+Cortex-M0处理器(48MHZ)

    W7500P 硬件TCP/IP+硬件物理层PHY+Cortex-M0处理器(48MHZ) 硬件TCP/IP+硬件物理层PHY+Cortex-M0处理器(48MHZ) 如果您发现商品信息不准确,欢迎纠错 ...

随机推荐

  1. Goby安装与使用

    前言 Goby是一款基于网络空间测绘技术的新一代网络安全工具,它通过给目标网络建立完整的资产知识库,进行网络安全事件应急与漏洞应急. Goby可提供最全面的资产识别,目前预置了超过10万种规则识别引擎 ...

  2. gRPC介绍(以Java为例)

    1.简介 1.1 gRPC的起源 RPC是Remote Procedure Call的简称,中文叫远程过程调用.用于解决分布式系统中服务之间的调用问题.通俗地讲,就是开发者能够像调用本地方法一样调用远 ...

  3. odoo中的字段创建后,不可以编辑

  4. 读Java8函数式编程笔记06_Lambda表达式编写并发程序

    1. 阻塞式I/O 1.1. 一种通用且易于理解的方式,因为和程序用户的交互通常符合这样一种顺序执行的方式 1.2. 将系统扩展至支持大量用户时,需要和服务器建立大量TCP连接,因此扩展性不是很好 2 ...

  5. vulnhub靶场之DIGITALWORLD.LOCAL: VENGEANCE

    准备: 攻击机:虚拟机kali.本机win10. 靶机:digitalworld.local: VENGEANCE,下载地址:https://download.vulnhub.com/digitalw ...

  6. Linux几种网络模式介绍

    简单介绍Linux几种网络模式 ​ 虚拟化层次: ​ 打开vmware虚拟机,我们可以在选项栏的"编辑"下的"虚拟网络编辑器"中看到VMnet0(桥接模式).V ...

  7. 基于View接口

    目录 基于View接口 1.写模型表以及数据库迁移 3.使用CBV写查询所有的视图接口 4.配路由 基于View接口 ​ Django原生即继承View来实现写接口,的确过程很繁杂,很多东西都是手动写 ...

  8. Python中的函数定义中的斜杠/和星号*

    Python中的函数定义中的斜杠/和星号* 示例 看一段代码  def say_hello(name,age=18):     print(f'你好!我是{name},今年我{age}啦.') say ...

  9. windows环境下安装es和kibana

    1 ES安装 1.1 下载地址 https://www.elastic.co/cn/downloads/elasticsearch 1.2 版本选择 注意选择合适的版本,ES依赖于JDK,需要有对应的 ...

  10. P13_协同工作_小程序权限管理的概念以及成员管理的两个方面

    协同工作和发布 - 协同工作 了解权限管理需求 在中大型的公司里,人员的分工非常仔细:同一个小程序项目,一般会有不同岗位.不同角色的员工同时参与设计与开发. 此时出于管理需要,我们迫切需要对不同岗位. ...