版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1 设计目的:1、 熟练掌握和使用基于cpld/fpga的数字系统开发工具、开发流程,能够自主进行成熟的基于cpld/fpga的数字系统设计,能够发现和独立解决开发过程中遇到的问题。 2、了解时序电路fpga的实现。3、学习用vhdl语言来描述时序电路的过程。4、了解lcd1602液晶显示器的工作原理。二设计环境: quartush 9.0 软件 mars-1270 cpld实验版 1602液晶 mars-1270 cpld实验版是针对cpld/fpga的初中级学者设计,该板可 以配合其扩展板进行相应的实验,也可以作为相关cpld/fpga研发的原型。核心板简单实用扩展性好,板上提供isp接口
2、,并将cpld/fpga的部分io引脚引出,为用户提供一个帮助用户快速开始可编程逻辑器件学习之旅的硬件平台。3 设计要求: 要求用1602液晶显示字符; 显示内容:学号+英文姓名; 显示方式:流动显示,开关控制字符流动速度及方向;具有暂停和清屏 的功能; 扩展部分:设计汉字字符及其他功能四设计思路及实现方法1. 下图所示1602字符液晶接口与实验板内部相连之图 上图所示是从mars-1270 cpld实验版 的手册上截取的1602与实验板相连的图,1,2,3,15,16均与实验板内部电压相连,显示时只需注意给1602的 4-14管脚赋值。 (1)1602引脚定义 1602采用标准的16脚接口,
3、其中: 第1脚:vss为地电源第2脚:vdd接5v正电源第3脚:v0为液晶显示器对比度调整端,接正电源时对比度最弱,接地电源时对比度最高,对比度过高时会产生“鬼影”,使用时可以通过一个10k的电位器调整对比度第4脚:rs为寄存器选择,高电平时选择数据寄存器、低电平时选择指令寄存器。第5脚:rw为读写信号线,高电平时进行读操作,低电平时进行写操作。当rs和rw共同为低电平时可以写入指令或者显示地址,当rs为低电平rw为高电平时可以读忙信号,当rs为高电平rw为低电平时可以写入数据。第6脚:e端为使能端,当e端由高电平跳变成低电平时,液晶模块执行命令。第714脚:d0d7为8位双向数据线。第151
4、6脚:空脚(2) 1602实际写时每位的地址 第一行:首地址为80h,”10000000”,最多能显示27个数;尾地址为a7h,”10100111” 第二行:首地址为 c0h,”11000000”, 最多能显示27个数;尾地址为 e7h,”11100111” (3) 1602内部1602液晶模块内部的字符发生存储器(cgrom)已经存储了160个不同的点阵字符图形,如表1所示,这些字符有:阿拉伯数字、英文字母的大小写、常用 的符号、和日文假名等,每一个字符都有一个固定的代码,比如大写的英文字母“a”的代码是01000001b(41h),显示时模块把地 址41h中的点阵字符图形显示出来,我们就能
5、看到字母“a”lcd1602的工作时序可查阅其他资料下图为cgrom中字符码与字符字模关系对照表从下图可以看出,“a”字的对应上面高位代码为0100,对应左边低位代码为0001,合起来就是01000001,也就是41h。可见它的代码与我们pc中的字符代码是基本一致的。因此我们在向ddram 写c51字符代码程序时甚至可以直接用p1a这样的方法。pc在编译时就把“a”先转为41h代码了。字符代码0x000x0f为用户自定义的字符图形ram(对于5x8点阵的字符,可以存放8组,5x10点阵的字符,存放4组),就是cgram了。0x200x7f 为标准的ascii 码,0xa00xff 为日文字符和
6、希腊文字符,其余字符码(0x100x1f及0x800x9f)没有定义。(4)对ddram的内容和地址进行操作的指令(只介绍本次设计中涉及的一些) 一清屏指令:使液晶不显示任何东西 二.设定显示屏或光标移动方向指令 三显示模式设置:写程序时从38h开写,是使液晶处于开始状态 四.暂停及流动 指令码 功能0 001sx00若s=1,则静止不动;为0,流动显示注:上述四个功能均在rs为0时方可写入;若rs为1,则可写入在1602上显示字符的代码;e一般选取系统时钟分频后的时钟;2. 设计思路及实现方法. 根据写1602的一般顺序:(1)开始38h.(2)显示模式设置.(3)显示关闭08h.(4)显示
7、清屏01h.(5)显示光标移动设置06h.(6)显示开及光标移动设置0ch 根据这几步决定用vhdl语言中的状态机描述方式进行编写程序,与其他描述方式相比,状态机的表述丰富多样,程序层次分明,结构清晰,易读易懂; 其中,在设计程序的过程中,由于程序包含地址和显示内容,考虑用到元件例化语句,将每个地址要显示的内容存到相应的元件例化语句中去。元件例化就是将预先设计好的设计实体定义为一个元件,然后利用特定的语句将此元件与当前的设计实体中的指定端口相连接。 五程序源文件与设计结果分析1.显示内容:学号+英文姓名library ieee;use ieee.std_logic_1164.all;use i
8、eee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity yejing2 is port ( clk : in std_logic;-40mhz reset : in std_logic;-rst lcd_rs : out std_logic;-data/mingling(en0) lcd_rw : out std_logic;-read/write(en1) lcd_e : buffer std_logic;-enable(en2) data : out std_logic_vector(7 downto 0);-/data
9、 shumaguan key:in std_logic; -拨码开关0 key1:in std_logic; -拨码开关1 key2:in std_logic -拨码开关2 );end yejing2 ;architecture behavioral of yejing2 isconstant idle : std_logic_vector(10 downto 0) :=00000000000;-/闲置constant clear : std_logic_vector(10 downto 0) :=00000000001;-/清屏 constantreturncursor:std_logic_
10、vector(10downto0) :=00000000010 ;-/光标返回constantsetmode : std_logic_vector(10 downto 0) :=00000000100;-/输入方式-/0x06-/显示光标移动设置,当读或写一个字符后地址指针加1,且光标加1constantswitchmode:std_logic_vector(10downto0) :=00000001000;-/显示开关-/0x0c-/开显示;不显示光标;光标不闪烁constant shift : std_logic_vector(10 downto 0) :=00000011000;-/移位
11、调整-/0x81-/显示位移;左移constantsetfunction:std_logic_vector(10downto0) :=00000100000;-/功能设置-/0x3c-/8位;两行显示16*2 ; constantsetcgram:std_logic_vector(10downto 0) :=00001000000;-/字符发生存储器地址acgconstantsetddram:std_logic_vector(10downto 0) :=00010000000;-/设置ddram(显示数据ram)的地址-/0x80 显示数据储存器地址add -/0xc0 显示数据储存器地址ad
12、d 第二行开头constant readflag : std_logic_vector(10 downto 0) :=00100000000;-/忙标志constant writeram: std_logic_vector(10 downto 0) :=01000000000; -写数据到cgram或者ddramconstantreadram: std_logic_vector(10 downto 0) :=10000000000;-/从cgram或者ddram读数signal state : std_logic_vector(10 downto 0);signal counter : int
13、eger range 0 to 127;signal div_counter : integer range 0 to 15;signal flag : std_logic;constant divss : integer :=15;signal char_addr: std_logic_vector(6 downto 0);signal data_in : std_logic_vector(7 downto 0);component char_ram2port( address : in std_logic_vector(6 downto 0) ; data : out std_logic_
14、vector(7 downto 0) );end component;-元件例化语句signal clk_int: std_logic;signal clkcnt: std_logic_vector(18 downto 0);constant divcnt: std_logic_vector(18 downto 0):=1111001110001000000; -/498752signal a:integer;signal clkdiv: std_logic;signal tc_clkcnt: std_logic; signal k: integer; -显示步进signal yi: std_
15、logic; -显示左移还是右移signal zanting: std_logic;-显示暂停还是流动 beginprocess(key)-该部分控制分频步进是1还是5,即是控制字符流动速度begin case key is when 0=kknull; end case;end process;process(key1)该部分控制液晶整屏左移还是右移1是左移, 0右移begincase key1 is when 1=yiyinull; end case;end process;process(key2)该部分控制整屏暂停还是流动1暂停,0流动begincase key2 is when 1=
16、zantingzantingnull; end case;end process;process(clk,reset)begin if(reset=0)thenclkcnt=0000000000000000000; elsif(clkevent and clk=1)then if(clkcnt=divcnt)then-/ t=498752*25ns=12.5msclkcnt=0000000000000000000; elseclkcnt=clkcnt+k; end if; end if;end process;tc_clkcnt=1 when clkcnt=divcnt else -/12.5
17、ms产生计数溢出脉冲 0; process(tc_clkcnt,reset)begin if(reset=0)thenclkdiv=0; elsif(tc_clkcntevent and tc_clkcnt=1)thenclkdiv=not clkdiv; -/翻转时钟 t=25ms f=40hz end if;end process;process(clkdiv,reset)begin if(reset=0)thenclk_int=0; elsif(clkdivevent and clkdiv=1)thenclk_int= not clk_int; -/分频 t=50ms f=20hz en
18、d if;end process;process(clkdiv,reset)begin if(reset=0)thenlcd_e=0; elsif(clkdivevent and clkdiv=0)thenlcd_echar_addr,data=data_in);lcd_rs = 1 when state =writeram or state = readram else 0; -/当lcd_rs=1时,为数据;=0时,为命令 lcd_rw = 0 when state =clear or state = returncursor or state=setmode or state=switc
19、hmode or state=shift or state= setfunction or state=setcgram or state =setddram or state =writeram else 1; -/=0,写;=1,读 data =00000001 when state =clear else -/0x01-清屏00000010 when state =returncursor else -/0x02-光标返回00000110 when state = setmode else -/0x06-/显示光标移动设置,当读或写一个字符后地址指针加1,且光标加100001100 wh
20、en state =switchmode else -/0x0c-/开显示;不显示光标;光标不闪烁0001 & zanting & yi &00 when state = shift else -/0x81-/显示位移;左移00111100 when state=setfunction else-/0x3c-/8位;两行显示16*2 ; 字体5*1001000000 when state =setcgram else -/0x40 字符发生器储存器地址acg10000000 when state =setddram and counter =0 else -/0x80 显示数据储存器地址add
21、 11000000 when state =setddram and counter /=0 else -/0xc0 显示数据储存器地址add 第二行开头 data_in when state = writeram else -/写入数据 zzzzzzzz; char_addr =conv_std_logic_vector( counter,7) when state =writeram and counter40 and counter40 and counter88 and counter73 and counter81 1-70000001; process(clk_int,reset)
22、 begin if(reset=0)then state=idle; counter=0; flag=0; div_counter -/(1)if(flag=0)then state=setfunction; -/-/0x3c-/8位;两行显示16*2 ; flag=1; counter=0; -/初始地址 div_counter=0;else if(div_counterdivss )then -/constant divss : integer :=15; div_counter=div_counter +1; state=idle; else div_counter=0; state -
23、/(2)-/-/0x3c-/8位;两行显示16*2 ; state-/(3)-/0x0c-/开显示;不显示光标;光标不闪烁 state-/(4) -/0x01-清屏 state-/(5)-/0x06-/显示光标移动设置,当读或写一个字符后地址指针加1,且光标加1 state-/(6) if(counter =40)then state=setddram; counter=counter+1;elsif(counter/=40 and counter81)then state=writeram; counter=counter+1;elsestate -/(7) state -/(7) stat
24、e state state state state stateresult := 32;when ! =result := 33;when =result := 34;when # =result := 35;when $ =result := 36; when % =result := 37;when & =result := 38;when =result := 39;when ( =result := 40;when ) =result := 41;when * =result := 42;when + =result := 43;when , =result := 44;when -
25、=result := 45;when . =result := 46;when / =result := 47;when 0 =result := 48;when 1 =result := 49;when 2 =result := 50;when 3 =result := 51;when 4 =result := 52;when 5 =result := 53;when 6 =result := 54;when 7 =result := 55;when 8 =result := 56;when 9 =result := 57;when : =result := 58;when ; =resul
26、t := 59;when result := 60;when = =result := 61;when =result := 62;when ? =result := 63;when =result := 64;when a =result := 65;when b =result := 66;when c =result := 67;when d =result := 68;when e =result := 69;when f =result := 70;when g =result := 71;when h =result := 72;when i =result := 73;when
27、j =result := 74;when k =result := 75;when l =result := 76;when m =result := 77;when n =result := 78;when o =result := 79;when p =result := 80;when q =result := 81;when r =result := 82;when s =result := 83;when t =result := 84;when u =result := 85;when v =result := 86;when w =result := 87;when x =res
28、ult := 88;when y =result := 89;when z =result := 90;when =result := 91;when =result := 92;when =result := 93;when =result := 94;when _ =result := 95;when =result := 96;when a =result := 97;when b =result := 98;when c =result := 99;when d =result := 100;when e =result := 101;when f =result := 102;whe
29、n g =result := 103;when h =result := 104;when i =result := 105;when j =result := 106;when k =result := 107;when l =result := 108;when m =result := 109;when n =result := 110;when o =result := 111;when p =result := 112;when q =result := 113;when r =result := 114;when s =result := 115;when t =result := 116;when
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 食品卫生安全检测技术进展
- 策划大寒节气活动模板
- 财务月报解读模板
- 硕士生导师训练模板
- 圣诞新媒体运营报告模板
- 学生会总结大会主持稿
- 统编版五年级语文上册寒假作业(三)(有答案)
- 河北省唐山市2024-2025学年七年级上学期1月期末考试生物试卷(含答案)
- 二零二五年度教育资源共享平台合作合同2篇
- 二零二五年度智能仓储系统安装与物流管理协议3篇
- 2023年保安公司副总经理年终总结 保安公司分公司经理年终总结(5篇)
- 中国华能集团公司风力发电场运行导则(马晋辉20231.1.13)
- 中考语文非连续性文本阅读10篇专项练习及答案
- 2022-2023学年度六年级数学(上册)寒假作业【每日一练】
- 法人不承担责任协议书(3篇)
- 电工工具报价单
- 反歧视程序文件
- 油气藏类型、典型的相图特征和识别实例
- 流体静力学课件
- 顾客忠诚度论文
- 实验室安全检查自查表
评论
0/150
提交评论