《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > 從零開始走進FPGA LCD1602 Hello World

從零開始走進FPGA LCD1602 Hello World

2015-05-29
關鍵詞: FPGA 數組 LCD1602 代碼

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

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

  一、驅動說明

  由于" style="outline-style: none; color: rgb(51, 51, 51); text-decoration: none;">FPGA的高速并行操作,并非順序執行,在代碼上與MCU有所不同。此處先講解驅動原理:

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

  

wps_clip_image-31116

 

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

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

  二、 LCD1602 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如下所示:

  

wps_clip_image-31119

 

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

  

image

 

  3. “Hello World”實物顯示

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

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


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          宅男66日本亚洲欧美视频| 性色av一区二区三区| 久久亚洲精品网站| 欧美午夜理伦三级在线观看| 欧美中文字幕久久| 久久午夜激情| 欧美日韩一二三区| 免费成人性网站| 欧美激情视频在线免费观看 欧美视频免费一| 国模私拍视频一区| 在线观看亚洲视频啊啊啊啊| 一本一本a久久| 免费观看30秒视频久久| 亚洲韩国精品一区| 好男人免费精品视频| 美女啪啪无遮挡免费久久网站| 欧美三级午夜理伦三级中视频| 狂野欧美激情性xxxx欧美| 久久久久五月天| 国产欧美日韩精品专区| 亚洲日韩欧美一区二区在线| 国产九九精品视频| 性伦欧美刺激片在线观看| 亚洲精品久久久久中文字幕欢迎你| 国产日韩高清一区二区三区在线| 亚洲免费视频成人| 美女国内精品自产拍在线播放| 麻豆成人综合网| 国产精品久久久久免费a∨大胸| 欧美日韩高清在线播放| 久久久噜久噜久久综合| 国产亚洲欧洲997久久综合| 在线观看成人av| 欧美一区二区三区四区在线| 国产精品美女视频网站| 亚洲国产人成综合网站| 国产真实乱偷精品视频免| 久久综合网hezyo| 在线播放精品| 一区二区三区在线视频播放| 亚洲精品国产拍免费91在线| 久久综合久色欧美综合狠狠| 久久一区视频| 亚洲一区二区三区精品在线观看| 午夜在线电影亚洲一区| 欧美特黄视频| 99re亚洲国产精品| 国产一区二区av| 欧美午夜在线一二页| 欧美国产日本韩| 欧美先锋影音| 亚洲专区在线| 久热综合在线亚洲精品| 性做久久久久久久久| 亚洲午夜av电影| 欧美多人爱爱视频网站| 亚洲视频在线看| 欧美大学生性色视频| 亚洲视频国产视频| 欧美阿v一级看视频| 国内精品一区二区| 亚洲自拍偷拍一区| 在线观看91精品国产麻豆| 国产有码一区二区| 麻豆精品一区二区av白丝在线| 国产精品a久久久久| 亚洲国产日韩一区二区| 久久人人爽国产| 国产欧美婷婷中文| 久久精品国产综合精品| 亚洲欧美日韩在线| 欧美激情乱人伦| 另类激情亚洲| 久久免费99精品久久久久久| 免费日韩av片| 亚洲精选视频免费看| 欧美精品少妇一区二区三区| 欧美成人激情视频免费观看| 国产综合一区二区| 在线日韩中文| 国产精品欧美风情| 亚洲自拍16p| 136国产福利精品导航网址| 国内久久视频| 欧美一区二区日韩| 国产日韩欧美综合在线| 欧美成人午夜免费视在线看片| 激情欧美日韩| 国产偷久久久精品专区| 欧美国产一区二区三区激情无套| 久久精品国产99国产精品澳门| 国产日韩欧美二区| 亚洲欧洲精品一区二区精品久久久| 亚洲精品综合| 欧美午夜精彩| 国产日韩欧美在线视频观看| 欧美久色视频| 欧美激情日韩| 国产精品人成在线观看免费| 久久av资源网| 亚洲精品视频在线观看免费| 久久人体大胆视频| 亚洲精品一区二区三区av| 欧美人与禽猛交乱配| 一区二区欧美精品| 亚洲国产欧美精品| 久久久久高清| 亚洲欧美bt| 国产精品男gay被猛男狂揉视频| 午夜精品久久久久久久久久久久久| 国模精品一区二区三区| 亚洲国产精品成人久久综合一区| 欧美精品高清视频| 亚洲国产一区二区精品专区| 久久精品视频播放| 亚洲国产精品一区二区第一页| 欧美尤物巨大精品爽| 亚洲精品一区二区在线| 国产精品国产亚洲精品看不卡15| 亚洲片在线观看| 国产日韩1区| 亚洲美女淫视频| 一区二区亚洲精品| 欧美日韩精品在线播放| 国产精品久久久久久五月尺| 91久久综合| 久久久亚洲国产天美传媒修理工| 精品88久久久久88久久久| 国产一区av在线| 久久狠狠婷婷| 最新精品在线| 亚洲美女免费精品视频在线观看| 亚洲丶国产丶欧美一区二区三区| 久久精品一区二区三区不卡| 欧美中文字幕视频在线观看| 韩国成人理伦片免费播放| 欧美人与禽猛交乱配| 欧美一区二区三区四区在线观看| 亚洲永久字幕| 国产欧美高清| 国模套图日韩精品一区二区| 亚洲欧洲一区二区三区| 美国十次了思思久久精品导航| 99pao成人国产永久免费视频| 欧美久久久久久蜜桃| 欧美日本一区二区高清播放视频| 国内自拍一区| 一区二区视频欧美| 久久视频在线视频| 亚洲人成网站精品片在线观看| 欧美日韩在线精品一区二区三区| 一区二区国产日产| 狠狠色综合播放一区二区| 国产亚洲制服色| 国产日韩在线一区二区三区| 午夜在线精品| 欧美亚洲网站| 国产精品盗摄久久久| 香蕉成人伊视频在线观看| 欧美午夜精彩| 国产精品免费看久久久香蕉| 亚洲综合99| 在线视频欧美日韩精品| 国产精品专区一| 免费成人高清视频| 亚洲电影视频在线| 久久久久久久性| 亚洲一区二区在线视频| 国产精品久久二区二区| 宅男噜噜噜66一区二区| 亚洲欧美在线观看| 一区二区三区久久网| 在线观看中文字幕不卡| 在线观看欧美日本| 久久久久久伊人| 国产精品婷婷午夜在线观看| 久久久亚洲精品一区二区三区| 亚洲福利视频二区| 欧美大片第1页| 国产一区99| 亚洲欧洲在线观看| 久久精品首页| 亚洲精品日韩激情在线电影| 日韩网站在线看片你懂的| 性欧美1819性猛交| 亚洲激情av在线| 免播放器亚洲一区| 一区二区三区高清在线观看| 久久噜噜亚洲综合| 一本大道久久a久久精品综合| 国产欧美1区2区3区| 99视频热这里只有精品免费| 亚洲黄色成人网| 欧美日韩亚洲国产精品| 日韩视频在线观看国产| 亚洲少妇一区| 国产精品毛片大码女人| 狠狠久久综合婷婷不卡| 午夜精品久久久久影视| 亚洲国产成人porn| 亚洲电影免费在线| 久久免费精品日本久久中文字幕| 欧美日韩精品欧美日韩精品| 91久久国产综合久久| 开元免费观看欧美电视剧网站| 亚洲自拍三区| 99国产一区二区三精品乱码| 欧美日韩午夜视频在线观看| 亚洲一区二区在线视频| 国产色产综合产在线视频| 欧美一区国产在线| 一区二区在线视频播放| 激情国产一区二区| 欧美成人官网二区| 国产精品国产三级国产普通话蜜臀| 欧美日韩免费在线视频| 亚洲美女一区| 在线视频欧美日韩精品| 欧美日韩网址| 国产精品网站在线观看| 亚洲视频在线观看| 欧美日韩国产综合在线| 久久久欧美一区二区| 免费在线播放第一区高清av| 欧美精品日韩| 亚洲大片一区二区三区| 亚洲亚洲精品三区日韩精品在线视频| 亚洲黄色三级| 亚洲图片欧美一区| 亚洲免费电影在线| 国产精品久久久久久久久果冻传媒| 精品成人久久| 久久精品在线播放| 亚洲一区国产视频| 黄色精品在线看| 国产精品免费一区二区三区观看| 在线日韩中文| 国产精品国产自产拍高清av王其| 欧美精品一区在线| 久久精品中文字幕一区二区三区| 激情六月综合| 日韩亚洲精品电影| 9色porny自拍视频一区二区| 国产精品久久久久久久浪潮网站| 亚洲一区成人| 亚洲成人在线免费| 亚洲一区区二区| 久久中文字幕一区二区三区| 久久av一区二区三区亚洲| 欧美精品一级| 久久av红桃一区二区小说| 欧美日韩中国免费专区在线看| 欧美亚洲色图校园春色| 免费观看亚洲视频大全| 亚洲一区在线观看免费观看电影高清| 亚洲理论在线观看| 狂野欧美激情性xxxx欧美| 欧美日本精品在线| 欧美在线三区| 国产婷婷一区二区| 欧美精品国产精品日韩精品| 日韩午夜激情av| 亚洲欧美一区二区三区久久| 好吊成人免视频| 欧美日韩一二三四五区| 亚洲综合色噜噜狠狠| 激情文学一区| 久久不见久久见免费视频1| 国产精品成人观看视频国产奇米| 欧美日本不卡高清| 亚洲第一视频| 欧美.日韩.国产.一区.二区| 午夜精品久久久久久久蜜桃app| 国产一区美女| 欧美系列电影免费观看| 久久久久久自在自线| 欧美成人精品一区二区| 国产资源精品在线观看| 久久久久久精| 国产精品h在线观看| 亚洲视频第一页| 欧美女同视频| 一区二区三区不卡视频在线观看| 国产日本欧美一区二区| 国产伦精品一区二区三区四区免费| 国产一区二区在线观看免费播放| 日韩亚洲国产欧美| 欧美激情 亚洲a∨综合| 欧美伊人精品成人久久综合97| 欧美另类专区| 久久精品视频在线播放| 亚洲国产精品一区二区第一页| 久久视频精品在线| 一本一道久久综合狠狠老精东影业| 欧美国产日韩精品免费观看| 国产欧美日韩一区二区三区在线| 国产精品亚洲片夜色在线| 国产精品成人一区二区艾草| 亚洲精品自在在线观看| 亚洲精品视频在线观看网站| 黄色工厂这里只有精品| 国产片一区二区| 国产亚洲欧洲| 亚洲一二三级电影| 在线电影国产精品| 亚洲三级观看| 久久在精品线影院精品国产| 欧美伊人久久久久久午夜久久久久| 蜜桃av噜噜一区| 亚洲开发第一视频在线播放| 欧美一区二区三区四区在线| 亚洲深夜激情| 欧美涩涩网站| 国产精品每日更新在线播放网址| 亚洲伊人一本大道中文字幕| 国产精品99久久99久久久二8| 欧美日韩精品福利| 欧美猛交免费看| 国产区日韩欧美| 国产精品夜色7777狼人| 国产日韩欧美在线看| 国产婷婷一区二区| 国产精品夜夜嗨| 国产日韩欧美二区| 亚洲在线免费观看| 麻豆91精品| 狠狠色伊人亚洲综合成人| 久久亚洲视频|