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

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

?? eeprom_interface.v

?? AT24C02的應用例程
?? V
字號:
// i2c.vhd
//
// This file implements an I2C Master interface that will read data
// from an external NVM (AT24C02A) at power-up to initialize a 256x8
// internal SRAM block. When external logic regs for an NVM write
// access, the block reads data from the external source and writes
// it to the specified I2C address.
//----------------------------------------------------------------------
//
//               Copyright 2004 Actel corporation
//
//----------------------------------------------------------------------
//
// Version 1.2  06/04/04 J.Vorgert - working file
//
//----------------------------------------------------------------------

`timescale 1ns / 1ps

module i2c (Reset_n, CLK, INIT, IENB, IADDR, IDATA, ICLK, UPDT,
            UENB, UADDR, UDATA, SDI, SDO, SCK);

input Reset_n;  /* active low reset */
input CLK    ;  /* processor clock  */
output INIT   ;  /* high during init */
output IENB   ;  /* low to enable write */
output [7:0] IADDR  ;  /* init address */
output [7:0] IDATA  ;  /* init data */
output ICLK   ;  /* init clock */

input UPDT   ;  /* high to trigger mirror image update */
output UENB   ;  /* low to enable fifo */
input [7:0] UADDR; /* write address */
input [7:0] UDATA;  /* write data */

input SDI    ;  /* serial input */
output SDO    ; /* active low open-drain drive enable - data */
output SCK    ; /* active low open-drain drive enable - clock */

reg IENB;
reg INIT;
reg UENB;
reg BTCK;
wire STEN;     
reg  [3:0] CSTATE;   
reg  [3:0] BCNT  ;  
reg  [7:0] CCNT  ;  
reg DLY     ;
reg D2 ;
wire D2I;
wire NKI     ;
reg NACK    ;
wire WRI     ;
wire RDI     ;
reg [8:0] BYTE   ; 
reg [8:0] SDATA  ; 
wire LD_BYTE  ;
reg STSP     ;
wire CTL_VAL  ;

always @ (posedge CLK or negedge Reset_n)
begin
  if(Reset_n == 1'b0) 
     BTCK <= 1'b0;
  else 
     BTCK <= #1 !BTCK;

end

// INIT is set at power-up and cleared when the state machine
// reaches state 0101.

always @ (negedge Reset_n or posedge CLK)
begin
  if(Reset_n == 1'b0) 
     INIT <= 1'b1;
  else if(CSTATE == 4'b0101)
        INIT <= #1 1'b0 ;
end 

// This state machine is set-up to read/write data to an AT24C02A 
// serial Flash memory
//
// At power-up, the INIT bit is set, and the state machine executes
// a 'sequencial read' operation starting at address 0x000 and 
// procedding until all 256 bytes have been read and forwarded into 
// the internal memory block. The state machine then sends a
// stop bit to the Flash and clears the INIT control bit.
//
// The state machine then waits for updt to be set.
// When the updt bit is set, the interface asserts u_enb low on a
// falling-edge of clk and addr/data is latched  on the next falling edge
// (rd_clk should be on the rising-edge).  The state machine writes
// data to the external FLASH memory one byte at a time whenever
// updt is asserted high.  If the FIFO remains 'not empty' then this
// block will poll the NVM until it is ready, and then proceed with
// a write cycle for the next byte.
//
// State Machine:
//
// 0000 - reset state:   generate a start bit and load 0xA0 command
// 0001 - send byte:     then load 0x00 address
// 0010 - send byte:     generate a start bit and load 0xA1 command
// 0011 - send byte:     clear byte count
// 0100 - receive byte:  if cnt /= FF: ack, cnt++, goto 0004 else: nack
// 0101 - stop:          assert stop bit and loop until updt = 1 - then
//                       generate a start bit and load A0
// 0110 - send byte:     send byte - if nack - goto 0101, else load Address
// 0111 - send byte:     send data byte, load data
// 1000 - send byte:     goto 0101
//
// In practice, the state machine is just a counter that starts at zero
// and counts up, then jumps back to 101 and counts up again,
// returning to zero only when reset_n is asserted low.

assign STEN = ( BCNT[3] == 1'b1 &&
                  (CSTATE[2] != 1'b1 || CSTATE[2:1] == 2'b11 ||
                   CSTATE[3]  == 1'b1 || (CSTATE == 4'b0100 && CCNT == 8'b11111111) ||
                  (CSTATE == 4'b0101 && UPDT == 1'b1)))?1'b1:1'b0;

always @(negedge Reset_n or negedge CLK)
begin
  if(Reset_n == 1'b0)  
     CSTATE <= 4'b0000;
  else 
  begin
  if(STEN == 1'b1 && BTCK == 1'b0) 
        begin 
         if(CSTATE < 4'b0101 && NACK == 1'b1)
           CSTATE <= #1 4'b0000 ;
        end
   else 
        begin
        if (CSTATE[3] == 1'b1 || NACK == 1'b1)
          CSTATE <= #1 4'b0101 ;
        else
          CSTATE <= #1 CSTATE + 1'b1 ;
        end
  end
end

// The bit counter (BCNT) is cleared at the state transition
// and during the first cycle of state "0011" (for start bit).
// incremented on the falling-edge of clk when BTCK is low.

always @ (negedge Reset_n or negedge CLK)
begin
  if(Reset_n == 1'b0) 
     begin
     BCNT <= 4'b0000;
     DLY  <= 1'b0;
     end
  else
    begin
     if(BTCK == 1'b0)
       begin
       if(BCNT[3] == 1'b1 && CSTATE == 4'b0010) 
          DLY <= #1 1'b1;
       else
          DLY <= 1'b0;
       
       if(BCNT[3] == 1'b1 || (CSTATE == 4'b0011 && DLY == 1'b1)) 
          BCNT <= #1 4'b0000;
       else
          BCNT <= #1 BCNT + 1'b1;
       end
    
    end
end

// The byte counter (CCNT) is cleared in state 0011.
// It is incremented during the ACK bit after each
// byte transfer in state 0100 to count 0x00-0xFF bytes
// as they are read from the NVM.  ccnt is used both as
// a control signal and as the iaddr output.

assign D2I = (BTCK == 1'b1 && BCNT[3] == 1'b1 && CSTATE == 4'b0100)?1'b1:1'b0;
           

always @ (negedge Reset_n or negedge CLK)
begin
  if(Reset_n == 1'b0)
   begin
     CCNT <= 8'b0;
     D2   <= 1'b0;
   end
  else 
   begin
     D2 <= #1 D2I;
     if(CSTATE == 4'b0011) 
        CCNT <= #1 8'b0;
     else if(D2 == 1'b1)
        CCNT <= #1 CCNT + 1'b1;
     end
end

// the following logic checks the ACK bit for all states except
// states "0100" and "0101" and asserts NACK if the data pin is
// high during the 9th bit of any transfer.  This is registered 
// so that the value is present during state changes.


assign NKI = (BCNT[3] == 1'b1 && CSTATE != 4'b0100 && CSTATE != 4'b0101 && SDI == 1'b1)?1'b1:1'b0;

always @ (negedge Reset_n or posedge CLK)
begin
  if(Reset_n == 1'b0)
     NACK <= 1'b0;
  else if(BTCK == 1'b1)
     NACK <= #1 NKI;
end

// Write enables are cleared to 1 at power-up and are asserted low during
// ACK in state 0100.


assign WRI = (CSTATE == 4'b0100 && BCNT[3] == 1'b1 && BTCK == 1'b1)?1'b0:1'b1;

always @ (negedge Reset_n or negedge CLK)
begin
  if(Reset_n == 1'b0)
     IENB <= 1'b1;
  else
     IENB <= #1 WRI;
end

assign IADDR = CCNT[7:0];   /* use byte count as address */
assign IDATA = SDATA[8:1];  /* account for ACK bit */
assign ICLK = !BTCK;           /* invert BTCK and use the rising-edge of this signal as */
                             /*the write clock into internal SRAM */

// UENB is cleared to 1 at power-up and is asserted low in state 0111
// while BCNT=7 and BTCK=1.  It is clocked on the falling-edge
// of CLK so RD_CLK should occur on the rising-edge.

assign RDI = (CSTATE == 4'b0111 && BCNT == 4'b0111  && BTCK == 1'b1)?0:1;

always @ ( negedge Reset_n or negedge CLK)
begin
  if(Reset_n == 1'b0) 
     UENB  <= 1'b1;
  else 
     UENB <= #1 RDI;
  
end

// The value that gets loaded into sdata is determined
// by which state we're exiting...

always @ (CSTATE or UDATA or UADDR)
begin
  case (CSTATE)
    4'b0000 :  BYTE = 9'b101000001; /* A0 */
    4'b0010 :  BYTE = 9'b101000011; /* A1 */
    4'b0101 :  BYTE = 9'b101000001; /* A0 */
    4'b0110 :  BYTE = {UADDR,1'b1};
    4'b0111 :  BYTE = {UDATA,1'b1};
    default :  BYTE = 9'b000000001; /* 0001,0011 */
  endcase
end

// The data register is 9 bits long (BYTE and ACK bit)
// It is parallel loaded during the ACK cycle in states
// 0000, 0001, 0010, 0011, 0101, 0110, and 0111;

assign LD_BYTE = (BCNT[3] == 1'b1 && BTCK == 1'b0 && CSTATE != 4'b0100 && CSTATE[3] == 1'b0)?1'b1:1'b0;

always @ (negedge Reset_n or negedge CLK)
begin
  if(Reset_n == 1'b0) 
     SDATA <= 9'b111111111;
  else 
     begin
     if(LD_BYTE == 1'b1) 
        SDATA <= #1 BYTE;
     else if((CSTATE != 4'b0101 && CSTATE != 4'b0100 && BTCK == 1'b0 && DLY == 1'b0) || 
           (CSTATE == 4'b0100 && BTCK == 1'b1)) 
            SDATA <= #1 {SDATA[7:0],SDI};
     end
end


// Start bits (data falling while BTCK is high) are generated as
// we exit states 0000, 0010, and 0101; stop bits (data rising
// while BTCK is high) are generated as we enter state 0101.
// This is done with the STSP signal.

always @ (negedge Reset_n or negedge CLK)
begin
  if(Reset_n == 1'b0) 
     STSP  <= 1'b1;
  else 
    begin
     if(((CSTATE == 4'b0000 || CSTATE == 4'b0101) && STEN == 1'b1 && BTCK == 1'b1) || (CSTATE == 4'b0011))
        STSP <= #1 1'b0;
     else if((CSTATE == 4'b0101 && BCNT == 4'b0000 && BTCK == 1'b1) ||
           (CSTATE == 4'b0010 && BCNT[3] == 1'b1)) 
        STSP <= #1 1'b1;
     
    end
end

// The serial output is driven either by stsp when
// outen is low, or by the MSBit of the shift register
// when oten is high.

assign CTL_VAL = (STSP == 1'b1 || (CSTATE == 4'b0100 && (BCNT[3] != 1'b1 || CCNT == 8'b11111111)))?1'b1:1'b0;

assign SDO = (CSTATE == 4'b0000 || DLY == 1'b1 || CSTATE == 4'b0100 || CSTATE == 4'b0101)?CTL_VAL:SDATA[8];

assign SCK = (BTCK == 1'b1 || (STSP == 1'b1 && (CSTATE == 4'b0000 || CSTATE == 4'b0101)))?1'b1:1'b0;

             
endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧洲精品一区二区三区 | 欧美二区三区的天堂| 国产精品一色哟哟哟| 久久国产精品无码网站| 裸体健美xxxx欧美裸体表演| 日韩精品每日更新| 日韩国产一二三区| 激情综合亚洲精品| 国产精品一区二区在线看| 国产久卡久卡久卡久卡视频精品| 麻豆成人免费电影| 国产成人免费视频一区| 成人精品国产福利| 99这里只有久久精品视频| 色综合久久综合中文综合网| 91久久精品一区二区| 欧美日韩一本到| 欧美成人在线直播| 国产精品美女久久久久久久久久久 | 日本女人一区二区三区| 日本vs亚洲vs韩国一区三区| 日本va欧美va精品发布| 国产成人免费xxxxxxxx| 91丨porny丨国产| 3atv一区二区三区| 中文文精品字幕一区二区| 亚洲综合激情网| 狠狠色综合色综合网络| 99久久综合国产精品| 欧美日韩国产综合一区二区三区 | 成人性视频网站| 色综合天天综合网国产成人综合天 | 亚洲欧美激情一区二区| 日韩av一级电影| 不卡在线视频中文字幕| 欧美日韩精品欧美日韩精品一| 日韩欧美亚洲另类制服综合在线| 国产精品免费人成网站| 日韩国产在线一| 99久久久免费精品国产一区二区| 欧美精品123区| 中文字幕亚洲一区二区av在线 | 亚洲欧美日韩国产中文在线| 三级一区在线视频先锋| 成人福利电影精品一区二区在线观看 | 国产丝袜美腿一区二区三区| 亚洲精品国产精品乱码不99| 激情五月播播久久久精品| 91黄色激情网站| 久久久久国产免费免费| 亚洲国产精品久久一线不卡| 色婷婷精品久久二区二区蜜臂av| 日韩一区二区免费电影| 亚洲一区在线视频观看| 成人午夜av在线| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 欧美一级搡bbbb搡bbbb| 亚洲猫色日本管| 国产精品白丝jk黑袜喷水| 日韩亚洲欧美高清| 亚洲一区二区高清| 91麻豆成人久久精品二区三区| 久久久精品国产99久久精品芒果| 日本午夜一区二区| 欧美日韩一区二区三区不卡| 亚洲精品国产a| 91女神在线视频| 亚洲视频一区在线观看| 成人免费视频播放| 中文字幕的久久| 成人天堂资源www在线| 国产欧美日本一区视频| 精品一区二区三区在线播放视频 | 国产精品白丝jk黑袜喷水| 欧美变态tickling挠脚心| 日韩av成人高清| 欧美美女黄视频| 青青草原综合久久大伊人精品 | 精品一二三四区| 日韩欧美精品在线| 韩国女主播成人在线观看| 精品国产精品一区二区夜夜嗨| 久久精品国产精品亚洲精品| 欧美精品一区二区在线播放| 国产一区二区三区蝌蚪| 国产日韩欧美不卡| 成人激情开心网| 亚洲精品视频观看| 精品视频123区在线观看| 日韩高清不卡一区二区三区| 日韩欧美国产成人一区二区| 免费三级欧美电影| 国产日韩欧美精品综合| 97se亚洲国产综合在线| 亚洲一级不卡视频| 日韩午夜电影在线观看| 高清成人免费视频| 亚洲欧洲综合另类在线| 欧美一区二区三区白人| 国产福利91精品一区| 一区二区三区欧美久久| 91精品一区二区三区在线观看| 国产一区日韩二区欧美三区| 中文字幕久久午夜不卡| 欧美日韩一区二区欧美激情| 九一九一国产精品| 日本一区二区三区dvd视频在线| 一本色道久久加勒比精品| 日韩电影在线免费| 国产精品三级在线观看| 精品视频在线看| 国产成人自拍网| 五月综合激情婷婷六月色窝| 国产亚洲一区二区三区四区| 欧美三级视频在线| 国产精华液一区二区三区| 亚洲国产毛片aaaaa无费看 | 图片区小说区区亚洲影院| 久久亚洲欧美国产精品乐播| 91免费版在线看| 精品一区二区三区视频| 亚洲精品日日夜夜| 国产日韩精品一区二区三区| 制服丝袜亚洲色图| 91在线一区二区| 极品少妇一区二区三区精品视频| 亚洲小说欧美激情另类| 欧美韩国日本不卡| 精品国产亚洲在线| 欧美日韩极品在线观看一区| www.欧美色图| 国产精品亚洲人在线观看| 欧美a级一区二区| 一区二区在线免费观看| 国产精品国产三级国产aⅴ入口 | 日韩一区二区在线观看| 欧美色图第一页| 99re视频精品| 不卡的电视剧免费网站有什么| 精品亚洲成a人| 日本成人在线网站| 肉肉av福利一精品导航| 亚洲国产一区二区视频| 亚洲欧洲日产国产综合网| 国产精品乱码人人做人人爱 | 日韩理论片一区二区| 久久精品欧美一区二区三区不卡| 在线成人av影院| 欧美综合亚洲图片综合区| 91蜜桃免费观看视频| 成人国产精品免费网站| 国产91色综合久久免费分享| 国产伦精一区二区三区| 国产一区二区在线观看免费| 国产在线一区观看| 久99久精品视频免费观看| 成人av午夜电影| www.亚洲精品| 在线视频国内一区二区| 欧美三级蜜桃2在线观看| 欧美日韩一二区| 欧美一二三四区在线| 欧美成人精品3d动漫h| 国产亚洲精品精华液| 国产精品萝li| 一区二区三区电影在线播| 亚洲一区二区av在线| 青青青爽久久午夜综合久久午夜| 久久精品国产一区二区三| 国产91在线观看丝袜| 91美女在线看| 欧美一区二区三区色| 久久色在线观看| 亚洲婷婷国产精品电影人久久| 亚洲一区在线观看视频| 蜜臀久久久久久久| 福利视频网站一区二区三区| 99久久99久久久精品齐齐| 欧美群妇大交群的观看方式| 日韩欧美国产电影| 中文字幕视频一区二区三区久| 一区二区久久久久久| 九色|91porny| 91丨porny丨蝌蚪视频| 欧亚洲嫩模精品一区三区| 欧美大白屁股肥臀xxxxxx| 国产精品嫩草影院com| 午夜不卡在线视频| 国产精品系列在线观看| 欧美亚日韩国产aⅴ精品中极品| 日韩女优视频免费观看| 亚洲免费观看视频| 久久成人综合网| 欧美视频一区二区在线观看| 国产亚洲午夜高清国产拍精品| 一区二区三区在线观看网站| 国产一区二区三区| 欧美性大战久久久久久久蜜臀| 久久久www免费人成精品| 亚洲小少妇裸体bbw|