VHDL 编写验证实现基本串口通信功能.docVIP

  • 4
  • 0
  • 约1.43万字
  • 约 9页
  • 2017-03-03 发布于江苏
  • 举报
可以用CPLD模拟一个RS232串口,利用这个串口与单片机通信 下面是用VHDL写的一个串口程序,你可以根据你的通信协议对这个程序略作修改即可使用 -- 本模块的功能是验证实现基本的串口通信的功能。 -- -- 程序实现了一个收发一帧10个bit(即无奇偶校验位)的串口控 --制器,10个bit是1位起始位,8个数据位,1个结束 --位。串口的波特律由程序中定义的div_par参数决定,更改该参数可以实 --现相应的波特率。程序当前设定的div_par 的值是0x104,对应的波特率是 --9600。用一个8倍波特率的时钟将发送或接受每一位bit的周期时间 --划分为8个时隙以使通信同步. :串口处于全双工工作状态, --字符串(串口调试工具设成按ASCII码接受方式); library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD_LOGIC_ARITH.ALL; use IEEE.STD_LOGIC_UNSIGNED.ALL; ENTITY UART IS PORT ( clk : IN std_logic; rst : IN std_logic; rxd : IN std_logic; --串行数据接收端 txd : OUT std_logic; --串行数据发送端 en : OUT std_logic; -- 数码管使能 seg_data : OUT std_logic_vector(7 DOWNTO 0); --数码管数据 key_input : IN std_logic --按键输入 ); END UART; ARCHITECTURE arch OF UART IS --//////////////////inner reg//////////////////// SIGNAL div_reg : std_logic_vector(15 DOWNTO 0);--分频计数器,分频值由波特率决定。分频后得到频率8倍波特率的时钟 SIGNAL div8_tras_reg : std_logic_vector(2 DOWNTO 0);--该寄存器的计数值对应发送时当前位于的时隙数 SIGNAL div8_rec_reg : std_logic_vector(2 DOWNTO 0); --寄存器的计数值对应接收时当前位于的时隙数 SIGNAL state_tras : std_logic_vector(3 DOWNTO 0); -- 发送状态寄存器 SIGNAL state_rec : std_logic_vector(3 DOWNTO 0); -- 接受状态寄存器 SIGNAL clkbaud_tras : std_logic; --以波特率为频率的发送使能信号 SIGNAL clkbaud_rec : std_logic; --以波特率为频率的接受使能信号 SIGNAL clkbaud8x : std_logic; --以8倍波特率为频率的时钟,它的作用是将发送或接受一个bit的时钟周期分为8个时隙 SIGNAL recstart : std_logic; -- 开始发送标志 SIGNAL recstart_tmp : std_logic; --开始接受标志 SIGNAL trasstart : std_logic; SIGNAL rxd_reg1 : std_logic; --接收寄存器1 SIGNAL rxd_reg2 : std_logic; --接收寄存器2,因为接收数据为异步信号,故用两级缓存 SIGNAL txd_reg

文档评论(0)

1亿VIP精品文档

相关文档