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

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

?? psp.v

?? psp屏顯示驅動程序cpld veriloghdl
?? V
字號:
module PSP(clk,HS,VS,DISP,LED,pspclk,pspdata,CE,OE,WE,BH,BL,ADDER,WR,wrdata,RamData,RST,RS);
	input clk,WR,RST,RS;
	input [15:0] wrdata;
	inout [15:0] RamData;
	output HS,VS,DISP,LED,pspclk,CE,OE,WE,BH,BL,ADDER,pspdata;
///////////////////////////////////////////////////////////////////////////////////////////////////////////	
	reg [9:0]J1;                   //HS計數器:
	reg [8:0]J2;                   //VS計數器:
	reg HS=1;                      //PSP屏行掃描
	reg VS=1;                      //PSP屏幀掃描
	reg PSPEN=0;                   //psp開始工作標志位
	reg DISP=0;                    //PSP開顯示,1開,0關
    reg [4:0] i;                  //分頻時的計數器
    reg pspclk;                    //psp屏時鐘
    reg [2:0] pspdataChoose;      //向PSP發數據時確定是第一位數據還是第二位數據
    reg [23:0] pspdata;
    //reg pspdataen=1;
////////////////////////////////////////////////////////////////////////////////////////////////////////////
    reg LED=1;                      //檢測系統時鐘工作正常的LED
    reg [1:0] led;
    reg [21:0] sysen;               //系統上電延時標志位
/////////////////////////////////////////////////////////////////////////////////////////////////////////      
    reg addstart;
    reg RamEN=0;
    reg [15:0] outdata;             //臨時數據區為inout中的OUT 輸出數據
    reg [4:0]  start;               //開始控制讀寫RAM和PSP數據發送計數器

    reg [15:0] RamA0;
    reg [15:0] RamB0;
    reg [15:0] RamC0;

    reg [15:0] RamA1;
    reg [15:0] RamB1;
    reg [15:0] RamC1;

    wire [17:0] ADDER;                     //RAM地址輸出寄存器
    reg CE=0;
    reg OE,WE,BH,BL;                      //RAM控制位
    reg [15:0] wridata;                   //外部輸入的數據臨時存放寄存器
    reg [17:0] WADDER;                    //寫入數據時的RAM地址
    reg [17:0] RADDER;                     //讀RAM數據時的地址
    reg oe;reg WRoe;
    reg RamStart=0;
    reg WADDEREN;
    assign RamData=oe? outdata:16'hzzzz;
    assign ADDER=WRoe? WADDER:RADDER;
   
///////////////////////////////////////////////////////////////////////////////////////////////////////////   

always @(posedge clk)              //系統上電延時函數
begin
    sysen<=sysen+1;
    if(sysen>4000000)//4000000)                   //大概是74MS
	  begin
	       PSPEN=1;
	  end
end

////////////////////////////////////////////////////////////////////////////////////////////////////////////

always @(posedge clk)             //時鐘分頻函數,輸出PSP時鐘
begin
if(PSPEN)                  //
 begin
   if(i==2)
     begin
      i<=0; 
      pspclk<=~pspclk;
     end
   else
      i<=i+1;
  end
end

////////////////////////////////////////////////////////////////////////////////////////////////////////////

always @(posedge clk)              //開始控制讀寫RAM和PSP數據發送函數
begin
  if(RamEN)
   begin
      BH=0;BL=0;
       case(start)
      0:
         begin
           OE=1;WE=0;CE=0;
           oe=1;WRoe=1;
           start=1;  
         end     
      1:
       begin
           outdata=wridata;
           start=2;
       end  
      2:
       begin
           oe=0;WRoe=0;
           OE=0;CE=0;WE=1; 
           start=3;
       end              
     3: 
         begin 
          RADDER<=RADDER+1;                        //adda0            
          start=4; 
         end
 
      4: 
         begin
           RamA0<=RamData;                       //dataa0
           start=5;              
         end
 
     5:  
         begin                               //addb0
           RADDER<=RADDER+1;     
           start=6;  
         end
      6: 
         begin                               //datab0
           RamB0<=RamData;    
           start=7; 
         end
 
      7: begin  
           RADDER<=RADDER+1;    
           start=8; 
          end
      8: 
         begin 
           RamC0<=RamData;                   //datac0
           start=9;
         end
      9: 
         begin
           RADDER<=RADDER+1;     
           start=10; 
         end
     10: 
         begin                             //dataa1
          RamA1<=RamData; 
          start=11; 
         end
      11:                                  //addb1
         begin  
           RADDER<=RADDER+1;     
           start=12;  
         end
     12: 
        begin
           RamB1<=RamData;               //databb1
           start=13;  
        end
     13: 
        begin 
           RADDER<=RADDER+1;    
           start=14;
         end
     14:
       begin
          RamC1<=RamData;               //datac1
          start=15;
       end
     15:
       begin
           CE=1;
        if(addstart==1)
           begin
              RADDER=0;
           end
           start=16;
       end     16:
       begin
           OE=1;WE=0;CE=0;
           oe=1;WRoe=1;
           start=17;
  
       end

    17:
       begin
          outdata=wridata;
          start=18;
       end
    18:
       begin
          start=19;
       end
    19:
       begin
          outdata=wridata;
          start=20;
       end
    20:
       begin
           oe=0; CE=1;
           start=21;
       end
        21:
       begin
           start=22;
       end       22:
       begin
           start=23;
       end
    23:
       begin
           start=0;
       end      endcase
   end
