www.亚洲男人天堂_欧美最顶级的aⅴ艳星_国产精品免费网站_欧美日韩在线一区_欧美床上激情在线观看_日韩av色在线_国产精品亚洲综合天堂夜夜_欧美做爰性生交视频_国产成人高潮免费观看精品_久久天天躁夜夜躁狠狠躁2022_国产美女久久精品香蕉69_亚洲专区在线视频_国产精品夜间视频香蕉_国产成人综合一区二区三区_国产精品69av_岛国av午夜精品

網絡消費網 >  5G > > 正文
【從零開始走進FPGA】 LCD 1602 Hello World
時間:2022-02-14 06:22:03

前面說過,在C,C++等語言學習中,“Hello World”將會是第一個學習的代碼,但是在FPGA中由于電路驅動的復雜性,與單片機雷同,我們無法在電腦上實現“Hello World”的顯示,而必須依靠相關硬件。因此我們不得不在一定的基礎上,才能講解關于LCD1602字符液晶的驅動,以及Hello World的顯示。

雷同于前面MCU按鍵消抖動移植代碼,此處也可以移植MCU LCD1602驅動代碼。本例程不是Bingo原創,是按照網友“小時不識月”的代碼,移植修改最后定型為Bingo版本(O(∩_∩)O哈哈~)。

電路圖此處不解釋,太簡單了。

一、驅動說明

由于FPGA的高速并行操作,并非順序執行,在代碼上與MCU有所不同。此處先講解驅動原理:

(1)分頻以得到500KHz固定的頻率,初始化LCD1602。如下圖所示,LCD_EN的頻率應該控制在2M以內(不同的LCD1602參數會有所不同)。

(2)通過三段式狀態機,來初始化以及給數據。

(3)通過循環讀取某一“數組”,循環給LCD1602數據,以接口形式方便改變。

二、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. 狀態機

(1)以下是State machine如下所示:

(2)模塊可分為一下幾個狀態

3. “Hello World”實物顯示

parameter [127:0] line_rom1 = "I am CrazyBingo!";

parameter [127:0] line_rom2 = "Hello World*^_^*";

關鍵詞:

版權聲明:
    凡注明來網絡消費網的作品,版權均屬網絡消費網所有,未經授權不得轉載、摘編或利用其它方式使用上述作品。已經本網授權使用作品的,應在授權范圍內使用,并注明"來源:網絡消費網"。違反上述聲明者,本網將追究其相關法律責任。
    除來源署名為網絡消費網稿件外,其他所轉載內容之原創性、真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考并自行核實。
熱文

網站首頁 |網站簡介 | 關于我們 | 廣告業務 | 投稿信箱
 

Copyright © 2000-2020 www.yushuoyun.cn All Rights Reserved.
 

中國網絡消費網 版權所有 未經書面授權 不得復制或建立鏡像
 

聯系郵箱:920 891 263@qq.com

備案號:京ICP備2022016840號-15

營業執照公示信息

