
前面說過,在C,C++等語言學(xué)習(xí)中,“Hello World”將會(huì)是第一個(gè)學(xué)習(xí)的代碼,但是在FPGA中由于電路驅(qū)動(dòng)的復(fù)雜性,與單片機(jī)雷同,我們無法在電腦上實(shí)現(xiàn)“Hello World”的顯示,而必須依靠相關(guān)硬件。因此我們不得不在一定的基礎(chǔ)上,才能講解關(guān)于LCD1602字符液晶的驅(qū)動(dòng),以及Hello World的顯示。
雷同于前面MCU按鍵消抖動(dòng)移植代碼,此處也可以移植MCU LCD1602驅(qū)動(dòng)代碼。本例程不是Bingo原創(chuàng),是按照網(wǎng)友“小時(shí)不識(shí)月”的代碼,移植修改最后定型為Bingo版本(O(∩_∩)O哈哈~)。
電路圖此處不解釋,太簡單了。
一、驅(qū)動(dòng)說明
由于FPGA的高速并行操作,并非順序執(zhí)行,在代碼上與MCU有所不同。此處先講解驅(qū)動(dòng)原理:
(1)分頻以得到500KHz固定的頻率,初始化LCD1602。如下圖所示,LCD_EN的頻率應(yīng)該控制在2M以內(nèi)(不同的LCD1602參數(shù)會(huì)有所不同)。
(2)通過三段式狀態(tài)機(jī),來初始化以及給數(shù)據(jù)。
(3)通過循環(huán)讀取某一“數(shù)組”,循環(huán)給LCD1602數(shù)據(jù),以接口形式方便改變。
二、FPGALCD1602 FSM
1. 代碼
/*************************************************
* Module Name : lcd1602_driver
* Engineer : Crazy Bingo
* Target Device : EP2C8Q208C8
* Tool versions : Quartus II 11.0
* Create Date : 2011-7-3
* Revision : v1.0
* Description :
**************************************************/
module lcd1602_driver
(
input clk,
input rst_n,
output lcd_en, // lcd enable
output reg lcd_rs, // record,statement
output lcd_rw,
output reg [7:0] lcd_data
);
parameter [127:0] line_rom1 = "I am CrazyBingo!";
parameter [127:0] line_rom2 = "Hello World*^_^*";
//--------------------------------------
reg [15:0] cnt;
always @ (posedge clk or negedge rst_n)
begin
if(!rst_n)
cnt <= 0;
else
cnt <= cnt + 1"b1;
end
assign lcd_en = cnt[15]; //lcd enable,keep same time
assign lcd_rw = 1"b0; //write only
wire cmd_flag = (cnt == 16"h7FFF) ? 1"b1 : 1"b0; //when lcd_en is steady,write a cmd
//---------------------------------------
// Gray code : 40 states
parameter IDLE = 8"h00; // IDLE
// lcd init
parameter DISP_SET = 8"h01; // display mode
parameter DISP_OFF = 8"h03; // off display
parameter CLR_SCR = 8"h02; // clear the lcd
parameter CURSOR_SET1 = 8"h06; // cursor set
parameter CURSOR_SET2 = 8"h07; // on display, cursor set
// display 1th line
parameter ROW1_ADDR = 8"h05;
parameter ROW1_0 = 8"h04;
parameter ROW1_1 = 8"h0C;
parameter ROW1_2 = 8"h0D;
parameter ROW1_3 = 8"h0F;
parameter ROW1_4 = 8"h0E;
parameter ROW1_5 = 8"h0A;
parameter ROW1_6 = 8"h0B;
parameter ROW1_7 = 8"h09;
parameter ROW1_8 = 8"h08;
parameter ROW1_9 = 8"h18;
parameter ROW1_A = 8"h19;
parameter ROW1_B = 8"h1B;
parameter ROW1_C = 8"h1A;
parameter ROW1_D = 8"h1E;
parameter ROW1_E = 8"h1F;
parameter ROW1_F = 8"h1D;
// display 2th line
parameter ROW2_ADDR = 8"h1C;
parameter ROW2_0 = 8"h14;
parameter ROW2_1 = 8"h15;
parameter ROW2_2 = 8"h17;
parameter ROW2_3 = 8"h16;
parameter ROW2_4 = 8"h12;
parameter ROW2_5 = 8"h13;
parameter ROW2_6 = 8"h11;
parameter ROW2_7 = 8"h10;
parameter ROW2_8 = 8"h30;
parameter ROW2_9 = 8"h31;
parameter ROW2_A = 8"h33;
parameter ROW2_B = 8"h32;
parameter ROW2_C = 8"h36;
parameter ROW2_D = 8"h37;
parameter ROW2_E = 8"h35;
parameter ROW2_F = 8"h34;
//---------------------------------------
reg [5:0] current_state, next_state;
// FSM: always1
always @ (posedge clk or negedge rst_n)
begin
if(!rst_n)
current_state <= IDLE;
else if(cmd_flag)
current_state <= next_state;
end
//---------------------------------------
// FSM: always2
always@*
begin
case(current_state)
// lcd init
IDLE : next_state = DISP_SET;
DISP_SET : next_state = DISP_OFF;
DISP_OFF : next_state = CLR_SCR;
CLR_SCR : next_state = CURSOR_SET1;
CURSOR_SET1 : next_state = CURSOR_SET2;
CURSOR_SET2 : next_state = ROW1_ADDR;
// display 1th line
ROW1_ADDR : next_state = ROW1_0;
ROW1_0 : next_state = ROW1_1;
ROW1_1 : next_state = ROW1_2;
ROW1_2 : next_state = ROW1_3;
ROW1_3 : next_state = ROW1_4;
ROW1_4 : next_state = ROW1_5;
ROW1_5 : next_state = ROW1_6;
ROW1_6 : next_state = ROW1_7;
ROW1_7 : next_state = ROW1_8;
ROW1_8 : next_state = ROW1_9;
ROW1_9 : next_state = ROW1_A;
ROW1_A : next_state = ROW1_B;
ROW1_B : next_state = ROW1_C;
ROW1_C : next_state = ROW1_D;
ROW1_D : next_state = ROW1_E;
ROW1_E : next_state = ROW1_F;
ROW1_F : next_state = ROW2_ADDR;
// display 2th line
ROW2_ADDR : next_state = ROW2_0;
ROW2_0 : next_state = ROW2_1;
ROW2_1 : next_state = ROW2_2;
ROW2_2 : next_state = ROW2_3;
ROW2_3 : next_state = ROW2_4;
ROW2_4 : next_state = ROW2_5;
ROW2_5 : next_state = ROW2_6;
ROW2_6 : next_state = ROW2_7;
ROW2_7 : next_state = ROW2_8;
ROW2_8 : next_state = ROW2_9;
ROW2_9 : next_state = ROW2_A;
ROW2_A : next_state = ROW2_B;
ROW2_B : next_state = ROW2_C;
ROW2_C : next_state = ROW2_D;
ROW2_D : next_state = ROW2_E;
ROW2_E : next_state = ROW2_F;
ROW2_F : next_state = ROW1_ADDR;
default : next_state = IDLE ;
endcase
end
//---------------------------------------
// FSM: always3
always @ (posedge clk or negedge rst_n)
begin
if(!rst_n)
begin
lcd_rs <= 0;
lcd_data <= 8"hXX;
end
else if(cmd_flag)
begin
// write statement
case(next_state)
IDLE : lcd_rs <= 0; //statement
//lcd init
DISP_SET : lcd_rs <= 0; //statement
DISP_OFF : lcd_rs <= 0; //statement
CLR_SCR : lcd_rs <= 0; //statement
CURSOR_SET1 : lcd_rs <= 0; //statement
CURSOR_SET2 : lcd_rs <= 0; //statement
// display 1th line
ROW1_ADDR : lcd_rs <= 0; //statement
ROW1_0 : lcd_rs <= 1; //record
ROW1_1 : lcd_rs <= 1; //record
ROW1_2 : lcd_rs <= 1; //record
ROW1_3 : lcd_rs <= 1; //record
ROW1_4 : lcd_rs <= 1; //record
ROW1_5 : lcd_rs <= 1; //record
ROW1_6 : lcd_rs <= 1; //record
ROW1_7 : lcd_rs <= 1; //record
ROW1_8 : lcd_rs <= 1; //record
ROW1_9 : lcd_rs <= 1; //record
ROW1_A : lcd_rs <= 1; //record
ROW1_B : lcd_rs <= 1; //record
ROW1_C : lcd_rs <= 1; //record
ROW1_D : lcd_rs <= 1; //record
ROW1_E : lcd_rs <= 1; //record
ROW1_F : lcd_rs <= 1; //record
// display 2th line
ROW2_ADDR : lcd_rs <= 0; //statement
ROW2_0 : lcd_rs <= 1; //record
ROW2_1 : lcd_rs <= 1; //record
ROW2_2 : lcd_rs <= 1; //record
ROW2_3 : lcd_rs <= 1; //record
ROW2_4 : lcd_rs <= 1; //record
ROW2_5 : lcd_rs <= 1; //record
ROW2_6 : lcd_rs <= 1; //record
ROW2_7 : lcd_rs <= 1; //record
ROW2_8 : lcd_rs <= 1; //record
ROW2_9 : lcd_rs <= 1; //record
ROW2_A : lcd_rs <= 1; //record
ROW2_B : lcd_rs <= 1; //record
ROW2_C : lcd_rs <= 1; //record
ROW2_D : lcd_rs <= 1; //record
ROW2_E : lcd_rs <= 1; //record
ROW2_F : lcd_rs <= 1; //record
endcase
// write lcd_data
case(next_state)
IDLE : lcd_data <= 8"hxx;
//lcd init
DISP_SET : lcd_data <= 8"h38; //set 16X2,5X7 ,8 bits record
DISP_OFF : lcd_data <= 8"h08; //off display
CLR_SCR : lcd_data <= 8"h01; //clear lcd
CURSOR_SET1 : lcd_data <= 8"h06; //cursor set
CURSOR_SET2 : lcd_data <= 8"h0C; //on display
// display 1th line
ROW1_ADDR : lcd_data <= 8"h80;
ROW1_0 : lcd_data <= line_rom1[127:120];
ROW1_1 : lcd_data <= line_rom1[119:112];
ROW1_2 : lcd_data <= line_rom1[111:104];
ROW1_3 : lcd_data <= line_rom1[103: 96];
ROW1_4 : lcd_data <= line_rom1[ 95: 88];
ROW1_5 : lcd_data <= line_rom1[ 87: 80];
ROW1_6 : lcd_data <= line_rom1[ 79: 72];
ROW1_7 : lcd_data <= line_rom1[ 71: 64];
ROW1_8 : lcd_data <= line_rom1[ 63: 56];
ROW1_9 : lcd_data <= line_rom1[ 55: 48];
ROW1_A : lcd_data <= line_rom1[ 47: 40];
ROW1_B : lcd_data <= line_rom1[ 39: 32];
ROW1_C : lcd_data <= line_rom1[ 31: 24];
ROW1_D : lcd_data <= line_rom1[ 23: 16];
ROW1_E : lcd_data <= line_rom1[ 15: 8];
ROW1_F : lcd_data <= line_rom1[ 7: 0];
// display 2th line
ROW2_ADDR : lcd_data <= 8"hC0;
ROW2_0 : lcd_data <= line_rom2[127:120];
ROW2_1 : lcd_data <= line_rom2[119:112];
ROW2_2 : lcd_data <= line_rom2[111:104];
ROW2_3 : lcd_data <= line_rom2[103: 96];
ROW2_4 : lcd_data <= line_rom2[ 95: 88];
ROW2_5 : lcd_data <= line_rom2[ 87: 80];
ROW2_6 : lcd_data <= line_rom2[ 79: 72];
ROW2_7 : lcd_data <= line_rom2[ 71: 64];
ROW2_8 : lcd_data <= line_rom2[ 63: 56];
ROW2_9 : lcd_data <= line_rom2[ 55: 48];
ROW2_A : lcd_data <= line_rom2[ 47: 40];
ROW2_B : lcd_data <= line_rom2[ 39: 32];
ROW2_C : lcd_data <= line_rom2[ 31: 24];
ROW2_D : lcd_data <= line_rom2[ 23: 16];
ROW2_E : lcd_data <= line_rom2[ 15: 8];
ROW2_F : lcd_data <= line_rom2[ 7: 0];
endcase
end
end
endmodule
2. 狀態(tài)機(jī)
(1)以下是State machine如下所示:
(2)模塊可分為一下幾個(gè)狀態(tài)
3. “Hello World”實(shí)物顯示
parameter [127:0] line_rom1 = "I am CrazyBingo!";
parameter [127:0] line_rom2 = "Hello World*^_^*";
關(guān)鍵詞:
網(wǎng)站首頁 |網(wǎng)站簡介 | 關(guān)于我們 | 廣告業(yè)務(wù) | 投稿信箱
Copyright © 2000-2020 m.yjkq2010.com All Rights Reserved.
中國網(wǎng)絡(luò)消費(fèi)網(wǎng) 版權(quán)所有 未經(jīng)書面授權(quán) 不得復(fù)制或建立鏡像
聯(lián)系郵箱:920 891 263@qq.com
欧美色综合网_狠狠色狠色综合曰曰_麻豆精品一区二区av白丝在线_久久精品综合一区 91麻豆精品国产91久久久久久 | 国产精品一区免费在线观看| 99精品视频免费在线观看| 91精品国产综合久久香蕉的特点| 中文字幕在线一区| 国产一区欧美二区| 日韩精品中文字幕一区| 亚洲va欧美va人人爽午夜| 色综合天天视频在线观看 | 国产成人av一区| 欧美成人精品高清在线播放| 一区二区高清视频在线观看| 99久久精品费精品国产一区二区| 国产日韩av一区| 国产麻豆一精品一av一免费| 精品区一区二区| 国产中文字幕一区| 久久综合久久综合九色| 国产在线精品一区二区不卡了 | 狠狠狠色丁香婷婷综合激情| 日韩免费视频一区二区| 美腿丝袜亚洲色图| 欧美一区二区三区性视频| 亚洲乱码国产乱码精品精可以看 | 一区二区三区四区不卡在线| 在线视频中文字幕一区二区| 亚洲激情在线播放| 欧美色区777第一页| 亚洲第一福利一区| 欧美另类videos死尸| 日韩av成人高清| 精品少妇一区二区三区免费观看| 久久精品国产一区二区| 欧美精品一区二区三区很污很色的 | 亚洲大型综合色站| 欧美久久久久久蜜桃| 美女一区二区久久| 国产婷婷精品av在线| eeuss国产一区二区三区| 一区二区三区在线免费播放| 欧美日韩中文另类| 国内精品写真在线观看| 国产欧美一区二区在线观看| 99re在线精品| 天天射综合影视| 亚洲精品在线三区| 99精品久久久久久| 亚洲成人免费电影| 久久久美女艺术照精彩视频福利播放| 粉嫩aⅴ一区二区三区四区五区| 亚洲欧美日韩一区二区| 日韩一区二区三区电影在线观看| 国产乱子伦视频一区二区三区 | 国产精品美女久久久久久久久久久| 色婷婷精品大视频在线蜜桃视频| 日韩国产高清影视| 国产精品三级久久久久三级| 欧美日韩一区 二区 三区 久久精品| 美美哒免费高清在线观看视频一区二区 | 日韩在线a电影| 国产亚洲va综合人人澡精品 | 国产精品久久久久久久第一福利| 精品污污网站免费看| 国产99久久久久| 日韩精品一二三区| 中文字幕一区二区三区不卡| 欧美一个色资源| 色欧美日韩亚洲| 国产在线观看一区二区| 亚洲国产精品久久一线不卡| 欧美国产综合一区二区| 欧美一区二区三区小说| 91免费视频网| 高清在线观看日韩| 九九**精品视频免费播放| 亚洲激情中文1区| 国产精品无遮挡| 精品国产免费人成电影在线观看四季 | 日韩一区二区三区高清免费看看 | 99精品国产91久久久久久| 美女视频黄免费的久久 | 成人动漫精品一区二区| 蜜桃av一区二区在线观看| 有坂深雪av一区二区精品| 亚洲精品免费在线播放| 欧美国产视频在线| 精品少妇一区二区三区| 欧美麻豆精品久久久久久| 色香蕉成人二区免费| 国产99久久精品| 国产真实精品久久二三区| 日本伊人午夜精品| 午夜视频在线观看一区二区三区| 亚洲日本丝袜连裤袜办公室| 国产精品麻豆视频| 国产日韩欧美精品在线| 国产亚洲精久久久久久| 久久精品亚洲精品国产欧美| 精品国产凹凸成av人导航| 日韩一卡二卡三卡四卡| 日韩欧美卡一卡二| 日韩一区二区在线观看| 欧美一区二区视频在线观看2022| 欧美日韩成人在线| 欧美日本高清视频在线观看| 欧美日韩综合不卡| 69p69国产精品| 日韩欧美国产综合| 欧美精品一区二区不卡| 久久蜜桃av一区二区天堂| 久久久精品免费观看| 国产嫩草影院久久久久| 国产精品国模大尺度视频| 亚洲婷婷国产精品电影人久久| 亚洲天堂网中文字| 亚洲一区在线视频| 午夜私人影院久久久久| 免费在线观看视频一区| 久久99精品久久只有精品| 国产毛片精品视频| 不卡的av电影在线观看| 色香蕉久久蜜桃| 91精品免费在线| 久久久精品黄色| 亚洲乱码国产乱码精品精的特点| 一区二区三区自拍| 日韩在线观看一区二区| 国产福利一区二区三区在线视频| 99久久精品久久久久久清纯| 欧美日韩视频在线一区二区| 日韩精品一区二区三区在线播放| 久久老女人爱爱| 一区二区三区在线视频观看58| 三级在线观看一区二区 | 国产一区二区在线观看视频| 成人永久aaa| 欧美日韩另类一区| 精品国产一区二区在线观看| 中文字幕在线观看一区| 日韩精品久久理论片| 国产精品66部| 欧美日韩一区在线观看| 国产亚洲自拍一区| 亚洲高清一区二区三区| 黄色资源网久久资源365| 色噜噜狠狠成人中文综合| 日韩欧美成人一区| 中文字幕字幕中文在线中不卡视频| 午夜精品视频一区| 国产**成人网毛片九色| 欧美电影在线免费观看| 国产精品久久久久久久岛一牛影视| 无吗不卡中文字幕| 91麻豆福利精品推荐| 欧美mv日韩mv国产网站| 亚洲一区视频在线| 国产精品亚洲一区二区三区妖精| 欧美无砖专区一中文字| 国产精品免费久久| 九色综合狠狠综合久久| 欧美人与z0zoxxxx视频| 中国av一区二区三区| 激情综合网天天干| 欧美精品高清视频| 亚洲人成亚洲人成在线观看图片| 国产一区二区不卡| 日韩欧美一区二区视频| 亚洲尤物视频在线| 不卡一区二区中文字幕| 久久久综合九色合综国产精品| 日产国产高清一区二区三区| 91国产丝袜在线播放| 国产精品国产三级国产普通话三级 | 日韩一区二区在线播放| 亚洲香肠在线观看| 色综合天天综合网国产成人综合天| 久久综合av免费| 韩国欧美国产1区| 欧美tk—视频vk| 蜜臀精品一区二区三区在线观看| 欧美午夜精品久久久久久超碰 | 日韩欧美国产电影| 日韩av不卡一区二区| 337p亚洲精品色噜噜狠狠| 亚洲妇熟xx妇色黄| 欧美三片在线视频观看| 亚洲一区二区三区爽爽爽爽爽 | 青青草国产精品亚洲专区无| 337p亚洲精品色噜噜噜| 日韩国产精品大片| 欧美麻豆精品久久久久久| 午夜精品在线看| 欧美一区二区观看视频| 蜜桃91丨九色丨蝌蚪91桃色| 精品国产凹凸成av人导航| 国产在线精品一区二区三区不卡| 久久久精品一品道一区| 成人亚洲精品久久久久软件| 国产精品久久久久久久裸模| 91蝌蚪porny成人天涯|