《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > eeprom_interface Verilog實現的簡單程序(I2C總線接口)

eeprom_interface Verilog實現的簡單程序(I2C總線接口)

2008-08-13
作者:Actel公司

// i2c.vhd
//
//這是是能從一個外部NUM(AT24C02A)讀數據到一個256x8的外部SRAM塊的I2C主接口程序,
//當用于寫NUM的外部邏輯寄存器存取時,SRAM就從外部源讀數據并且把數據寫到特定的I2C地址。
//----------------------------------------------------------------------
//
// ????????????? 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

//這個狀態機是建立AT24C02A串行閃存" title="串行閃存">串行閃存的數據讀寫

// 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.
//
//在上電" title="上電">上電時,INIT被設置為高,狀態機從地址0x000開始執行“連續讀”操作,
//一直進行下去直到所有的256字節都被讀,然后向前到內部存儲區,
//狀態機然后給FLASH發送一個停止位并且清除INIT控制位。

// 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.

//狀態機一直等待UPDT被置為高。當updt比特被置成高,當clk下降沿時,接口把u_enb設成低
//(rd_clk應該在上升沿)。這個狀態機每次updt為高時就寫一個字節數據到外部閃存。
//如果FIFO保持“非空”,則這個塊會一直等到它準備好,然后在接下來的比特進行一個寫周期。

// 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.
//在練習中,狀態機只是一個從0開始計數的計數器,加起來,然后跳到101,再重新計數,
//只有到reset_n被置為低時才返回到0。

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.

//比特計數器在過渡狀態時和在狀態“0011”(起始比特)第一個" title="第一個">第一個循環期間被清空。
//在clk下降沿并且BTCK為低電平時,比特計數器增加。

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.
//字節計數器在狀態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
//UEUB在上電時被清到1,在0111狀態當BCNT=7和BTCK=1時被置為低.

// 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...

//這個裝載到sdata里的值由從哪個狀態退出來決定

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;

//這個數據寄存器為9比特長(一個字節加一個ACK位)
//在狀態0000,0001,0010,0101,0110和0111狀態的ACK循環時,這些都是平行加載" title="加載">加載的。

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.

//起始位(數據下降當BTCK為高)產生于退出狀態0000,0010和0101 時;
//停止位(數據上升當BTCK為高)產生于進入狀態0101時。
//這些由STSP信號完成

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.

