UART接口控制器

UART接口控制器主设备与从设备通过总线来进行数据通信,是一个数字系统不可或缺的一部分,本篇讲述一种常见的总线控制器UART串行数据接口,也称为串口。串口的标准一般有,RS-232、RS-422与RS-485标准,我们讲述的是RS-232接口信号。1、接口信号定义RS-232最常见的是9脚接口表1-1:RS-232接口定义在实际的应用中,我们只需要关注两个接口,数据接收(RXD)和数据发送(TXD),而…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

主设备与从设备通过总线来进行数据通信,是一个数字系统不可或缺的一部分,本篇讲述一种常见的总线控制器UART串行数据接口,也称为串口。
串口的标准一般有,RS-232、RS-422与RS-485标准,我们讲述的是RS-232接口信号。

1、接口信号定义

RS-232最常见的是9脚接口
表1-1:RS-232接口定义
在这里插入图片描述
在实际的应用中,我们只需要关注两个接口,数据接收(RXD)和数据发送(TXD),而其他的接口不需要理会。
串口的时序如图1-1所示:
在这里插入图片描述
结合时序图我们说明以下,串口收发数据的过程。在没有需要发送的数据时,接口的电平为高。在需发送的数据到达之前,先会有一个低电平的起始位。而后开始发送数据,而后会发送校验位,最后是停止位。结束后恢复高电平,等待下一个传送周期的起始位出现。
所以我们可以画出一个简单的收发结构图,如图1-2所示:
在这里插入图片描述

2、发送模块的设计

当数据准备好时,start信号为高电平,数据并行输入内部寄存器中,等时钟周期来了之后由低位到高位串行发送,代码如下:

module UART (clk,rst,start,data_in,TXD);
	parameter fst_bit=1'b0; //开始位为低电平
	parameter last_bit=1'b0; //传输结束信号
	input clk,rst;
	input start; //数据传输高电平有效
	input [7:0]data_in;
	output TXD;
	reg [9:0]shift;   //内部寄存器
	always@(posedge clk or negedge rst)
	begin
		if (!rst) shift<=10'b1111111111;
		else if (start) shift<={ 
   1'b1,data_in,1'b0};
		else shift<={ 
   1'b1,shift[9:1]};
	end
	assign TXD=shift[0];
endmodule

3、接收模块

接收模块的设计采用状态机设计,在无接收数据时,状态为初始状态init_s
开始接收时为接收状态rec_s,当状态在接收状态时内部计数器开始计数,当计数器达到8时输出数据状态复位。代码如下:

module UART_re2(clk,rst,data_out,XRD);
	parameter init_s=2'b00;//初始状态
	parameter rec_s=2'b01;//数据接收状态
	input clk,rst;
	input XRD;
	output [7:0]data_out;
	reg [7:0] data_out;
	reg [3:0] count;//数据接收计数器
	reg [7:0]data_reg;//数据寄存器
	reg [1:0] state,next_state;
	always@(posedge clk or negedge rst)
	begin
		if (!rst)
		begin
			state<=init_s;
			data_out<=8'b0;
			count <=4'b0;//初始化
		end
		else begin
			state<=next_state; //状态转换
			if (state==rec_s) begin
				data_reg<={ 
   XRD,data_reg[7:1]};//数据位移
				count<=count+1'b1; //计数器计数
			end
		end
	end
	
	always@(state or XRD or count )
	begin
		next_state<=state; //激励
		case(state)
			init_s:if (!XRD) next_state<=rec_s;
			rec_s: begin
				if (count==4'b1000) begin
					data_out<=data_reg;//数据输出
					state<=init_s;
					count<=4'b0000;
				end 
				else next_state<=state;
				end
			default:state<=init_s;
		endcase
	end	
endmodule 

仿真结果

测试代码如下:

module UART_t;
	reg clk,rst;
	reg [7:0]data_in;
	reg start;
	wire [7:0]data_out;
	wire serial;
	
	initial 
		begin
			clk=1'b0;
			rst=1'b1;
			start=1'b0;
			data_in=8'b11110000;
			#20 rst=1'b0;
			#40 rst=1'b1; start=1'b1;
			#100 start=1'b0;
		end
	always #50 clk=~clk;
	UART U1(.clk(clk),.rst(rst),.start(start),.data_in(data_in),.TXD(serial));
	UART_re2 U2(.clk(clk),.rst(rst),.data_out(data_out),.XRD(serial));
endmodule 
			

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/193912.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 二叉树层序遍历实现

    二叉树层序遍历实现二叉树的层序遍历下图是一个简单的二叉树例图实现思路:1.创建一个队列用于二叉树的层序遍历。2.将二叉树根节点插入队列中。3.通过while循环遍历二叉树,直至遍历完整个二叉树后则结束循环。4.每次循环开始时先进行出队操作,若当前出队元素为null则证明已经完成层序遍历结束循环循环,若不为null则打印该节点的值,并判断该节点是否存在左右子树,若存在则依次插入队列中。图解上述二叉树的层序遍历过程依次进行图上操作直至最终队列为空时则层序遍历结束。实现代码如下:classTreeNod

    2022年5月11日
    40
  • python aic准则_pythonAIC准则下线性回归实现及模型检验案例分析

    python aic准则_pythonAIC准则下线性回归实现及模型检验案例分析#coding=utf/8#time:2019/8/11#function:线性回归#author:Karenimportpandasaspdimportnumpyasnpimportstatsmodels.apiassmimportmatplotlib.pyplotaspltfromsklearnimportpreprocessingimportstatsmode…

    2022年5月24日
    38
  • 本地的html源文件,本地书源导入教程

    本地的html源文件,本地书源导入教程本地书源导入教程免贵姓操•2018年05月05日请注意,本文编写于1143天前,最后修改于96天前,其中某些信息可能已经过时。0×1.单个书源导入操作步骤:复制下面的书源代码,在[书源管理]点击“+”号,然后点击右上角的3个点,选择[粘贴书源],再点击[保存],然后书源前面勾选启用即可。{“bookSourceGroup”:””,”bookSourceName”…

    2022年6月15日
    53
  • HDU4907小技巧

    HDU4907小技巧

    2021年12月2日
    40
  • docker搭建kafka集群[通俗易懂]

    docker搭建kafka集群[通俗易懂]docker搭建kafka集群我在M1mbp上使用的以下镜像新建文件zk-kafka-docker-compose.ymlversion:”2″services:zookeeper:user:rootimage:docker.io/zookeeperports:-“12181:2181″environment:-ALLOW_ANONYMOUS_LOGIN=yesvolumes:-zoo

    2022年4月25日
    48
  • oracle11g安装步骤详细图文教程

    oracle11g安装步骤详细图文教程一、下载oracle11g下载地址:https://www.oracle.com/database/technologies/oracle-database-software-downloads.h

    2022年7月3日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号