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

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

?? 220model.v

?? 這是基于s3c2410+uCos的LCD驅動程序源碼
?? V
?? 第 1 頁 / 共 5 頁
字號:

		
  always @(posedge inclock)
	begin
	  if((lpm_indata === "REGISTERED") && (lpm_address_control === "REGISTERED"))
	  begin
		paddress <= address;
		pdata <= data;
		pwe <= we;
	  end
	  else
	  begin
		if((lpm_indata === "REGISTERED") && (lpm_address_control === "UNREGISTERED"))
			pdata <= data;

		if((lpm_indata === "UNREGISTERED") && (lpm_address_control === "REGISTERED"))
		begin
			paddress <= address;
			pwe <= we;
		end
	  end
	end

  always @(data)
	begin
	  if(lpm_indata === "UNREGISTERED")
		pdata <= data;
	end
	
  always @(address)
  begin
	if(lpm_address_control === "UNREGISTERED")
		paddress <= address;
  end
	
  always @(we)
  begin
	if(lpm_address_control === "UNREGISTERED")
		pwe <= we;
  end
	
  always @( pdata or paddress or pwe )
	begin :unregistered_inclock
		if(ValidAddress(paddress))
		begin
			if((lpm_indata === "UNREGISTERED" && lpm_address_control === "UNREGISTERED") || (lpm_address_control === "UNREGISTERED"))
			begin
				if (pwe)
					mem_data[paddress] <= pdata ;
			end

		end
		else
		begin
			if(lpm_outdata === "UNREGISTERED")
				tmp_q <= UNKNOWN ;
		end
	end

  always @(posedge outclock )
	begin
		if(lpm_outdata === "REGISTERED")
		begin
			if(ValidAddress(paddress))
				tmp_q <= mem_data[paddress] ;
			else
				tmp_q <= UNKNOWN ;
		end
	end
 
  always @(negedge inclock )
	begin
		if (lpm_address_control === "REGISTERED")
		begin
			if (pwe)
				mem_data[paddress] <= pdata;
		end
	end

  assign q = ( lpm_outdata === "UNREGISTERED" ) ? mem_data[paddress] : tmp_q ;

endmodule // lpm_ram_dq
 
//------------------------------------------------------------------------

