亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? lcm240128zk03_interface.v

?? 青云開發的LCD模塊LCM240128ZK3用于ALTERA的FPGA
?? V
字號:
/****************************************Copyright (c)**************************************************
**                               張敏 西北核技術研究所一室 2008
**
**--------------File Info-------------------------------------------------------------------------------
** File name:			lcm240128zk03.v
** Last modified Date:	2008-7-26
** Last Version:		1.0
** Descriptions:		lcm240128zk03控制邏輯
**------------------------------------------------------------------------------------------------------
** Created by:			張敏 西北核技術研究所一室
** Created date:		2008-7-26
** Version:				1.0
** Descriptions:		The original version
**
**------------------------------------------------------------------------------------------------------
** Modified by:			
** Modified date:		
** Version:				
** Descriptions:		
**
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/

module lcm240128zk03_interface(
	//模塊輸入
	clk,
	reset_n,
	lcd_int,
	chipselect,
	read,
	write,
	lcd_busy,
	address,
	writedata,
	
	//模塊輸出
	lcd_rs,
	lcd_rw,
	lcd_en,
	lcd_cs1,
	lcd_cs2,
	lcd_rst,
	irq,		//LCD 中斷信號
	readdata,
	lcd_data	//lcd 數據線
	
	);

//Inputs
input clk;			//Input Clock
input reset_n;		//Reset
input lcd_int;		//lcd 中斷
input chipselect;	//Avalon Chip select signal
input read;			//Avalon read
input write;		//Avalon read signal
input lcd_busy;		//lcd busy
input [1:0] address;//Avalon Address bus 
input [7:0] writedata;//Avalon ritedata
	

//Outputs
output lcd_rs;			//lcd 指令、數據控線
output lcd_rw;			//lcd 讀寫線
output lcd_en;			//lcd 使能線
output lcd_cs1;			//lcd cs1
output lcd_cs2;			//lcd cs2
output lcd_rst;			//lcd rst
output irq;				//lcd 中斷
output reg [7:0] readdata;	//IP的輸出,LCD寄存器的值

//inout
inout reg [7:0]	lcd_data;//lcd 數據線

//中間寄存器聲明
reg lcd_rs_r;			//lcd rs
reg lcd_rw_r;			//lcd rw
reg lcd_en_r;			//lcd en
reg lcd_rst_r;			//lcd rst
reg [10:0] timecount;	//狀態機狀態變量
	
//寄存器輸出
assign irq = lcd_int;	//直接將LCD中斷向上報告
assign lcd_cs1 = 1'h0;	//直接將LCD cs1 置0
assign lcd_cs2 = 1'h1;	//直接將LCD cs2 置1

assign lcd_rs = lcd_rs_r;
assign lcd_rw = lcd_rw_r;
assign lcd_en = lcd_en_r;
assign lcd_rst = lcd_rst_r;

//初始化狀態
initial
begin
	readdata<=8'h0;
	lcd_rs_r<= 1'h1;
	lcd_rw_r<= 1'h1;
	lcd_en_r<= 1'h0;
	lcd_rst_r<= 1'h1;
	lcd_data<=8'h0;
	timecount = 10'h0;
	
end

//合成讀、寫控制
wire	read_act;
assign	read_act  = chipselect & read;
wire	write_act;
assign	write_act  = chipselect & write &!lcd_busy;


parameter tcntwritemax = 10'h37;//寫LCD比較耗時,一般需要用到55個時鐘周期約550ns
//write and read
always @(posedge clk )
begin
	if (write_act && !read_act)//AVALON 寫數據
	begin
		case (address)
			2'h0:		//寫指令
			begin
			/*
  LCD_ChkBusy();	//Call LCD_ChkBusy to Check Busy Bit
  LCD_Command = Cmd_Data;
  P2 = 0x91;
  EN = 1;
  _nop_();
  EN = 0;
  P2 = 0x93;
			*/
				if(timecount==10'h0)//首先配置RS、RW,輸出數據
				begin
					lcd_rs_r<= 1;//指令
					lcd_rw_r<= 0;//寫入
					lcd_data<=writedata;//將指令輸出到LCD的數據線
				end
				else if(timecount==10'h8)//第8個時鐘周期輸出lcd的enable高電平,以100M計地址、數據的建立時間約80ns,符合63ns的最小要求
				begin
					lcd_en_r<= 1;
				end
				else if(timecount==10'h35)//0x35=53輸出lcd的enable低電平,以100M計地址、enable的脈寬約450ns,符合400ns的最小要求
				begin
					lcd_en_r<= 0;
				end
				else if(timecount==10'h37)//0x37=55可以拆消地址和數據了,以100M計地址、數據的保持時間約20ns,符合10ns的最小要求,至此寫數據就已經完成了
				begin
					lcd_rs_r<= 1;//指令
					lcd_rw_r<= 1;//讀入
					lcd_data<=8'h0;//將LCD的數據線置0
				end
				else if(timecount>=10'h0 && timecount<=tcntwritemax)
				begin
				end
				else
				begin
					readdata<=8'h0;
					lcd_rs_r<= 1'h1;
					lcd_rw_r<= 1'h1;
					lcd_en_r<= 1'h0;
					lcd_data<=8'h0;
					timecount = 10'h0;
				end
    			if(timecount<=tcntwritemax&&timecount>=0)  begin  timecount = timecount+1;  end
				else  begin  timecount =0; end
			end
			
			2'h1:		//寫數據
			begin
			/*
   LCD_ChkBusy();							//Call LCD_ChkBusy to Check Busy Bit
   LCD_Data = Data_Data;
   P2 = (0x90);
   EN = 1;
   _nop_();
   EN = 0;
   P2 = (0x93);
			*/
				if(timecount==10'h0)//首先拉低RS、RW,輸出數據
				begin
					lcd_rs_r<= 0;//數據
					lcd_rw_r<= 0;//寫入
					lcd_data<=writedata;//將數據輸出到LCD的數據線
				end
				else if(timecount==10'h8)//第8個時鐘周期輸出lcd的enable高電平,以100M計地址、數據的建立時間約80ns,符合63ns的最小要求
				begin
					lcd_en_r<= 1;
				end
				else if(timecount==10'h35)//0x35=53輸出lcd的enable低電平,以100M計地址、enable的脈寬約450ns,符合400ns的最小要求
				begin
					lcd_en_r<= 0;
				end
				else if(timecount==10'h37)//0x37=55可以拆消地址和數據了,以100M計地址、數據的保持時間約20ns,符合10ns的最小要求,至此寫數據就已經完成了
				begin
					lcd_rs_r<= 1;//指令
					lcd_rw_r<= 1;//讀入
					lcd_data<=8'h0;//將LCD的數據線置0
				end
				else if(timecount>=10'h0 && timecount<=tcntwritemax)
				begin
				end
				else
				begin
					readdata<=8'h0;
					lcd_rs_r<= 1'h1;
					lcd_rw_r<= 1'h1;
					lcd_en_r<= 1'h0;
					lcd_data<=8'h0;
					timecount = 10'h0;
				end
    			if(timecount<=tcntwritemax&&timecount>=0)  begin  timecount = timecount+1;  end
				else  begin  timecount =0; end
			end
			
			2'h2:		//重啟LCK,由于RESET時延要求100ms ,過長,無法由硬件產生這么長的時序,改由上層軟件分兩次控制
			begin
				//使用方法為:RESET_LCM240128(base,0),100ms后再RESET_LCM240128(base,1)
				lcd_rst_r <= writedata[0];
			end
			
			default:	//非法地址,將各路信號置為默認狀態
			begin
				//readdata<=8'h0;
				lcd_rs_r<= 1'h1;
				lcd_rw_r<= 1'h1;
				lcd_en_r<= 1'h0;
				lcd_data<=8'h0;
				timecount = 10'h0;
			end
		endcase
	end if (read_act && !write_act)//AVALON 讀數據,讀數據只用0個等待周期
	begin
		case (address)
			2'h0:		//讀指令
			begin//未用到,返回0
				readdata <= 8'h0;
			end
			
			2'h1:		//讀數據
			begin//未用到,返回0
				readdata <= 8'h0;
			end
			
			2'h2:		//讀取LCD的BUSY情況
			begin
				//使用方法為:CHECK_BUSY_LCM240128(base)
				readdata <= {7'h0,lcd_busy};
			end
			
			default:	//非法地址,將各路信號置為默認狀態
			begin
				readdata<=8'h0;
				lcd_rs_r<= 1'h1;
				lcd_rw_r<= 1'h1;
				lcd_en_r<= 1'h0;
				lcd_data<=8'h0;
				timecount = 10'h0;
			end
		endcase
	end
	else if(lcd_busy)//如果處于忙碌狀態,則跳過此次操作,嚴格來講,應該是busy只影響寫操作
	begin
	
	end
	else//非讀、非寫、非忙時,將各路信號置為默認狀態
	begin
			readdata<=8'h0;
			lcd_rs_r<= 1'h1;
			lcd_rw_r<= 1'h1;
			lcd_en_r<= 1'h0;
			lcd_data<=8'h0;
			timecount = 10'h0;
	end
end



endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩av在线免费观看不卡| 亚洲男人都懂的| 国产精品免费人成网站| 图片区日韩欧美亚洲| 国产电影一区二区三区| 欧美日韩激情在线| 中文字幕中文乱码欧美一区二区 | 国产精华液一区二区三区| 在线观看免费亚洲| 日韩一区欧美小说| 国产成人精品免费一区二区| 日韩欧美国产1| 视频一区视频二区中文| 在线观看成人小视频| 最新不卡av在线| 高清不卡在线观看av| 精品久久国产字幕高潮| 青草国产精品久久久久久| 欧美日韩成人一区| 亚洲福中文字幕伊人影院| 色成年激情久久综合| 中文字幕在线观看不卡| 播五月开心婷婷综合| 国产日韩精品一区二区三区在线| 久久66热偷产精品| 欧美成人福利视频| 国产一区二区视频在线播放| 日韩欧美一区电影| 国内国产精品久久| 亚洲精品一区二区三区精华液| 麻豆freexxxx性91精品| 欧美成人精品高清在线播放| 久久99国内精品| 久久九九久精品国产免费直播| 精品亚洲国产成人av制服丝袜| 久久亚洲一级片| 成人免费看的视频| 亚洲精品网站在线观看| 在线观看国产91| 日本不卡的三区四区五区| 欧美一区欧美二区| 国产伦精品一区二区三区在线观看| 久久久久国产精品厨房| 床上的激情91.| 一区二区久久久久久| 欧美欧美欧美欧美首页| 久久99精品国产麻豆婷婷洗澡| 国产日韩视频一区二区三区| 91小视频在线观看| 婷婷国产在线综合| 久久久精品人体av艺术| 91视视频在线观看入口直接观看www | 欧美一区二区三区四区久久| 奇米777欧美一区二区| 26uuu久久综合| 97精品视频在线观看自产线路二| 洋洋av久久久久久久一区| 91精品在线观看入口| 国产精品白丝av| 亚洲综合成人网| 精品国产亚洲在线| 91麻豆.com| 国产一区二区日韩精品| 亚洲欧美日韩一区二区| 欧美一区二区三区四区高清 | 国产精品毛片高清在线完整版| 91猫先生在线| 日韩成人午夜电影| 国产精品看片你懂得| 4438成人网| 不卡影院免费观看| 美女任你摸久久| 亚洲视频在线一区二区| 日韩欧美国产午夜精品| 色综合久久九月婷婷色综合| 久久精品国产一区二区三| 亚洲视频精选在线| 久久久久国产一区二区三区四区 | 午夜精品福利在线| 国产精品乱人伦| 欧美成人精品3d动漫h| 欧美三级电影精品| 99久久精品99国产精品| 激情六月婷婷综合| 午夜精品福利一区二区蜜股av| 国产精品嫩草影院com| 精品国精品自拍自在线| 欧美体内she精视频| 99久久久久久| 国产成人亚洲精品狼色在线| 奇米色一区二区| 五月婷婷欧美视频| 一区2区3区在线看| 最好看的中文字幕久久| 亚洲国产精品黑人久久久| 久久综合九色综合97婷婷| 日韩欧美国产高清| 56国语精品自产拍在线观看| 色素色在线综合| 91丨九色porny丨蝌蚪| 成人动漫中文字幕| 成人不卡免费av| 成人亚洲精品久久久久软件| 国产一区二区三区黄视频| 精品中文字幕一区二区小辣椒| 秋霞影院一区二区| 日韩黄色小视频| 免费一级欧美片在线观看| 日本强好片久久久久久aaa| 午夜精品免费在线观看| 日本亚洲欧美天堂免费| 免费成人av资源网| 美女mm1313爽爽久久久蜜臀| 美女视频黄免费的久久| 国产麻豆午夜三级精品| 国产激情一区二区三区四区 | 国内精品免费**视频| 国产在线国偷精品免费看| 国产在线看一区| 粉嫩av亚洲一区二区图片| 成熟亚洲日本毛茸茸凸凹| www.日韩大片| 色婷婷久久久综合中文字幕| 欧美性生交片4| 欧美一区二区三区免费大片| 欧美电视剧免费观看| 久久精品在线免费观看| 久久精品亚洲国产奇米99| 国产精品电影一区二区三区| 一区二区三区中文在线观看| 性做久久久久久| 精品在线观看视频| bt欧美亚洲午夜电影天堂| 欧美亚洲愉拍一区二区| 日韩欧美国产麻豆| 国产精品美女久久久久aⅴ| 一区二区三区小说| 日韩高清一区在线| 国产成人精品免费在线| 色综合久久88色综合天天6| 欧美一区二区三区思思人| 日韩毛片高清在线播放| 午夜精品一区二区三区电影天堂| 国产一区二区三区不卡在线观看| 91猫先生在线| 久久综合九色综合久久久精品综合 | 免费不卡在线观看| 成人涩涩免费视频| 欧美精选午夜久久久乱码6080| 精品国产乱子伦一区| 亚洲美女屁股眼交3| 美女视频一区在线观看| 色婷婷综合久久久久中文| 欧美xxxxx裸体时装秀| 亚洲女与黑人做爰| 激情综合亚洲精品| 欧美色视频在线观看| 欧美激情在线免费观看| 石原莉奈在线亚洲三区| 99久久免费视频.com| 26uuu精品一区二区| 午夜av一区二区| 99精品视频一区二区| 2023国产精品| 视频一区在线播放| 91久久国产综合久久| 欧美高清在线一区二区| 蜜臀av一区二区在线免费观看| 色噜噜久久综合| 中文子幕无线码一区tr| 极品少妇xxxx偷拍精品少妇| 欧美日本一区二区三区四区| 亚洲视频 欧洲视频| 国产毛片精品视频| 欧美成人免费网站| 日本欧洲一区二区| 欧美日韩大陆在线| 亚洲男人都懂的| 91亚洲精品久久久蜜桃网站| 欧美韩国日本不卡| 国产一区二区免费视频| 日韩精品资源二区在线| 五月天视频一区| 欧美日韩一级片在线观看| 一区二区三区中文字幕在线观看| 99re亚洲国产精品| 国产精品高潮呻吟| 成人激情免费网站| 亚洲欧洲三级电影| 不卡影院免费观看| 亚洲三级在线播放| 91视频精品在这里| 亚洲免费观看高清完整版在线观看熊 | 综合激情成人伊人| 99国产精品国产精品毛片| 中文字幕不卡三区| 99精品国产一区二区三区不卡| 国产精品福利电影一区二区三区四区| 国产激情一区二区三区| 国产精品免费视频观看|