国产爱久久久精品_看**视频一一级毛片_91啪国自产中文字幕在线_国内精品伊人久久久久妇

網(wǎng)絡(luò)消費(fèi)網(wǎng) >  5G > > 正文
【從零開始走進(jìn)FPGA】 LCD 1602 Hello World
時(shí)間:2022-02-14 06:22:03

前面說過,在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)鍵詞:

版權(quán)聲明:
    凡注明來網(wǎng)絡(luò)消費(fèi)網(wǎng)的作品,版權(quán)均屬網(wǎng)絡(luò)消費(fèi)網(wǎng)所有,未經(jīng)授權(quán)不得轉(zhuǎn)載、摘編或利用其它方式使用上述作品。已經(jīng)本網(wǎng)授權(quán)使用作品的,應(yīng)在授權(quán)范圍內(nèi)使用,并注明"來源:網(wǎng)絡(luò)消費(fèi)網(wǎng)"。違反上述聲明者,本網(wǎng)將追究其相關(guān)法律責(zé)任。
    除來源署名為網(wǎng)絡(luò)消費(fèi)網(wǎng)稿件外,其他所轉(zhuǎn)載內(nèi)容之原創(chuàng)性、真實(shí)性、完整性、及時(shí)性本站不作任何保證或承諾,請讀者僅作參考并自行核實(shí)。
熱文

網(wǎng)站首頁 |網(wǎng)站簡介 | 關(guān)于我們 | 廣告業(yè)務(wù) | 投稿信箱
 

Copyright © 2000-2020 m.fnsyft.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

備案號(hào):京ICP備2022016840號(hào)-15

營業(yè)執(zhí)照公示信息