end   

////////////////////////////////////////////////////////////////////////////////////////////////////////////
/*
always @(posedge clk ) 
begin
  if(RST==0) 
     begin
      WADDEREN=0;
     end
  else 
      WADDEREN=1;
end
*/
////////////////////////////////////////////////////////////////////////////////////////////////////////////

always @(negedge WR )                         //WR下降沿時讀入外部數據
begin
   case(RS)                                   //RS=0;cmd
    1:                                        //RS=1;DATA
     begin
       if(WADDER==196560) //195840                            
         begin
           WADDER=1;
          end
        else   
         WADDER=WADDER+1;

       if(WADDER<=196560)
         begin
          wridata<=wrdata;
         end 
     end
    0:
      begin
        WADDER<=wrdata;
      end
    endcase
end 

///////////////////////////////////////////////////////////////////////////////////////////////////////////	     
 
always@(posedge pspclk)                      //將colordata的數據發送給PSP
 begin
      if(J1==525) 
	     begin
	       J1=1; 
	      end 
	    else  
	        J1=J1+1;
   if(J1<=41) 
        begin
           HS=0;
        end 
    else if(J1<=43)
        begin
          HS=1;
          RamEN=1;
          pspdata='hzzzzzz;
        end
    else if(J1<=523) 
	   begin
	       if(J1==522)
	          begin
	             RamEN=0;
	           end
	         case(pspdataChoose)
	             0:
	              begin
	                pspdata[23:8]<=RamA0[15:0];
	                pspdata[7:0] <=RamB0[15:8];
	                pspdataChoose=1;
	                 
	             end
	             1:
                   begin
	                pspdata[23:16]<=RamB0[7:0];
	                pspdata[15:0] <=RamC0[15:0];
	                pspdataChoose=2;
	               end
	            2:
	              begin
	                pspdata[23:8]<=RamA1[15:0];
	                pspdata[7:0] <=RamB1[15:8];
	                pspdataChoose=3;  
	              end
	            3:
	              begin
	                pspdata[23:16]<=RamB1[7:0];
	                pspdata[15:0] <=RamC1[15:0];
	                pspdataChoose=0;
	            end 
	           endcase
	end  
	
	 else if(J1<=525)
	      begin
             pspdata='hzzzzzz;
          end   
     
end	
	
///////////////////////////////////////////////////////////////////////////////////////////////////////////	
	
always@(posedge HS)	             //PSP屏幀掃描函數
 begin
   if(J2==286)
	 begin
       J2=1;
     end
    else
      J2=J2+1;

  if(J2<=10)
    begin
        DISP=1;
        VS=0;
     end
  else if(J2<=12)
     begin
        addstart=1;
        VS=1;
     end
  else if(J2<=286)
      begin
	    addstart=0;
	  end	
  /*else if(J2<=286)
     begin
     end*/
 end		

////////////////////////////////////////////////////////////////////////////////////////////////////////////

always @(posedge VS)                   //LED閃爍函數,為了檢測系統時鐘是否工作正常
begin      
    led<=led+1;
	if(led==3)
		begin
			 LED=~LED;
			 led<=0;
		end
end    