//當outen為低時,stsp可以驅動連續的輸出,
//或者當oten為高時,移位寄存器的MSbit也能驅動連續輸出

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

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          国产亚洲欧美另类一区二区三区| 国产色婷婷国产综合在线理论片a| 亚洲国产女人aaa毛片在线| 香蕉久久a毛片| 中文精品视频一区二区在线观看| 国产亚洲精品一区二555| 久久久久久一区二区三区| 欧美精品www| 精品电影一区| 欧美日韩精品在线观看| 欧美成人免费一级人片100| 精品999在线观看| 欧美日韩调教| 欧美激情视频网站| 在线亚洲一区二区| 99精品久久免费看蜜臀剧情介绍| 欧美色欧美亚洲另类二区| 欧美视频二区| 欧美日韩精品一区二区在线播放| 一区二区三区久久| 日韩亚洲欧美成人| 国产精品一卡二卡| 亚洲私人影吧| 亚洲视频电影在线| 国产九九精品视频| 久久亚洲精品视频| 国产真实乱偷精品视频免| 欧美国产日韩二区| 另类图片综合电影| 久久综合久色欧美综合狠狠| 玖玖精品视频| 99精品免费网| 影音先锋在线一区| 久久精品国产99国产精品| 亚洲三级性片| 国产视频综合在线| 国产欧美日韩一区二区三区在线观看| 国产模特精品视频久久久久| 欧美日韩精品在线视频| 免费h精品视频在线播放| 欧美黄色日本| 国产精品大片wwwwww| 欧美视频一区在线观看| 久久免费少妇高潮久久精品99| 亚洲一区二区精品视频| 亚洲系列中文字幕| 国产精品久久久久久福利一牛影视| 久热精品视频在线观看一区| 一区二区三区鲁丝不卡| 国产欧美一区二区三区视频| 伊人成综合网伊人222| 在线观看成人网| 国产精品视频第一区| 亚洲高清色综合| 亚洲一区二区三区免费视频| 国产精品视频成人| 黄色资源网久久资源365| 国产伦精品一区二区三区照片91| 久久精品在线视频| 99亚洲一区二区| 日韩午夜激情| 欧美大片在线看免费观看| 亚洲性线免费观看视频成熟| 国产欧美一区二区白浆黑人| 国产老肥熟一区二区三区| 欧美一区二区私人影院日本| 欧美香蕉大胸在线视频观看| 亚洲欧洲一区二区在线播放| 欧美成人综合在线| 久久久精品国产一区二区三区| 国产精品国产三级国产| 亚洲精品综合久久中文字幕| 亚洲午夜91| 欧美黄在线观看| 久久黄色级2电影| 亚洲六月丁香色婷婷综合久久| 一区二区三区四区在线| 老鸭窝91久久精品色噜噜导演| 亚洲精品系列| 狠狠色丁香婷婷综合| 国产精品xvideos88| 亚洲福利专区| 亚洲国产精品va在线观看黑人| 亚洲福利视频免费观看| 亚洲三级视频| 一色屋精品亚洲香蕉网站| 欧美呦呦网站| 欧美一区二区三区播放老司机| 欧美国产日韩亚洲一区| 一区二区免费在线视频| 欧美日韩18| 欧美激情亚洲一区| 国产精品久久九九| 国产永久精品大片wwwapp| 欧美xxx成人| 91久久国产自产拍夜夜嗨| 狠狠色狠狠色综合| 国产一区二区三区视频在线观看| 欧美午夜理伦三级在线观看| 在线 亚洲欧美在线综合一区| 欧美性猛交一区二区三区精品| 欧美日韩精品久久| 国产精品久久久久久av福利软件| 欧美在线|欧美| 国产精品五月天| 久久精品国产一区二区三| 伊人精品久久久久7777| 99国产精品国产精品毛片| 欧美国产一区视频在线观看| 一区二区三区在线视频观看| 亚洲片区在线| 国产精品美女久久久久久免费| 影音先锋日韩有码| 欧美a一区二区| 欧美一区二区三区日韩视频| 亚洲韩国精品一区| 国产香蕉久久精品综合网| 亚洲一区二区视频在线| 亚洲欧洲日产国产综合网| 亚洲视频二区| 欧美专区亚洲专区| 国产精品日韩欧美大师| 国产精品久久久久77777| 国产亚洲va综合人人澡精品| 国产区精品在线观看| 国产精品美女在线| 久久久久久久尹人综合网亚洲| 欧美日韩国产999| 亚洲国产成人久久综合| 亚洲在线中文字幕| 免费在线视频一区| 久久久精品视频成人| 国产精品v日韩精品| 国产精品国产三级欧美二区| 久久综合狠狠综合久久激情| 欧美日本精品在线| 国产日产高清欧美一区二区三区| 亚洲视频一区二区在线观看| 日韩亚洲欧美高清| 欧美高清视频在线播放| 国产精品国产三级国产普通话蜜臀| 国产精品系列在线播放| 在线中文字幕不卡| 91久久夜色精品国产九色| 欧美理论视频| 国产亚洲精品久久久久久| 国内一区二区三区在线视频| 亚洲第一中文字幕| 99视频一区二区三区| 亚洲电影在线免费观看| 国产精品一区二区男女羞羞无遮挡| 狠狠干狠狠久久| 欧美亚洲在线观看| 国产一区二区成人| 欧美在线看片| 亚洲免费人成在线视频观看| 国产亚洲精品一区二区| 亚洲欧美日韩区| 亚洲美女在线国产| 韩国成人理伦片免费播放| 亚洲精品国产品国语在线app| 欧美一区综合| 欧美视频在线观看一区二区| 黄色成人av网| 亚洲精品欧美日韩专区| 亚洲精品网站在线播放gif| 国产欧美精品日韩区二区麻豆天美| 国产精品尤物福利片在线观看| 黄色成人免费观看| 欧美四级在线| 一本一本a久久| 亚洲欧美中文在线视频| 欧美剧在线观看| 国产亚洲欧美日韩一区二区| 欧美日本在线视频| 亚洲三级电影全部在线观看高清| 国产欧美一区二区三区在线看蜜臀| 激情久久久久久久| 欧美全黄视频| 国产精品视频男人的天堂| 在线视频你懂得一区二区三区| 久久精品2019中文字幕| 国产精品99久久99久久久二8| 免费91麻豆精品国产自产在线观看| 国产一区二区三区的电影| 亚洲国产一区二区三区在线播| 日韩视频精品在线观看| 国产欧美精品在线观看| 久久国产福利国产秒拍| 欧美一级一区| 欧美在线播放| 欧美性猛交xxxx乱大交蜜桃| 国产欧美在线看| 在线精品亚洲| 国产精品入口| 国产精品v欧美精品∨日韩| 亚洲人www| 激情av一区| 欧美在线视频免费| 欧美性色视频在线| 亚洲综合色激情五月| 性欧美18~19sex高清播放| 国产精品免费区二区三区观看| 亚洲欧美亚洲| 欧美日韩成人综合| 欧美日韩免费一区二区三区视频| 欧美精品一区在线播放| 亚洲第一色中文字幕| 在线不卡视频| 欧美国产一区视频在线观看| 国产精品99久久久久久久女警| 久久综合婷婷| 欧美三级黄美女| 欧美一区二区在线看| 亚洲视频在线免费观看| 欧美一级久久久久久久大片| 久久婷婷国产综合国色天香| 欧美日韩1234| 亚洲综合社区| 久久精品国产成人| 久久精品免费看| 欧美一级夜夜爽| 欧美在线一级va免费观看| 欧美成人亚洲| 欧美人与禽猛交乱配视频| 一区二区三区 在线观看视频| 伊甸园精品99久久久久久| 久久久噜久噜久久综合| 欧美粗暴jizz性欧美20| 欧美精品日韩综合在线| 欧美一二三区精品| 怡红院精品视频| 亚洲视频狠狠| 麻豆久久久9性大片| 国产在线视频欧美一区二区三区| 久久香蕉国产线看观看网| 亚洲国产人成综合网站| 亚洲国产天堂久久综合| 亚洲免费观看在线观看| 亚洲免费在线电影| 久久精品成人| 在线视频国内自拍亚洲视频| 国产午夜精品美女视频明星a级| 在线观看视频免费一区二区三区| 亚洲国产精品第一区二区三区| 亚洲高清av| 亚洲你懂的在线视频| 午夜国产精品视频| 国产精品www色诱视频| 欧美色精品天天在线观看视频| 一本色道久久综合亚洲91| 亚洲高清资源| 亚洲缚视频在线观看| 久久精品视频网| 久久综合九色综合网站| 欧美日韩国产精品一区| 中文一区字幕| 久久亚洲精品视频| 亚洲永久网站| 国产女人18毛片水18精品| 国产精品自拍一区| 国产精品麻豆欧美日韩ww| 久久久久国产精品人| 欧美成人精品在线| 亚洲一区欧美| 国产偷自视频区视频一区二区| 欧美理论电影网| 亚洲另类一区二区| av成人毛片| 欧美一区二区三区视频免费播放| 亚洲欧美另类中文字幕| 久久精品一区二区三区不卡牛牛| 亚洲国产一区二区三区在线播| 亚洲天天影视| 亚洲精品在线观看视频| 激情综合色综合久久| 国产精品久久久久国产a级| 国产精品精品视频| 久久久久久久久久看片| 亚洲精品影院| 国产欧美日韩视频一区二区| 欧美激情综合五月色丁香小说| 欧美系列一区| 黄色一区三区| 欧美日韩国内| 国产亚洲激情视频在线| 欧美高清视频一区二区三区在线观看| 一区视频在线| 国内精品视频一区| 国产日韩精品视频一区| 亚洲精品激情| 在线视频你懂得一区| 欧美91福利在线观看| 国产精品免费网站在线观看| 一区二区三区视频在线| 欧美专区一区二区三区| 久久精品一本| 久久一区免费| 国产在线精品一区二区夜色| 久久精品一区二区| 香蕉久久夜色精品| 日韩特黄影片| 宅男噜噜噜66一区二区66| 国产精品乱人伦一区二区| 黄色成人免费观看| 国产一二三精品| 亚洲综合社区| 国产精品theporn| 国产亚洲在线观看| 欧美本精品男人aⅴ天堂| 亚洲美女精品一区| 久久久青草青青国产亚洲免观| 久久人人超碰| 欧美国产精品一区| 久久久水蜜桃av免费网站| 国产精品国产成人国产三级| 一区二区三区四区五区视频| 国产精品盗摄一区二区三区| 一本久道综合久久精品| 久久久美女艺术照精彩视频福利播放| 久久精品免费观看| 校园春色国产精品| 先锋a资源在线看亚洲| 欧美三级精品| 国内激情久久| 国产精品成人aaaaa网站| 99综合精品| 99综合在线|