国产爱久久久精品_看**视频一一级毛片_91啪国自产中文字幕在线_国内精品伊人久久久久妇

        亚洲一区影音先锋| 精品精品国产高清a毛片牛牛 | 亚洲成a人片综合在线| 欧美一区二区在线视频| 亚洲日本乱码在线观看| 国产主播一区二区三区| 国产精品福利一区| 69堂精品视频| 亚洲欧美日本韩国| 国产成人精品影视| 亚洲激情图片一区| 精品欧美乱码久久久久久 | 欧美在线综合视频| 国产精品久久国产精麻豆99网站| 另类小说一区二区三区| 中文字幕精品一区二区精品绿巨人| 色国产综合视频| 国产精品网站在线观看| 精久久久久久久久久久| 中文字幕制服丝袜一区二区三区| 正在播放亚洲一区| 亚洲一区二区3| 国产午夜亚洲精品羞羞网站| 午夜精彩视频在线观看不卡| 久久综合九色综合欧美98| 色爱区综合激月婷婷| 中文字幕日韩一区| 成人一二三区视频| 一本一道波多野结衣一区二区| 国产欧美日韩久久| 国产高清不卡一区| 亚洲国产一区视频| 国产精品久久久久久久蜜臀| 国产精品亚洲成人| 亚洲国产精品天堂| 日韩美女视频19| 白白色 亚洲乱淫| 欧美性生活一区| 亚洲在线中文字幕| 久久久精品黄色| 欧美一区二区三区性视频| 天天影视色香欲综合网老头| 国产精品水嫩水嫩| 精品国产91乱码一区二区三区 | 亚洲综合视频在线观看| 91蝌蚪porny九色| 欧美精品在欧美一区二区少妇| 亚洲成在线观看| 中文字幕久久午夜不卡| 欧美电影免费观看高清完整版在| 麻豆精品一二三| 一区二区三区不卡在线观看| 国产精品你懂的| 成人18视频日本| 欧美疯狂做受xxxx富婆| 日韩电影免费一区| 亚洲精品videosex极品| 国产精品人妖ts系列视频| av电影在线观看不卡| 欧美日韩国产综合一区二区三区| 亚洲成人777| 亚洲视频网在线直播| 国产欧美综合在线观看第十页| 成人av在线电影| 欧美精品一二三| 久热成人在线视频| 午夜精品免费在线| 亚洲国产欧美日韩另类综合| 亚洲丝袜另类动漫二区| 中文字幕中文字幕一区二区| 久久久精品一品道一区| 精品日韩99亚洲| 国产精品18久久久久久久网站| 欧美中文一区二区三区| 日韩激情一二三区| 亚洲一线二线三线视频| 一区二区三区在线免费观看| 亚洲欧洲另类国产综合| 国产精品久久久久影院亚瑟| 国产欧美一区二区精品秋霞影院| 久久久久久久久久久久电影 | 久久69国产一区二区蜜臀| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 日韩亚洲欧美高清| 国产激情一区二区三区四区 | 久久久蜜臀国产一区二区| 成人av动漫在线| 日韩精品一区二区三区四区 | 国产精品麻豆久久久| 国产精品视频yy9299一区| 久久影院视频免费| 久久精品视频一区二区| 91免费看`日韩一区二区| 欧美刺激脚交jootjob| a美女胸又www黄视频久久| 日韩女优电影在线观看| 成人黄色电影在线| 久久综合色之久久综合| 97se亚洲国产综合自在线| 久久久亚洲精品一区二区三区| 久久久综合网站| 欧美国产激情一区二区三区蜜月| 国产日产精品1区| 亚洲日本乱码在线观看| 玉足女爽爽91| 丝袜美腿亚洲色图| 欧美性受xxxx黑人xyx| 国产麻豆一精品一av一免费| 日韩一区国产二区欧美三区| 成人动漫av在线| 久久久亚洲高清| 国产精品国产自产拍高清av| 亚洲精品成人在线| 亚洲成人午夜电影| 久久国产麻豆精品| 日韩三级免费观看| 99久久精品免费看国产| 国产欧美一区二区精品秋霞影院| 日本一二三四高清不卡| 亚洲与欧洲av电影| 色欧美片视频在线观看在线视频| 狠狠色2019综合网| 精品久久久久久久久久久久久久久久久 | 日韩av一级电影| 欧美三级日韩在线| 成人精品国产免费网站| 国产喷白浆一区二区三区| 成人免费一区二区三区在线观看| 亚洲福利电影网| 欧美最猛性xxxxx直播| 国产伦精品一区二区三区在线观看 | 2023国产精品自拍| 中文欧美字幕免费| 性做久久久久久免费观看| 在线观看国产一区二区| 国产91清纯白嫩初高中在线观看| 久久九九99视频| 亚洲欧美日韩综合aⅴ视频| 日韩精品电影在线| 欧美一卡在线观看| 国产日韩欧美不卡| 亚洲成人激情综合网| 欧美日韩一区二区在线观看| 99精品国产视频| 亚洲美女偷拍久久| 欧美在线制服丝袜| 99久久精品一区二区| 亚洲精品伦理在线| 欧美午夜一区二区三区| 99久久亚洲一区二区三区青草 | 一卡二卡三卡日韩欧美| 91国在线观看| 91在线免费看| 亚洲成人资源在线| 91精品国产综合久久国产大片| 国产清纯在线一区二区www| 亚洲成人av电影| 欧美成人性战久久| 最新国产成人在线观看| 激情综合亚洲精品| 国产免费观看久久| 色综合久久天天综合网| 白白色 亚洲乱淫| 亚洲一级二级三级| 日韩一区二区免费高清| 自拍偷拍亚洲欧美日韩| 韩国午夜理伦三级不卡影院| 国产精品欧美久久久久无广告 | 美女爽到高潮91| 国产日韩欧美电影| 午夜精品久久久久久久99樱桃| 成人av资源下载| 亚洲自拍都市欧美小说| 日韩视频123| 一区二区三区四区高清精品免费观看| 国产精品18久久久久久久网站| 亚洲视频 欧洲视频| 欧美老女人第四色| 国产精品久久久久9999吃药| 国产中文字幕一区| 中文字幕制服丝袜成人av| 欧美日韩卡一卡二| 国产精品福利在线播放| 国产伦精品一区二区三区免费迷 | 最新欧美精品一区二区三区| 国产成人综合亚洲网站| 亚洲你懂的在线视频| 91精品在线免费观看| 亚洲色图.com| 成人毛片老司机大片| 午夜激情综合网| 中文字幕高清不卡| 欧美日韩激情一区二区三区| 最新不卡av在线| 成人免费高清视频| 青娱乐精品视频| 国产精品家庭影院| 日韩视频一区二区三区 | 日本不卡视频在线观看| 国产精品亲子伦对白|