全球最实用的IT互联网信息网站!

AI人工智能P2P分享&下载搜索网页发布信息网站地图

当前位置:诺佳网 > 电子/半导体 > 接口/总线/驱动 >

CPLD的串口通信设计

时间:2011-04-25 11:44

人气:

作者:admin

标签: cpld  串口通信 

导读:CPLD的串口通信设计-本文选用CPLD 是ALTERA 公司的EPM240T100,结合MAX232 接口芯片进行串口通信设计...

  一、硬件电路设计

  本文选用CPLDALTERA 公司的EPM240T100,结合MAX232 接口芯片进行串口通信设计,框图如下图1 所示。

  

 

  图1 CPLD串口通信模块硬件设计

  二、VHDL程序模块设计及描述

  使用VHDL 对CPLD 进行编程,设计3 个模块,波特率发生模块,接收器,发送器。

  1. 波特率发生模块

  波特率发生器实际是一个分频器,如前所述,本文设计的波特率为19.2kb/ 秒,设计使用的时钟频率为10MHz,所以计数器进行计数时计数到260进行翻转。

  程序如下(关键部分保留,非必要部分用……代替):

  ……

  ENTITY uart IS

  GENERIC(d_len:INTEGER:=8);

  PORT (

  f10MHz:IN STD_LOGIC;-- 系统时钟

  reset:IN STD_LOGIC;-- 复位信号

  rxd:IN STD_LOGIC; -- 串行接收

  txd:OUT STD_LOGIC;-- 串行发送

  );

  END uart;

  ARCHITECTURE behav of uart IS

  ……

  BEGIN

  rxds<=rxd;

  PROCESS(f10MHz,reset)

  -- 设置波特率发生器 19200kb/s

  VARIABLE clk19200hz: STD_LOGIC;

  VARIABLE count:INTEGER RANGE 0 TO 260;

  BEGIN

  IF reset='0' THEN

  count:=0;

  clk19200hz:='0';

  ELSIF f10MHz'EVENT AND f10MHz='1' THEN

  IF count=260 THEN

  count:=0;clk19200hz:= NOT clk19200hz;

  ELSE

  count:=count+1;

  END IF;

  END IF;

  baud_rate<=clk19200hz;

  END PROCESS;

 

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信