module lpm_ram_dp ( q, data, wraddress, rdaddress, rdclock, wrclock, rdclken, wrclken, rden, wren) ;

  parameter lpm_type = "lpm_ram_dp" ;
  parameter lpm_width = 1 ;
  parameter lpm_widthad = 1 ;
  parameter lpm_numwords = 1<< lpm_widthad ;
  parameter lpm_indata = "REGISTERED" ;
  parameter lpm_outdata = "REGISTERED" ;
  parameter lpm_rdaddress_control  = "REGISTERED" ;
  parameter lpm_wraddress_control  = "REGISTERED" ;
  parameter lpm_file = "UNUSED" ;
  parameter lpm_hint = "UNUSED" ;

  input  [lpm_width-1:0] data ;
  input  [lpm_widthad-1:0] rdaddress, wraddress ;
  input  rdclock, wrclock, rdclken, wrclken, rden, wren ;
  output [lpm_width-1:0] q;


  // internal reg 
  reg   [lpm_width-1:0] mem_data [lpm_numwords-1:0];
  reg   [lpm_width-1:0] tmp_q ;
  reg   [lpm_width-1:0] prev_q ;
  reg   [lpm_width-1:0] new_data ;
  reg   [lpm_widthad-1:0] new_raddress ;
  reg   [lpm_widthad-1:0] new_wraddress ;
  reg   wren_event, rden_event;
  reg   [lpm_width-1:0]  ZEROS, UNKNOWN ;
  reg [8*256:1] ram_initf ;
  integer i ;

  function ValidAddress ;
	input [lpm_widthad-1:0] paddress ;
	begin
		ValidAddress = 1'b0 ;
		if(^paddress ==='bx)
			$display("%d:Error! Invalid address.\n", $time) ;
		else if(paddress >= lpm_numwords)
			$display("%d:Error! Address out of bound on RAM.\n", $time) ;
		else
			ValidAddress = 1'b1 ;
	end
  endfunction
		
  initial
  begin

	// Initialize the internal data register.
	new_data = 0;
	new_raddress = 0;
	new_wraddress = 0;
	wren_event = 0;
	tmp_q = 0;

	if(lpm_width <= 0)
		$display("Error! lpm_width parameter must be greater than 0.");

	if(lpm_widthad <= 0)
		$display("Error! lpm_widthad parameter must be greater than 0.");
	// check for number of words out of bound
	if((lpm_numwords > (1 << lpm_widthad))
		||(lpm_numwords <= (1 << (lpm_widthad-1))))
	begin
		$display("Error! lpm_numwords must equal to the ceiling of log2(lpm_widthad).");
 
	end
 
	if((lpm_indata !== "REGISTERED") && (lpm_indata !== "UNREGISTERED"))
	begin
	$display("Error! lpm_indata must be REGISTERED (the default) or UNREGISTERED.");
	end
	
	if((lpm_rdaddress_control !== "REGISTERED") && (lpm_rdaddress_control !== "UNREGISTERED"))
	begin
		$display("Error! lpm_rdaddress_control must be REGISTERED (the default) or UNREGISTERED.");
	end
	
	if((lpm_wraddress_control !== "REGISTERED") && (lpm_wraddress_control !== "UNREGISTERED"))
	begin
		$display("Error! lpm_wraddress_control must be REGISTERED (the default) or UNREGISTERED.");
	end
	
	if((lpm_outdata !== "REGISTERED") && (lpm_outdata !== "UNREGISTERED"))
	begin
		$display("Error! lpm_outdata must be REGISTERED (the default) or UNREGISTERED.");
	end  

	// check if lpm_indata or lpm_wraddress_control is set to registered
	// wrclock and wrclken must be used.
	if(((lpm_indata === "REGISTERED") || (lpm_wraddress_control === "REGISTERED")) && ((wrclock === 1'bz) || (wrclken == 1'bz)))
	begin
		$display("Error! wrclock = 1'bz. wrclock and wrclken pins must be used.\n");
	end

	// check if lpm_rdaddress_control is set to registered
	// rdclock and rdclken must be used.
	if((lpm_rdaddress_control === "REGISTERED") && ((rdclock === 1'bz) || (rdclken == 1'bz)))
	begin
		$display("Error! rdclock = 1'bz. rdclock and rdclken pins must be used.\n");
	end

	// check if lpm_outdata, rdclock must be used
	if((lpm_outdata === "REGISTERED") && (rdclock === 1'bz))
	begin
		$display("Error! lpm_outdata = REGISTERED, rdclock = 1'bz . rdclock pnd rdclken pins must be used.\n");
	end

	for(i=0; i < lpm_width; i=i+1)
	begin
		ZEROS[i] = 1'b0 ;
		UNKNOWN[i] = 1'bX ;
	end 
	
	for(i = 0; i < lpm_numwords; i=i+1)
		mem_data[i] = ZEROS ;

	// load data to the RAM
	if(lpm_file != "UNUSED")
	begin
		$convert_hex2ver(lpm_file, lpm_width, ram_initf);
		$readmemh(ram_initf, mem_data);
	end 

  end

		
  always @(posedge wrclock)
	begin
	if (wrclken)
		begin
	  if((lpm_indata === "REGISTERED") && (lpm_wraddress_control === "REGISTERED"))
	  begin
		new_wraddress <= wraddress;
		new_data <= data;
		wren_event <= wren;
	  end
	  else
	  begin
		if((lpm_indata === "REGISTERED") && (lpm_wraddress_control === "UNREGISTERED"))
			new_data <= data;

		if((lpm_indata === "UNREGISTERED") && (lpm_wraddress_control === "REGISTERED"))
		begin
			new_wraddress <= wraddress;
			wren_event <= wren;
		end
	  end
	end
	end


  always @(data)
	begin
	  if(lpm_indata === "UNREGISTERED")
		new_data <= data;
	end
	
  always @(wraddress)
  begin
	if(lpm_wraddress_control === "UNREGISTERED")
		new_wraddress <= wraddress;
  end

  always @(rdaddress)
  begin
	if(lpm_rdaddress_control === "UNREGISTERED")
		new_raddress <= rdaddress;
  end
	
  always @(wren)
  begin
	if(lpm_wraddress_control === "UNREGISTERED")
		wren_event <= wren;
  end

  always @(rden)
  begin
	if(lpm_rdaddress_control === "UNREGISTERED")
		rden_event <= rden;
  end
	
  always @( new_data or new_wraddress or wren_event )
	begin 
		if(ValidAddress(new_wraddress))
		begin
				if ((wren_event) && (wrclken))
				mem_data[new_wraddress] <= new_data ;
		end
		else
		begin
			if(lpm_outdata === "UNREGISTERED")
				tmp_q <= UNKNOWN ;
		end
	end

  always @(posedge rdclock)
	begin
				if(lpm_rdaddress_control == "REGISTERED")
				if (rdclken)
		begin
						new_raddress <= rdaddress;
			rden_event <= rden;
		end
		if(lpm_outdata === "REGISTERED")
		begin
						if ((rdclken) && (rden_event))
						begin
			if(ValidAddress(new_raddress))
			begin
				tmp_q <= mem_data[new_raddress] ;
			end
			else
				tmp_q <= UNKNOWN ;
			
						end
		end
	end
 
  //assign q = ( lpm_outdata === "UNREGISTERED" ) ? mem_data[new_raddress] : tmp_q ;

  always @( mem_data[new_raddress] or tmp_q or rden )
	begin
		if (rden || lpm_outdata === "REGISTERED")
			prev_q <= ( lpm_outdata === "UNREGISTERED" ) ? mem_data[new_raddress] : tmp_q ;
	end

  assign q = prev_q;

endmodule // lpm_ram_dp

//------------------------------------------------------------------------

module lpm_ram_io ( dio, inclock, outclock, we, memenab, outenab, address ) ;

  parameter lpm_type = "lpm_ram_io" ;
  parameter lpm_width = 1 ;
  parameter lpm_widthad = 1 ;
  parameter lpm_numwords = 1<< lpm_widthad ;
  parameter lpm_indata = "REGISTERED" ;
  parameter lpm_address_control = "REGISTERED" ;
  parameter lpm_outdata = "REGISTERED" ;
  parameter lpm_file = "UNUSED" ;
  parameter lpm_hint = "UNUSED" ;

  input  [lpm_widthad-1:0] address ;
  input  inclock, outclock, we ;
  input  memenab ;
  input  outenab ;
  inout  [lpm_width-1:0] dio ;


  // inernal reg 
  reg   [lpm_width-1:0] mem_data [lpm_numwords-1:0];
  reg   [lpm_width-1:0] tmp_io ;
  reg   [lpm_width-1:0] tmp_q ;
  reg   [lpm_width-1:0] pdio ;
  reg   [lpm_widthad-1:0] paddress ;
  reg   pwe ;
  reg   [lpm_width-1:0] ZEROS, UNKNOWN, HiZ ;
  reg   [8*256:1] ram_initf ;
  integer i ;

  function ValidAddress ;
	input [lpm_widthad-1:0] paddress ;
	begin
		ValidAddress = 1'b0 ;
		if(^paddress ==='bx)
			$display("%d:Error: Invalid address.", $time) ;
		else if(paddress >= lpm_numwords)
			$display("%d:Error: Address out of bound on RAM.", $time) ;
		else
			ValidAddress = 1'b1 ;
	end
  endfunction
		
  initial
  begin

	if(lpm_width <= 0)
		$display("Error! lpm_width parameter must be greater than 0.");

	if(lpm_widthad <= 0)
		$display("Error! lpm_widthad parameter must be greater than 0.");

	// check for number of words out of bound
	if((lpm_numwords > (1 << lpm_widthad))
		||(lpm_numwords <= (1 << (lpm_widthad-1))))
	begin
		$display("Error! lpm_numwords must equal to the ceiling of log2(lpm_widthad).");
 
	end

	if((lpm_indata !== "REGISTERED") && (lpm_indata !== "UNREGISTERED")) 
	begin
		$display("Error! lpm_indata must be REGISTERED (the default) or UNREGISTERED.");
	end
	
	if((lpm_address_control !== "REGISTERED") && (lpm_address_control !== "UNREGISTERED")) 
	begin
		$display("Error! lpm_address_control must be REGISTERED (the default) or UNREGISTERED.");
	end
	
	if((lpm_outdata !== "REGISTERED") && (lpm_outdata !== "UNREGISTERED")) 
	begin
		$display("Error! lpm_outdata must be REGISTERED (the default) or UNREGISTERED.");
	end
	

	// check if lpm_indata or lpm_address_control is set to registered
	// inclock must be used.
	if(((lpm_indata === "REGISTERED") || (lpm_address_control === "REGISTERED")) && (inclock === 1'bz))
	begin
		$display("Error! inclock = 1'bz.  Inclock pin must be used.\n");
	end
 
	// check if lpm_outdata, outclock must be used
	if((lpm_outdata === "REGISTERED") && (outclock === 1'bz))
	begin
		$display("Error! lpm_outdata is REGISTERED, outclock = 1'bz.  Outclock pin must be used.\n");  
	end
 
	for(i=0; i < lpm_width; i=i+1)
	begin
		ZEROS[i] = 1'b0 ;
		UNKNOWN[i] = 1'bX ;
		HiZ[i] = 1'bZ ;
	end 
	
	for(i = 0; i < lpm_numwords; i=i+1)
		mem_data[i] = ZEROS ;

	// Initialize input/output 
	pdio = 0;
	paddress = 0;
	tmp_io = 0;
	tmp_q = 0;

	// load data to the RAM
	if(lpm_file != "UNUSED")
	begin
		$convert_hex2ver(lpm_file, lpm_width, ram_initf);
		$readmemh(ram_initf, mem_data);
	end
  end


  always @(dio)
	begin
	  if(lpm_indata === "UNREGISTERED")
		pdio <=  dio;
	end
	
  always @(address)
  begin
	if(lpm_address_control === "UNREGISTERED")
		paddress <=  address;
  end
	
	
  always @(we)
  begin
	if(lpm_address_control === "UNREGISTERED")
		pwe <=  we;
  end
	
  always @(posedge inclock)
  begin
	  if(lpm_indata === "REGISTERED")
		pdio <=  dio;

	  if(lpm_address_control === "REGISTERED")
		begin
			paddress <=  address;
			pwe <=  we;
		end
  end

  always @( pdio or paddress or pwe or memenab  )
  begin :block_a
	if(ValidAddress(paddress))
	begin

		if((lpm_indata === "UNREGISTERED" && lpm_address_control === "UNREGISTERED") || (lpm_address_control === "UNREGISTERED"))
				begin
			if (pwe && memenab)
			mem_data[paddress] <= pdio ;
		end

		if(lpm_outdata === "UNREGISTERED")
		begin
			tmp_q <= mem_data[paddress];
			tmp_q <= mem_data[paddress];
		end

	end
	else
	begin
		if(lpm_outdata === "UNREGISTERED")
			tmp_q <= UNKNOWN ;
	end
  end

  always @(negedge inclock  )
	begin
		if (lpm_address_control === "REGISTERED")
	begin
			if (pwe && memenab)
			mem_data[paddress] <= pdio ;
		end
	end

  always @(posedge outclock )
	begin
		if(lpm_outdata === "REGISTERED")
		begin
		tmp_q <= mem_data[paddress];
 
	
		end
	end

  always @( memenab or outenab or tmp_q)
  begin
	if(memenab && outenab)
		tmp_io <= tmp_q ;
	else if(!memenab || (memenab && !outenab))
		tmp_io <= HiZ ;
  end
 
  assign dio =  tmp_io ;

endmodule // lpm_ram_io
 
//------------------------------------------------------------------------

module lpm_rom ( q, inclock, outclock, memenab, address ) ;

  parameter lpm_type = "lpm_rom" ;
  parameter lpm_width = 1 ;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久伊人久久99| 久久久精品免费网站| 日韩精品一区二区三区视频| 国产精品乱码一区二区三区软件| 亚洲综合免费观看高清完整版| 精品一区二区在线观看| 欧美系列日韩一区| 中文字幕免费不卡| 国产久卡久卡久卡久卡视频精品| 欧美色偷偷大香| 亚洲欧美色图小说| 成人18精品视频| 国产欧美精品在线观看| 老司机精品视频导航| 欧美一区中文字幕| 亚洲va欧美va国产va天堂影院| 一本大道久久精品懂色aⅴ| 欧美激情一区二区三区不卡| 国产一区二区影院| 日韩欧美www| 久久国产视频网| 欧美一级一区二区| 美女高潮久久久| 亚洲视频小说图片| 成人精品免费视频| 欧美国产精品中文字幕| 狠狠色狠狠色综合日日91app| 91麻豆精品国产91久久久使用方法| 亚洲综合在线电影| 欧洲在线/亚洲| 亚洲最新视频在线观看| 欧美日韩在线播放三区| 亚洲午夜av在线| 51精品视频一区二区三区| 日韩不卡免费视频| 日韩欧美一级二级| 黄色精品一二区| 欧美激情一区二区在线| 99久久精品免费精品国产| 国产精品超碰97尤物18| 色综合久久中文字幕| 亚洲成人免费在线| 日韩三级av在线播放| 国产精品一级片| 中文字幕在线一区二区三区| 色综合久久久久综合体桃花网| 亚洲一区二区三区四区不卡| 91精品国产91综合久久蜜臀| 精品综合久久久久久8888| 国产日韩精品一区| 91福利精品视频| 久久精品国产秦先生| 久久九九久精品国产免费直播| 99久久er热在这里只有精品15| 一区二区成人在线| 欧美成人乱码一区二区三区| 成人午夜激情影院| 亚洲最大成人网4388xx| 欧美α欧美αv大片| 不卡av在线网| 同产精品九九九| 中文字幕欧美日韩一区| 日本丶国产丶欧美色综合| 日本一不卡视频| 中文字幕一区二区三区av| 91.com在线观看| 99精品欧美一区二区蜜桃免费 | 热久久久久久久| 久久久国际精品| 欧美丝袜丝交足nylons| 国产麻豆日韩欧美久久| 亚洲综合激情小说| 国产丝袜欧美中文另类| 6080yy午夜一二三区久久| 国产成人av一区二区| 亚洲aaa精品| 日韩一区在线看| 久久亚洲精华国产精华液| 欧美在线观看视频在线| 日韩欧美国产小视频| 91女神在线视频| 国产精品综合视频| 天堂精品中文字幕在线| 国产精品毛片大码女人 | 在线视频一区二区三区| 国产一区 二区 三区一级| 亚洲午夜日本在线观看| 中文在线免费一区三区高中清不卡| 制服丝袜av成人在线看| 97久久精品人人做人人爽| 国产乱码一区二区三区| 美国十次综合导航| 日韩电影免费在线看| 日韩美女啊v在线免费观看| 国产日韩欧美一区二区三区综合 | 欧美韩国日本综合| 欧美sm美女调教| 欧美一区二区免费视频| 欧美另类z0zxhd电影| 91福利在线看| 欧美综合一区二区三区| 9i在线看片成人免费| 成人黄色国产精品网站大全在线免费观看| 日本免费新一区视频| 亚洲18影院在线观看| 午夜免费久久看| 五月激情综合色| 午夜电影网一区| 亚洲国产精品久久久久秋霞影院| 亚洲色大成网站www久久九九| 亚洲国产精品v| 国产精品青草久久| 国产精品电影院| 中文字幕人成不卡一区| 成人欧美一区二区三区1314| 1024成人网| 一区二区三区自拍| 午夜在线成人av| 日日欢夜夜爽一区| 免费成人av在线| 9色porny自拍视频一区二区| 国产精品羞羞答答xxdd| 国产精品91一区二区| 国产精品1区2区| 国产成人夜色高潮福利影视| 国产成a人无v码亚洲福利| 国产成人精品免费| k8久久久一区二区三区| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 91精品婷婷国产综合久久竹菊| 日韩欧美三级在线| 久久美女高清视频| 国产精品不卡在线| 亚洲大片精品永久免费| 琪琪久久久久日韩精品| 久久91精品久久久久久秒播| 国产精品一色哟哟哟| 91污在线观看| 在线成人高清不卡| 久久久蜜桃精品| 成人免费视频播放| 91成人网在线| 日韩一级免费一区| 中文字幕免费观看一区| 亚洲一本大道在线| 国产高清亚洲一区| 欧美性生活久久| 亚洲精品一区二区三区影院 | 久久久久久综合| 亚洲黄色性网站| 男女激情视频一区| 97国产一区二区| 日韩视频一区二区三区| 国产精品国产三级国产| 舔着乳尖日韩一区| 成人免费视频网站在线观看| 91精品久久久久久久91蜜桃| 国产人伦精品一区二区| 亚洲国产中文字幕在线视频综合| 韩国在线一区二区| 欧美日韩一区二区三区在线| 国产人妖乱国产精品人妖| 亚洲aⅴ怡春院| 91免费在线视频观看| 欧美电影免费观看完整版| 一区二区三国产精华液| 岛国一区二区三区| 日韩欧美国产精品| 午夜精品福利一区二区蜜股av| 国产精品白丝av| 在线播放中文字幕一区| 国产精品久久影院| 国产一区在线观看视频| 欧美视频一区二区三区在线观看| 欧美国产一区二区| 久久99精品久久久久| 正在播放亚洲一区| 亚洲va国产va欧美va观看| 99久久精品国产一区| 国产视频一区二区在线| 美国十次综合导航| 欧美一级淫片007| 日韩和的一区二区| 欧美日韩精品免费| 亚洲成人激情av| 欧美视频自拍偷拍| 亚洲国产欧美在线| 欧美影院精品一区| 亚洲一区二区三区不卡国产欧美| 99久久久精品| 亚洲猫色日本管| 97久久超碰精品国产| 日韩一区欧美小说| 成人va在线观看| 中文字幕精品在线不卡| 成人污视频在线观看| 国产精品三级视频| 91蜜桃视频在线| 亚洲一区在线播放| 在线免费亚洲电影|