www.亚洲男人天堂_欧美最顶级的aⅴ艳星_国产精品免费网站_欧美日韩在线一区_欧美床上激情在线观看_日韩av色在线_国产精品亚洲综合天堂夜夜_欧美做爰性生交视频_国产成人高潮免费观看精品_久久天天躁夜夜躁狠狠躁2022_国产美女久久精品香蕉69_亚洲专区在线视频_国产精品夜间视频香蕉_国产成人综合一区二区三区_国产精品69av_岛国av午夜精品

        国产综合婷婷| 久久躁日日躁aaaaxxxx| 久久久久一区二区三区四区| 欧美日韩一区二区三区四区五区| 免费观看日韩av| 亚洲美女在线一区| 欧美性猛交xxxx乱大交退制版| 99国产麻豆精品| 男同欧美伦乱| 国产精品永久入口久久久| 欧美资源在线观看| 久久综合婷婷| 亚洲欧美视频在线观看视频| 国内精品久久久久久久果冻传媒| 亚洲人成人99网站| 欧美视频一区二区三区在线观看| 韩日欧美一区二区| 久久久久久久久久码影片| 国产欧美日韩视频一区二区| 国产精品久久久久天堂| 欧美午夜a级限制福利片| 欧美夫妇交换俱乐部在线观看| 亚洲免费播放| 亚洲精品中文字幕在线观看| 久久精品视频免费| 欧美日韩激情小视频| 国产精品男gay被猛男狂揉视频| 香蕉国产精品偷在线观看不卡| 亚洲一区影院| 国内精品免费在线观看| 99re8这里有精品热视频免费| 亚洲欧洲精品一区二区三区不卡| 亚洲视屏一区| 国产精品久久久久9999吃药| 欧美精品成人| 在线视频亚洲| 欧美日韩另类丝袜其他| 欧美女主播在线| 久久蜜桃av一区精品变态类天堂| 一区二区在线免费观看| 亚洲激情成人在线| 在线亚洲免费| 欧美另类videos死尸| 在线播放视频一区| 国产日韩精品在线播放| 亚洲精品男同| 国产欧美日韩亚洲| 亚洲美女精品久久| 国产精品久久一级| 国产亚洲精品一区二555| 在线视频精品一| 一区二区高清在线观看| 欧美激情网站在线观看| 欧美精品一线| 欧美精品黄色| 久久久久久久综合色一本| 国产精品久久777777毛茸茸| 国产一区二区三区电影在线观看| 国产一区二区久久| 国产精品久久久久久超碰| 久久久久亚洲综合| 欧美一区二区在线| 国产精品一区免费观看| 亚洲高清一区二区三区| 免费在线视频一区| 激情综合色丁香一区二区| 欧美成人免费小视频| 欧美亚洲成人网| 亚洲风情在线资源站| 国产精品一级久久久| 欧美精品一区二区三区很污很色的| 亚洲九九九在线观看| 亚洲欧美国产日韩中文字幕| 久久在线播放| 久久精品av麻豆的观看方式| 欧美日韩综合在线免费观看| 亚洲国产午夜| 久久大综合网| 欧美日韩日本视频| 国产视频自拍一区| 激情六月婷婷综合| 国内精品免费午夜毛片| 国产精品羞羞答答| 久久久久久尹人网香蕉| 亚洲精品一区二区三区不| 性8sex亚洲区入口| 欧美日韩国产一区精品一区| 亚洲在线免费观看| 99国产精品99久久久久久粉嫩| 欧美一区二区三区在线播放| 国产精品成人一区二区三区吃奶| 免费影视亚洲| 亚洲免费小视频| 亚洲国产成人在线视频| 亚洲激情成人在线| 国产精品日韩一区二区| 一区二区激情视频| 欧美/亚洲一区| 久久精品国产亚洲a| 国产精品第一页第二页第三页| 久久天天躁狠狠躁夜夜av| 亚洲免费成人av| 国产精品久久久久久久久果冻传媒| 国产精品久久久久高潮| 黑丝一区二区| 欧美激情区在线播放| 久久久不卡网国产精品一区| 亚洲破处大片| 久久久久久综合网天天| 亚洲午夜一区二区三区| 午夜影视日本亚洲欧洲精品| 欧美—级在线免费片| 欲色影视综合吧| 亚洲午夜激情网页| 国产精品手机视频| 欧美日韩亚洲一区二| 国产日韩欧美日韩大片| 欧美激情精品久久久久久免费印度| 欧美日韩美女一区二区| 国产午夜精品理论片a级探花| 日韩视频中午一区| 亚洲激情电影在线| 亚洲自拍偷拍网址| 一区二区毛片| 欧美ab在线视频| 久久精品99国产精品酒店日本| 欧美日韩三级电影在线| 宅男精品视频| 欧美日韩美女一区二区| 麻豆九一精品爱看视频在线观看免费| 一区二区三区高清在线观看| 欧美性色视频在线| 欧美成人首页| 亚洲黄色在线| 亚洲精品视频二区| 欧美国产精品久久| 99视频有精品| 在线亚洲国产精品网站| 久久精品欧美| 欧美91视频| 亚洲精品国产欧美| 欧美视频在线一区| 国产精品久久夜| 国产伦精品一区二区三区在线观看| 久久久久久91香蕉国产| 久久久国产一区二区三区| 国产精品久久| 欧美在线观看天堂一区二区三区| 亚洲国产精品第一区二区三区| 国产精品久久久久7777婷婷| 午夜精品在线看| 亚洲日本乱码在线观看| 久久久久**毛片大全| 新狼窝色av性久久久久久| 国产精品爱久久久久久久| 国色天香一区二区| 99国产欧美久久久精品| 欧美高清在线| 久久久久久久91| 日韩一区二区福利| 午夜精品视频在线| 亚洲免费av观看| 欧美在线一二三| 亚洲精品在线看| 亚洲国内在线| 午夜视频在线观看一区二区三区| 亚洲美女一区| 亚洲国产精品va| 亚洲一区二区三区精品视频| 伊人久久综合| 一本一本久久a久久精品综合妖精| 久久国产精品久久国产精品| 国产精品久久久久久久久久久久久| 国产香蕉久久精品综合网| 亚洲婷婷免费| 亚洲欧美色婷婷| 久久成人在线| 欧美视频在线观看| 欧美视频网站| 国产精品免费电影| 欧美紧缚bdsm在线视频| 日韩网站免费观看| 欧美人牲a欧美精品| 久久在线视频| 国产精品乱人伦一区二区| 国产精品久久久久久户外露出| 欧美1区2区3区| 9色porny自拍视频一区二区| 欧美国产激情二区三区| 国产精品久久777777毛茸茸| 91久久精品日日躁夜夜躁欧美| 韩国自拍一区| 欧美日韩国产三区| 久久亚洲午夜电影| 欧美日韩一区综合| 亚洲国产精品一区二区三区| 久久爱www久久做| 在线视频你懂得一区二区三区| 欧美激情黄色片| 国产精品萝li| 欧美私人网站| 欧美在线3区| 黄色综合网站| 一本色道久久综合亚洲精品高清| 亚洲精品一区二区网址| 久久精品视频一| 欧美色一级片| 一区二区三区高清| 亚洲午夜在线观看| 在线看日韩av| 亚洲精品国产拍免费91在线| 国产日韩欧美不卡| 亚洲伊人观看| 国产精品婷婷午夜在线观看| 国产精品激情偷乱一区二区∴| 激情欧美日韩| 亚洲视频视频在线| 欧美午夜精品久久久久久孕妇| 欧美日韩ab片| 影音先锋亚洲视频| 欧美激情欧美狂野欧美精品| 国产美女扒开尿口久久久| 欧美日韩精品免费在线观看视频| 久久久久久九九九九| 亚洲乱码精品一二三四区日韩在线| 国内精品久久国产| 免费成人激情视频| 欧美三区免费完整视频在线观看| 亚洲电影下载| 精品999在线播放| 国产精品一二三| 国产精品护士白丝一区av| 久久精品国产久精国产爱| 欧美三级电影网| 美女免费视频一区| 亚洲午夜影视影院在线观看| 欧美日韩国产影院| 一区二区三区欧美激情| 在线电影一区| 国产精品久久久91| 国产精品久久国产精品99gif| 欧美日韩一视频区二区| 久热精品视频在线观看一区| 在线日韩日本国产亚洲| 欧美成人精品一区二区| 国产精品久久久久久一区二区三区| 国产精品扒开腿做爽爽爽软件| 欧美成人亚洲| 国产一区再线| 欧美精品免费在线| 亚洲视频高清| 欧美成年人网| 国产日产亚洲精品| 亚洲欧美激情在线视频| 欧美精品一区二区三区在线播放| 亚洲人成在线播放网站岛国| 国产情侣一区| 91久久精品美女高潮| 国产伦精品一区二区三区四区免费| 亚洲高清视频一区| 在线国产精品播放| 欧美亚洲视频一区二区| 在线视频一区观看| 久久精品一区二区三区不卡| 欧美中日韩免费视频| 欧美日韩国产成人在线免费| 精品不卡一区二区三区| 亚洲午夜三级在线| 国产精品免费观看在线| 一色屋精品视频免费看| 欧美一区二区三区免费观看视频| 国产偷国产偷精品高清尤物| 久久免费的精品国产v∧| 亚洲午夜影视影院在线观看| 欧美裸体一区二区三区| 欧美日韩另类视频| 亚洲七七久久综合桃花剧情介绍| 欧美日韩二区三区| 午夜视频久久久久久| 久久综合色婷婷| 久久久久久999| 欧美精品久久一区二区| 欧美日韩在线播放三区| 国产精品一区二区你懂得| 欧美日韩一区二区三区免费| 亚洲福利视频网站| 久久久久国产一区二区三区四区| 韩国v欧美v日本v亚洲v| 亚洲伊人一本大道中文字幕| 蜜臀99久久精品久久久久久软件| 欧美激情国产精品| 国产精品美女久久久免费| 国语精品一区| 一本色道久久综合亚洲精品小说| 影音先锋日韩精品| 亚洲精品影院在线观看| 欧美一区二区高清| 精久久久久久久久久久| 欧美国产精品一区| 欧美亚洲成人免费| 国产精品视频九色porn| 99在线热播精品免费| 美乳少妇欧美精品| 久久黄金**| 久久深夜福利| 激情久久久久久久久久久久久久久久| 性欧美在线看片a免费观看| 欧美中文在线观看| 国内揄拍国内精品久久| 亚洲茄子视频| 亚洲国产欧美另类丝袜| 久久人人爽人人爽爽久久| 亚洲日本成人网| 久久国产精品99国产| 欧美日韩在线三级| 亚洲女与黑人做爰| 欧美一级在线视频| 亚洲黄一区二区三区| 国产精品亚洲一区二区三区在线| 国产精品专区第二| 国产欧美视频在线观看| 久久婷婷影院| 亚洲一区二区三区国产| 日韩午夜av| 欧美日韩国产一区二区三区| 国产精品久久久久久久久久久久| 国产精品成人午夜| 亚洲视频免费观看|