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

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

?? eeprom_wr.v

?? 夏宇聞老師優秀的verilog教程課件
?? V
?? 第 1 頁 / 共 2 頁
字號:


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

`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;                 //串行數據線
inout[7:0] DATA;            //并行數據線
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 寫狀態寄存器
reg [9:0] sh8in_state;         //EEPROM 讀狀態寄存器
reg [2:0] head_state;          //啟動狀態寄存器
reg [2:0] stop_state;          //停止狀態寄存器
reg [10:0] main_state;        //主狀態寄存器  
reg [7:0] data_from_rm;      //EEPROM讀寄存器
reg link_sda;               //SDA 數據輸入EEPROM開關  
reg link_read;               //EEPROM讀操作開關   
reg link_head;               //啟動信號開關
reg link_write;              //EEPROM寫操作開關
reg link_stop;               //停止信號開關 
wire sda1,sda2,sda3,sda4;   
 
//--------------串行數據在開關的控制下有次序的輸出或輸入-------------------
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;

//--------------------------------主狀態機狀態定義------------------------------------------
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,

//-------------------------并行數據串行輸出狀態-----------------------------
                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;
//--------------------------串行數據并行輸出狀態----------------------------
 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,
//---------------------------------啟動狀態----------------------------------     
                head_begin   = 3'b001,
                head_bit     = 3'b010,
                head_end     = 3'b100,                
//---------------------------------停止狀態----------------------------------
                stop_begin   = 3'b001,
                stop_bit     = 3'b010,
                stop_end     = 3'b100;
                
 parameter       YES             = 1,
                 NO              = 0;                

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

//-----------------------------主狀態機程序----------------------------------
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一区二区三区免费野_久草精品视频
国产精品女上位| 中文字幕不卡三区| 在线观看网站黄不卡| 99久久精品情趣| 91热门视频在线观看| 成人黄色一级视频| 成人毛片视频在线观看| 成人激情综合网站| 成人天堂资源www在线| 97久久精品人人做人人爽| 一本一本大道香蕉久在线精品 | 欧美激情一区二区三区蜜桃视频| xnxx国产精品| 中文幕一区二区三区久久蜜桃| 中文字幕在线免费不卡| 亚洲精品成a人| 午夜一区二区三区在线观看| 美女高潮久久久| 国内精品在线播放| 99久久精品免费精品国产| 欧美影院一区二区三区| 91精品国产一区二区三区香蕉 | 成人黄色免费短视频| 91麻豆国产福利精品| 欧美精品在线一区二区| 久久你懂得1024| 亚洲天堂2014| 蜜桃视频免费观看一区| 成人av在线资源网| 51久久夜色精品国产麻豆| 国产亚洲欧美日韩在线一区| 亚洲韩国精品一区| 国产999精品久久久久久绿帽| 一本一道波多野结衣一区二区| 日韩一区二区三区四区五区六区| 国产精品―色哟哟| 日韩精品电影在线观看| 国产99久久久久| 91麻豆精品国产91久久久久久| 国产喷白浆一区二区三区| 亚洲亚洲人成综合网络| voyeur盗摄精品| 精品久久99ma| 亚洲国产精品久久一线不卡| 国产精品一区二区果冻传媒| 欧美日韩国产综合久久| 国产精品久久午夜| 国产专区欧美精品| 91精品一区二区三区在线观看| 亚洲图片激情小说| 国产麻豆精品在线| 日韩精品在线一区| 日韩1区2区日韩1区2区| 一本大道久久a久久综合婷婷| 26uuu色噜噜精品一区二区| 亚洲国产成人高清精品| 色8久久人人97超碰香蕉987| 久久精品无码一区二区三区| 老司机精品视频在线| 7777精品久久久大香线蕉| 亚洲精品亚洲人成人网| av一二三不卡影片| 国产精品私人影院| 成人免费精品视频| 国产精品三级av| 国v精品久久久网| 国产午夜精品久久久久久久 | 一区二区三区精品视频| 成人福利视频在线看| 国产亚洲欧美日韩日本| 国产在线精品视频| 久久精品视频一区二区三区| 国产综合色产在线精品| 精品国产乱码久久久久久蜜臀| 午夜av电影一区| 欧美精品日韩精品| 琪琪一区二区三区| 日韩欧美亚洲国产另类| 国产一区二区三区免费| 国产农村妇女毛片精品久久麻豆| 国产91清纯白嫩初高中在线观看| 久久色.com| 国产成人免费9x9x人网站视频| 欧美极品另类videosde| 91香蕉视频黄| 亚洲风情在线资源站| 欧美一区二区三区在线电影| 免费成人结看片| 久久久久国产精品人| 91在线小视频| 亚洲一区二区不卡免费| 日韩免费观看高清完整版| 国产成人免费在线观看不卡| 国产精品乱码人人做人人爱| 日本高清视频一区二区| 免费视频最近日韩| 久久九九久精品国产免费直播| 高清不卡一区二区| 一区二区三区四区不卡在线| 91精品黄色片免费大全| 国产精品一区二区免费不卡| 亚洲精品成人悠悠色影视| 日韩欧美精品三级| 99视频在线观看一区三区| 亚洲.国产.中文慕字在线| 亚洲精品在线三区| 色综合欧美在线| 精品中文字幕一区二区| 樱桃视频在线观看一区| 欧美成人精品高清在线播放| 99视频精品免费视频| 日本aⅴ免费视频一区二区三区| 2021久久国产精品不只是精品| 91丨porny丨首页| 老汉av免费一区二区三区| 中文字幕欧美一| 日韩美女一区二区三区| 一本色道久久综合狠狠躁的推荐 | 久久久国际精品| 欧美三区免费完整视频在线观看| 国产一区二区在线观看免费| 亚洲.国产.中文慕字在线| 中文一区二区完整视频在线观看| 欧美女孩性生活视频| av成人免费在线| 国产精品一区久久久久| 日韩av午夜在线观看| 亚洲综合在线第一页| 久久久久久久久久久黄色| 欧美一区二区三区日韩视频| 在线观看日产精品| 99久久精品国产毛片| 国产精品一区免费在线观看| 欧美aa在线视频| 亚洲国产一区二区视频| 成人免费在线播放视频| 久久综合色鬼综合色| 日韩一区二区精品葵司在线| 欧美午夜精品电影| 91伊人久久大香线蕉| 成人av网站在线| 国产综合久久久久影院| 三级亚洲高清视频| 椎名由奈av一区二区三区| 欧美国产1区2区| 国产日韩欧美一区二区三区乱码| 精品欧美黑人一区二区三区| 51精品国自产在线| 欧美日本韩国一区二区三区视频| 欧美三级一区二区| 欧美人妖巨大在线| 欧美精品在欧美一区二区少妇| 色婷婷av一区| 91黄色免费看| 欧美午夜精品久久久久久孕妇| 色欧美88888久久久久久影院| 夫妻av一区二区| 99久久精品国产毛片| 91官网在线免费观看| 欧美肥胖老妇做爰| 欧美一区二区久久久| 精品国免费一区二区三区| 亚洲精品在线免费播放| 中文字幕av在线一区二区三区| 精品久久免费看| 中文av一区二区| 亚洲欧美日韩电影| 视频一区二区国产| 狠狠色丁香婷综合久久| 国产成人免费视频一区| 高清不卡一区二区| 欧美午夜在线一二页| 日韩一级片在线观看| 欧美激情一二三区| 亚洲制服丝袜一区| 天天综合网天天综合色| 国产精品一区二区三区乱码| 色av一区二区| 欧美一二三区在线观看| 国产天堂亚洲国产碰碰| 亚洲另类在线制服丝袜| 男男视频亚洲欧美| 成人小视频免费观看| 7777精品久久久大香线蕉| 国产欧美精品一区二区色综合朱莉 | 99久久精品一区二区| 538prom精品视频线放| 国产精品你懂的在线欣赏| 亚洲一卡二卡三卡四卡无卡久久 | 欧美日韩精品一区二区天天拍小说| 日韩欧美中文一区二区| 成人免费在线视频| 狠狠色丁香婷综合久久| 欧美性色黄大片| 欧美激情一区二区三区在线| 日韩精品电影在线观看| 91香蕉视频污| 国产网站一区二区| 日韩福利电影在线| 在线免费一区三区|