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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? eeprom_wr.v

?? Verilog HDL 入門教程
?? V
?? 第 1 頁 / 共 2 頁
字號:


/****************************************************************************
模塊名稱:EEPROM_WR  文件名:eeprom_wr.v
模塊功能:EEPROM讀寫器,可以根據(jù)MCU的并行數(shù)據(jù)、地址線和讀/寫的控制
          線對EEPROM (AT24C02/4/8/16)的行為模塊進行隨機的讀寫操作。
          而且本模塊為教學目的做了許多簡化,只能做隨機的讀寫操作,功能
          不完整,不能用做商業(yè)目的。
模塊說明:本模塊為可綜合模塊,可綜合為門級網(wǎng)表。
****************************************************************************/

`timescale 1ns/1ns 
module EEPROM_WR(SDA,SCL,ACK,RESET,CLK,WR,RD,ADDR,DATA);
output SCL;                //串行時鐘線
output ACK;               //讀寫一個周期的應答信號
input  RESET;             //復位信號
input  CLK;               //時鐘信號輸入
input  WR,RD;             //讀寫信號 
input[10:0] ADDR;           //地址線
inout SDA;                 //串行數(shù)據(jù)線
inout[7:0] DATA;            //并行數(shù)據(jù)線
reg ACK;
reg SCL;
reg WF,RF;                //讀寫操作標志
reg FF;                    //標志寄存器
reg [1:0] head_buf;        //啟動信號寄存器
reg[1:0] stop_buf;           //停止信號寄存器 
reg [7:0] sh8out_buf;         //EEPROM寫寄存器
reg [8:0] sh8out_state;        //EEPROM 寫狀態(tài)寄存器
reg [9:0] sh8in_state;         //EEPROM 讀狀態(tài)寄存器
reg [2:0] head_state;          //啟動狀態(tài)寄存器
reg [2:0] stop_state;          //停止狀態(tài)寄存器
reg [10:0] main_state;        //主狀態(tài)寄存器  
reg [7:0] data_from_rm;      //EEPROM讀寄存器
reg link_sda;               //SDA 數(shù)據(jù)輸入EEPROM開關(guān)  
reg link_read;               //EEPROM讀操作開關(guān)   
reg link_head;               //啟動信號開關(guān)
reg link_write;              //EEPROM寫操作開關(guān)
reg link_stop;               //停止信號開關(guān) 
wire sda1,sda2,sda3,sda4;   
 
//--------------串行數(shù)據(jù)在開關(guān)的控制下有次序的輸出或輸入-------------------
assign sda1  = (link_head)     ?   head_buf[1]    :  1'b0;
assign sda2  = (link_write)    ?   sh8out_buf[7]   :  1'b0;
assign sda3  = (link_stop)     ?   stop_buf[1]     :  1'b0;
assign sda4  = (sda1 | sda2 | sda3);
assign SDA  = (link_sda)       ?  sda4          :  1'bz;
assign DATA = (link_read)      ?  data_from_rm   :  8'hzz;

//--------------------------------主狀態(tài)機狀態(tài)定義------------------------------------------
parameter		
                  Idle        = 11'b00000000001,
                    Ready     = 11'b00000000010,	
               Write_start    = 11'b00000000100,    
                Ctrl_write    = 11'b00000001000,	
                  Addr_write  = 11'b00000010000, 
		         Data_write   = 11'b00000100000,	 
		        Read_start    = 11'b00001000000,	    
		        Ctrl_read     = 11'b00010000000,	     
		         Data_read    = 11'b00100000000,	     
		         Stop         = 11'b01000000000,	     
 		          Ackn        = 11'b10000000000,

//-------------------------并行數(shù)據(jù)串行輸出狀態(tài)-----------------------------
                sh8out_bit7     = 9'b000000001,
                sh8out_bit6     = 9'b000000010,
                sh8out_bit5     = 9'b000000100,
                sh8out_bit4     = 9'b000001000,		
                sh8out_bit3     = 9'b000010000,
                sh8out_bit2     = 9'b000100000,
                sh8out_bit1     = 9'b001000000,
                sh8out_bit0     = 9'b010000000,
                sh8out_end     = 9'b100000000;
//--------------------------串行數(shù)據(jù)并行輸出狀態(tài)----------------------------
 parameter      sh8in_begin    = 10'b0000000001,
                sh8in_bit7     = 10'b0000000010,
                sh8in_bit6     = 10'b0000000100,
                sh8in_bit5     = 10'b0000001000,		
                sh8in_bit4     = 10'b0000010000,
                sh8in_bit3     = 10'b0000100000,
                sh8in_bit2     = 10'b0001000000,
                sh8in_bit1     = 10'b0010000000,
                sh8in_bit0     = 10'b0100000000,
                sh8in_end      = 10'b1000000000,
//---------------------------------啟動狀態(tài)----------------------------------     
                head_begin   = 3'b001,
                head_bit     = 3'b010,
                head_end     = 3'b100,                
//---------------------------------停止狀態(tài)----------------------------------
                stop_begin   = 3'b001,
                stop_bit     = 3'b010,
                stop_end     = 3'b100;
                
 parameter       YES             = 1,
                 NO              = 0;                

//-------------產(chǎn)生串行時鐘scl,為輸入時鐘的二分頻-------------------
always @(negedge CLK)    
  if(RESET)
     SCL <= 0;
  else   	  
     SCL <= ~SCL; 

//-----------------------------主狀態(tài)機程序----------------------------------
always @ (posedge CLK)
  if(RESET)
    begin     
     link_read  <= NO;
     link_write <= NO;
     link_head  <= NO;
     link_stop  <= NO;
     link_sda   <= NO;
     ACK        <= 0;
     RF         <= 0;
     WF         <= 0;
     FF         <= 0;
     main_state <= Idle; 
    end
  else
   begin   
     casex(main_state)
            Idle:
                 begin
                  link_read  <= NO;
                  link_write <= NO;
                  link_head  <= NO;
                  link_stop  <= NO;
                  link_sda   <= NO;
                  if(WR)
                    begin
                    	 WF <= 1;
                    	 main_state <= Ready ;
                    	end
                  else if(RD)
                    begin
                    	 RF <= 1;
                    	 main_state <= Ready ;
                    	end
                 else
                   begin
                    WF <= 0;
                    RF <= 0; 
                    main_state <= Idle;
                   end
                 end 
         Ready:  
      	       begin
      		       link_read        <= NO; 
 	   	       link_write       <= NO;
 	              link_stop        <= NO;
 	              link_head        <= YES;
 	              link_sda         <= YES;			 
	              head_buf[1:0]    <= 2'b10;	
 	              stop_buf[1:0]    <= 2'b01;	
 	              head_state       <= head_begin;
	              FF               <= 0;	
	              ACK         	    <= 0;	 
	              main_state       <= Write_start;
	            end
  Write_start: 
     	          if(FF == 0)
	               shift_head;		 
		          else 
		            begin
		              sh8out_buf[7:0]  <= {1'b1,1'b0,1'b1,1'b0,ADDR[10:8],1'b0};
		              link_head        <= NO;
		              link_write       <= YES;
		              FF               <= 0;   
		              sh8out_state     <= sh8out_bit6;
		              main_state       <= Ctrl_write;
		            end
  Ctrl_write: 
                if(FF ==0)
	               shift8_out;
 	   	       else
 	   	         begin
 	   	              sh8out_state    <= sh8out_bit7;
		              sh8out_buf[7:0] <= ADDR[7:0];
		              FF              <= 0;
		              main_state      <= Addr_write;
		           end	      	    
  Addr_write: 
                if(FF == 0)
		            shift8_out;
		          else 
		            begin
		              FF <= 0;	
		              if(WF)
		                begin	 
		                  sh8out_state    <= sh8out_bit7;		                  
		                  sh8out_buf[7:0] <= DATA;
		                  main_state      <= Data_write;
		                end
		              if(RF)
		                begin
		                  head_buf        <= 2'b10;
		                  head_state       <= head_begin;
		                  main_state      <= Read_start; 
		                end
		            end  	  
  Data_write:  
                 if(FF == 0)
		             shift8_out;
      		     else  
		            begin	
		             stop_state       <= stop_begin;
		             main_state       <= Stop;
		             link_write       <= NO;
		             FF               <= 0;
		            end

  Read_start:  
                if(FF == 0)
	                shift_head;
	             else 
		            begin	
		              sh8out_buf       <= {1'b1,1'b0,1'b1,1'b0,ADDR[10:8],1'b1};
		              link_head        <= NO;
                            link_sda         <= YES;
		              link_write       <= YES;
		              FF               <= 0;
		              sh8out_state     <= sh8out_bit6;
		              main_state       <= Ctrl_read;
 		            end
  Ctrl_read:	
                if(FF == 0)	
	               shift8_out; 
      	       else  
		            begin	
		              link_sda         <= NO;
		              link_write       <= NO;
		              FF               <= 0;
		              sh8in_state      <= sh8in_begin;
		              main_state       <= Data_read;
	               end
  Data_read:	
               if(FF == 0) 
	              shift8in;
   	         else 
		           begin	
		              link_stop        <= YES;
		              link_sda         <= YES;
		              stop_state       <= stop_bit;
		              FF               <= 0;
		              main_state       <= Stop;
		           end  
  Stop: 
               if(FF == 0)
		           shift_stop;
  		         else 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美日韩电影| 日韩av网站在线观看| 宅男噜噜噜66一区二区66| 国产在线播精品第三| 大白屁股一区二区视频| 亚洲va天堂va国产va久| 国产精品日产欧美久久久久| 日韩视频免费直播| 在线观看日韩毛片| 99精品欧美一区二区三区综合在线| 精久久久久久久久久久| 亚洲成人综合网站| 中文字幕一区二区三区四区不卡 | 五月激情综合网| 亚洲欧洲综合另类在线| 中文成人av在线| 久久久亚洲精品石原莉奈| 日韩免费成人网| 5858s免费视频成人| 欧美日韩日本视频| 欧美色图12p| 欧美色偷偷大香| 欧美三级资源在线| 在线一区二区三区| 色悠悠亚洲一区二区| av网站免费线看精品| 成人一区二区三区视频在线观看| 激情综合一区二区三区| 久久国产婷婷国产香蕉| 麻豆成人av在线| 美女在线视频一区| 久久精品99国产国产精| 蜜臀av一区二区三区| 麻豆国产91在线播放| 久久精品国产成人一区二区三区| 青娱乐精品视频| 美女视频网站黄色亚洲| 老司机午夜精品99久久| 极品少妇一区二区三区精品视频| 卡一卡二国产精品 | 久久久久久97三级| 国产午夜精品一区二区三区视频 | 国产一区二区不卡老阿姨| 久久9热精品视频| 国内一区二区在线| 久久69国产一区二区蜜臀| 精品一区二区在线观看| 国内外成人在线视频| 国产精品一区二区久久精品爱涩| 国产福利电影一区二区三区| 丁香啪啪综合成人亚洲小说| 99精品视频在线免费观看| 一本一道久久a久久精品| 欧美艳星brazzers| 欧美丰满高潮xxxx喷水动漫| 精品精品国产高清a毛片牛牛| 亚洲精品一区二区在线观看| 亚洲国产精品黑人久久久| 蜜桃精品视频在线| 国产美女精品一区二区三区| 成人自拍视频在线| 色偷偷一区二区三区| 91精品国产91久久综合桃花| 久久免费电影网| √…a在线天堂一区| 亚洲图片欧美色图| 国内精品久久久久影院色| 不卡的看片网站| 欧美性感一区二区三区| 日韩欧美国产麻豆| 国产精品久久久久久户外露出 | 日本中文在线一区| 国产福利91精品一区| 在线观看www91| 久久综合色婷婷| 亚洲欧美视频在线观看视频| 丝袜美腿亚洲一区| 成人精品视频一区二区三区| 精品视频色一区| 国产婷婷色一区二区三区在线| 一个色在线综合| 韩国三级中文字幕hd久久精品| 色又黄又爽网站www久久| 精品乱人伦小说| 亚洲人成在线播放网站岛国| 美女看a上一区| 91老师国产黑色丝袜在线| 日韩免费在线观看| 亚洲综合一二区| 成人永久免费视频| 日韩视频免费观看高清完整版 | 午夜电影一区二区三区| 成人午夜激情视频| 欧美一级免费大片| 亚洲精品国产精品乱码不99| 国产乱子伦一区二区三区国色天香| 在线亚洲人成电影网站色www| 国产亚洲一二三区| 免费在线观看一区| 91久久免费观看| 欧美激情在线看| 黄色精品一二区| 91精品国产综合久久福利软件| 国产精品久久久久久久久搜平片| 极品少妇xxxx精品少妇偷拍 | 精品国产不卡一区二区三区| 亚洲国产你懂的| 91啪九色porn原创视频在线观看| 欧美精品一区二区三区四区| 亚洲.国产.中文慕字在线| 91尤物视频在线观看| 国产情人综合久久777777| 九色综合国产一区二区三区| 欧美精品第一页| 一级女性全黄久久生活片免费| 99视频一区二区| 欧美国产精品一区| 国产99精品视频| 国产视频一区二区在线| 韩国女主播成人在线观看| 一区二区三区在线观看视频| www.亚洲人| 国产精品家庭影院| av毛片久久久久**hd| 久久久久久久性| 国产精品中文字幕一区二区三区| 精品1区2区在线观看| 激情成人综合网| 久久蜜桃av一区精品变态类天堂 | 色老汉一区二区三区| 亚洲色图欧洲色图婷婷| 成人成人成人在线视频| 国产精品三级电影| 成人激情视频网站| 国产精品国产馆在线真实露脸 | 日韩片之四级片| 六月婷婷色综合| www日韩大片| 国内精品写真在线观看| 亚洲精品一区二区三区精华液 | 欧美日韩电影一区| 亚洲国产aⅴ天堂久久| 欧美日韩久久久一区| 亚洲va韩国va欧美va精品 | 亚洲乱码中文字幕综合| 在线亚洲人成电影网站色www| 亚洲高清免费观看 | 亚洲柠檬福利资源导航| 91国产丝袜在线播放| 丝袜诱惑制服诱惑色一区在线观看 | 国产美女精品人人做人人爽| 国产欧美一区视频| 91网站最新地址| 首页国产欧美日韩丝袜| 久久亚洲综合色一区二区三区 | 91久久国产综合久久| 亚洲成人精品一区| 欧美一区国产二区| 国产美女在线精品| 自拍偷拍亚洲欧美日韩| 欧美日韩国产美| 精品一区二区日韩| 国产精品福利电影一区二区三区四区| 色中色一区二区| 欧美a级一区二区| 国产精品私人影院| 精品视频在线免费| 韩日av一区二区| 亚洲精品国产视频| 日韩三级.com| 91蜜桃婷婷狠狠久久综合9色| 亚洲国产精品久久人人爱蜜臀 | 91麻豆精品国产91久久久久久久久 | 天堂成人国产精品一区| 久久精品亚洲一区二区三区浴池| 9久草视频在线视频精品| 午夜精品福利一区二区蜜股av| 久久久久九九视频| 欧美视频第二页| 国产福利精品一区| 偷拍与自拍一区| 国产精品进线69影院| 欧美日本在线观看| 成人黄色小视频在线观看| 日韩福利视频网| 一区免费观看视频| 日韩欧美一区在线| 在线精品视频免费观看| 精品一二线国产| 亚洲一二三四久久| 欧美国产成人精品| 日韩美一区二区三区| 欧美影院一区二区| 风间由美一区二区三区在线观看 | 日韩电影免费在线| 亚洲欧美一区二区三区国产精品| 精品国产乱码久久久久久免费| 在线一区二区视频| 不卡一区二区中文字幕| 国产一区二区主播在线|