endmodule 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲天天做日日做天天谢日日欢| 一区二区三区毛片| 欧美一区二区三区免费大片| 六月丁香婷婷久久| 麻豆精品视频在线观看视频| 国产一区二区0| 91视视频在线观看入口直接观看www | 色综合久久综合网97色综合 | 久久精品人人做人人爽人人| 中文字幕亚洲电影| 日韩国产在线观看一区| 国产成人精品www牛牛影视| 亚洲成人av电影在线| 91久久精品一区二区三区| 精品乱人伦小说| 亚洲成人av中文| 国产成人午夜精品5599| 日本一不卡视频| 成人福利在线看| 精品剧情v国产在线观看在线| 自拍偷拍欧美激情| 国产传媒一区在线| 日韩理论片中文av| 久久蜜臀精品av| 五月天欧美精品| 色综合久久88色综合天天6| 337p日本欧洲亚洲大胆色噜噜| 亚洲午夜一二三区视频| 在线一区二区三区| 91福利视频久久久久| 国产亚洲欧洲一区高清在线观看| 日韩电影在线观看网站| 欧美综合欧美视频| 亚洲国产中文字幕在线视频综合| 成人app网站| 波多野结衣亚洲一区| 一区二区中文字幕在线| 91视频.com| 午夜视频在线观看一区二区| 不卡在线观看av| 亚洲国产精品久久人人爱| 亚洲午夜激情网站| 欧美性色黄大片| 香港成人在线视频| 日韩欧美综合一区| 国产不卡视频在线观看| 亚洲男人的天堂在线aⅴ视频| av一区二区三区| 亚洲高清免费视频| 精品久久久久久久久久久久久久久久久| 精品一区二区三区视频| 中文字幕制服丝袜一区二区三区| 色婷婷精品大在线视频| 久久国产精品第一页| 成人欧美一区二区三区白人 | 日韩精品一区二区三区在线| 国产精品性做久久久久久| 一区二区三区美女视频| 欧美一级午夜免费电影| 色综合天天狠狠| 国产精品一区二区三区乱码| 亚洲欧洲性图库| 精品久久久久久久久久久久久久久久久 | 欧美精品一区二区蜜臀亚洲| 亚洲欧美精品午睡沙发| 欧美成人精品高清在线播放| eeuss鲁片一区二区三区在线观看| 亚洲国产aⅴ成人精品无吗| 中文天堂在线一区| 中文字幕精品在线不卡| 狠狠色综合播放一区二区| 亚洲电影激情视频网站| 亚洲天堂精品视频| 一区在线中文字幕| 国产亚洲视频系列| 欧美激情在线免费观看| 国产成人av电影在线观看| 日韩综合一区二区| 爽好久久久欧美精品| 日韩激情一区二区| 成人av在线资源网| 91亚洲国产成人精品一区二三| 国产传媒欧美日韩成人| 成人高清视频免费观看| 一本一道综合狠狠老| 精品国产网站在线观看| 久久精品人人爽人人爽| 国产夜色精品一区二区av| 久久精品亚洲一区二区三区浴池| 久久蜜桃av一区二区天堂| 日本一区二区三区在线观看| 亚洲精品五月天| 亚洲地区一二三色| 久久爱另类一区二区小说| 国产一区二区三区在线观看精品 | 午夜精品在线视频一区| 蜜臀久久久99精品久久久久久| 老司机午夜精品| 成人黄色电影在线| 欧美日韩美女一区二区| 国产精品午夜电影| 欧美日韩免费一区二区三区视频| 亚洲精品高清在线| 欧美日韩视频在线观看一区二区三区| 欧美理论在线播放| 极品美女销魂一区二区三区| 99re热这里只有精品视频| 欧美一区二区三区四区在线观看| 中文字幕一区二区三区视频| 午夜久久久影院| 色老综合老女人久久久| 国产欧美日韩久久| 久久精品99国产精品| 欧美电影影音先锋| 夜夜爽夜夜爽精品视频| 国产69精品久久777的优势| 日韩欧美中文字幕制服| 亚洲人精品午夜| 99r国产精品| 一区在线观看视频| av激情综合网| 中文字幕成人在线观看| 九九在线精品视频| 日韩精品一区二| 精品综合免费视频观看| 欧美成人精品福利| av网站一区二区三区| 亚洲日本电影在线| 在线免费亚洲电影| 亚洲欧美日韩电影| 91福利在线观看| 蜜臀av一区二区在线免费观看| 精品国产自在久精品国产| 蜜臀久久99精品久久久久宅男| 精品国产乱码久久久久久久久| 国产在线不卡一区| 国产精品欧美一区喷水| 欧美无乱码久久久免费午夜一区| 亚洲精品欧美专区| 精品国产一区二区三区忘忧草 | 国产三级一区二区| 成人激情图片网| 天天综合天天综合色| 久久综合成人精品亚洲另类欧美| 成人一级视频在线观看| 亚洲电影一级黄| 亚洲国产精品激情在线观看| 欧美日韩精品综合在线| 国产sm精品调教视频网站| 亚洲国产欧美另类丝袜| 久久久99精品久久| 在线电影一区二区三区| 不卡的av网站| 国产精品一二三在| 日韩精品成人一区二区在线| 国产精品色呦呦| 精品久久一二三区| 欧美精品一卡二卡| 亚洲成人免费在线| 一区二区三区四区视频精品免费| 久久久久成人黄色影片| 久久电影网站中文字幕| 亚洲二区在线视频| 亚洲美女区一区| 亚洲欧美在线视频| 国产精品久久毛片a| 久久久亚洲精华液精华液精华液| 日韩一区二区视频| 欧美高清精品3d| 在线播放91灌醉迷j高跟美女| 在线免费av一区| 欧美视频三区在线播放| 欧美日本一道本| 韩国三级电影一区二区| 国产精品资源网站| 成人一区二区三区中文字幕| 成人涩涩免费视频| k8久久久一区二区三区| av色综合久久天堂av综合| 99re这里只有精品首页| 欧美揉bbbbb揉bbbbb| 美女一区二区三区在线观看| 激情偷乱视频一区二区三区| 国产98色在线|日韩| 色激情天天射综合网| 日韩一级大片在线观看| 国产日韩av一区| 一区二区三区中文在线| 蜜桃精品在线观看| 91一区二区在线| 国产真实乱对白精彩久久| 成人网在线免费视频| 欧美日韩不卡一区| 国产精品乱人伦中文| 日韩黄色一级片| 91原创在线视频| 日韩欧美中文字幕制服| 一区二区三区在线观看视频| 精品一区二区三区免费毛片爱| 亚洲午夜视频在线观看|