wwwxxx国产_337p日本欧洲亚洲大胆张筱雨_免费在线看成人av_日本黄色不卡视频_国产精品成熟老女人_99视频一区_亚洲精品97久久中文字幕_免费精品视频在线_亚洲色图欧美视频_欧美一区二三区

標題: 開源自己做的CPLD+SRAM液晶驅動verilog代碼 [打印本頁]

作者: jianfengxixi    時間: 2019-6-9 15:59
標題: 開源自己做的CPLD+SRAM液晶驅動verilog代碼
斷斷續續地學了verilog HDL和FPGA一段時間,一直沒有完整的做一個東西,看到論壇上有做TFT控制器的,于是就仿制了一個.
verilog程序大部分是自己寫的,一些部分如異步寫入,HSync,VSync時序產生部分參考了"dzng11"
廢話不說了:直接上圖上資料


電路原理圖如下:




verilog HDL源程序如下:
  1. /**********************************************************************
  2. 通用4.3寸tft驅動
  3. 地址1位
  4. -----------------------------------------------------------------——----
  5. A0=0寄存器,寄存器0-7
  6. 0 SRAM數據
  7. 1 xIdex x軸寄存器
  8. 2 yIdex y軸寄存器
  9. 3 yend  結束寄存器,用于窗口繪圖加速

  10. 4 前景顏色
  11. 5 背景色
  12. 6
  13. 7 系統狀態0-15位
  14.   bo-b2          b3          b4-b6              b7-b9             b10-b12   
  15.    背光        顯示開/關      顯示方式           要寫入的頁          當前顯示頁
  16.                                                必須位x00                必須位x00
  17.                                                                                                                          x可改變(b7)      x可改變(b10)
  18. -----------------------------------------------------------------------
  19. AO=1數據

  20. 2011.12.5
  21. ***********************************************************************/

  22. /*
  23. 接口說明:
  24. Clk54:系統晶振,選擇54M晶振
  25. SysRst:系統復位線.
  26. ExDataBus:外部16位數據總線
  27. ExCs:控制器片選,
  28. ExRs:數據批令選擇
  29. ExWr:寫信號
  30. ExRd:讀信號
  31. RamAddrBus:顯存地址線.
  32. RamDataBus:顯存數據總線
  33. RamCs:顯存片選
  34. RamWe:顯存寫選通.
  35. LedOn:背光控制PWM
  36. DE:TFT屏
  37. DE:VSyncTFT屏,
  38. HSync:TFT屏
  39. RGB:TFT屏
  40. Pclk:TFT屏);
  41. */

  42. module tft43(Clk54, SysRst, ExDataBus, ExCs, ExRs, ExWr, ExRd, RamAddrBus,
  43.              RamDataBus, RamCs, RamWe,RamOe, LedOn, DE, VSync, HSync, RGB, Pclk);
  44.     input Clk54, SysRst, ExCs, ExRs, ExRd, ExWr;
  45.     inout [15:0] ExDataBus;
  46.     inout [15:0] RamDataBus;
  47.     output [17 : 0] RamAddrBus;
  48.     output [15:0] RGB;
  49.     output RamCs, RamWe,RamOe, LedOn, DE, VSync, HSync, Pclk;

  50.     reg [2:0] ClkCnt_Q3;
  51.     reg DotClkEn_Q;
  52.     reg Pclk_Q;
  53.     reg WrEn_Q;
  54.     reg [15:0]ExBusOut_Q;
  55.     reg [15:0] ExOutM;
  56.     reg [15:0] WriteRgb_Q;
  57.     reg ExWrClk_Q;
  58.     reg ExRsR_Q;
  59.     reg ExCsR_Q;
  60.     reg ExRdClk_Q;
  61.     reg ExRdClk_Q1;
  62.     reg ExRdClk_Q2;
  63.   
  64.     reg ExWrClk_Q1;
  65.     reg ExWrClk_Q2;


  66.     reg [12:0] SramAddr;
  67.     reg [15:0] PrePareData;
  68.     reg [7:0] IndexData;
  69.     reg InRamWe;
  70.     reg IncAddr;
  71.     reg XRegOver;
  72.     reg YRegOver;
  73.     reg AskWr;

  74.     reg [15:0] RGB_Q;
  75.     reg [15:0] InBusOut_Q;
  76.     reg [8:0] XRegValue_Q;
  77.     reg [8:0] YRegValue_Q;
  78.     reg [15:0] SysCmdValue_Q;
  79.     reg [2:0] RegAddr_Q;
  80.     reg RamWeReg_Q;
  81.     reg RamTriState_Q;
  82.     reg [2:0] FillCount_Q;
  83.     reg [15:0] BRGBValue_Q;
  84.     reg [15:0] FRGBValue_Q;
  85.     reg [17:0] RamAddrBus_Q;
  86.     reg FillHead_Q;
  87.     reg [8:0] HsCount_Q;
  88.     reg [8:0] DotCount_Q;
  89.     reg SelDispRam_Q;
  90.     reg RamCsReg_Q;
  91.     reg DsMark;
  92.     reg HsMark;
  93.     reg [1:0]DsState_Q;
  94.     reg [1:0]HsState_Q;
  95.     reg DE_Q;
  96.     reg [4:0]LedCount_Q;
  97.     reg LedOn_Q,LedOn_W;

  98.     assign Pclk = Pclk_Q;
  99.     assign RGB = RGB_Q;
  100.     assign RamAddrBus = {RamAddrBus_Q};
  101.     assign RamWe = RamWeReg_Q;
  102.     assign RamCs = RamCsReg_Q;
  103.          assign RamOe = RamCsReg_Q;/////
  104.     assign RamDataBus = (RamTriState_Q | Clk54)?16'bzzzzzzzzzzzzzzzz:InBusOut_Q;
  105.     assign VSync = DE_Q;
  106.     assign HSync = DE_Q;//1'b0;
  107.     assign DE = DE_Q;
  108.     assign LedOn = LedOn_Q;
  109.     assign ExDataBus = ExOutM;   
  110. /*
  111. --1.將54M主時鐘6分頻,產生9M時鐘并輸出至引腳Pclk
  112. --2.輸出DotClkEn為9M信號同步其他進程.高電平為1個主時鐘周期,低電平5個主時鐘周期
  113. --3.技巧: 001,010,011,100,101,110.共6個狀態,高位剛好是6分頻等寬.
  114. */
  115.     always @(posedge Clk54 or negedge SysRst)
  116.     begin
  117.         if (!SysRst) begin
  118.             ClkCnt_Q3   = 3'd1;
  119.             Pclk_Q      = 1'b0;
  120.             DotClkEn_Q  = 1'b0;
  121.         end else begin
  122.             if (ClkCnt_Q3[2] & ClkCnt_Q3[1]) begin
  123.                 ClkCnt_Q3 <= 3'd1;
  124.             end else begin
  125.                 ClkCnt_Q3 <= ClkCnt_Q3 + 3'd1;
  126.             end
  127.             Pclk_Q <= (SysCmdValue_Q[3])?1'b0:ClkCnt_Q3[2];
  128.             DotClkEn_Q <= ((~ClkCnt_Q3[2]) & ClkCnt_Q3[1] & ClkCnt_Q3[0]);
  129.         end
  130.     end
  131. /*
  132. --外部接口在RD及CS低電平期間輸出內部數據
  133. --RS為0時輸出忙信號.RS為1時輸出當前地址的內部數據
  134. */
  135.     always @(SysRst or ExBusOut_Q or WrEn_Q or ExCs or ExRs or ExWr or ExRd)
  136.      begin
  137.         if (!SysRst) begin
  138.             ExOutM = 16'bzzzzzzzzzzzzzzzz;
  139.         end else begin
  140.             if ((~ExCs) & ExWr & (~ExRd)) begin
  141.                 ExOutM = (ExRs)?ExBusOut_Q:({15'd0,WrEn_Q});
  142.             end else begin
  143.                 ExOutM = 16'bzzzzzzzzzzzzzzzz;
  144.             end
  145.         end
  146.     end
  147. /*
  148. --外部異步WR寫入數據.
  149. */
  150.     always @(posedge ExWr or negedge SysRst)
  151.     begin
  152.         if (!SysRst) begin
  153.             WriteRgb_Q = 16'd0;
  154.             ExWrClk_Q  = 1'b0;
  155.             RegAddr_Q  = 3'd0;
  156.          end else begin
  157.             if (!ExCs) begin
  158.                 if (!ExRs) begin
  159.                     RegAddr_Q <= ExDataBus[2:0];
  160.                 end else begin
  161.                     WriteRgb_Q <= ExDataBus;
  162.                     ExWrClk_Q <= ~ExWrClk_Q;
  163.                 end
  164.             end
  165.         end
  166.     end
  167. /*
  168. --外部異步RD讀出數據.
  169. */
  170. always @(negedge ExRd or negedge SysRst)
  171. begin
  172.         if (!SysRst) begin
  173.             ExRsR_Q = 1'b0;
  174.             ExCsR_Q = 1'b1;
  175.          end else begin
  176.             ExCsR_Q <= ExCs;
  177.             ExRsR_Q <= ExRs;
  178.         end
  179. end
  180. always @(posedge ExRd or negedge SysRst)
  181. begin
  182.         if (!SysRst) begin
  183.             ExRdClk_Q = 1'b0;
  184.          end else begin
  185.             if  ((~ExCsR_Q) & ExRsR_Q) begin
  186.                 ExRdClk_Q <= ~ExRdClk_Q;
  187.             end
  188.         end
  189. end
  190. /******************************************
  191. --主時鐘打兩拍同步采用外部讀寫信號
  192. ******************************************/
  193.     always @(posedge Clk54 or negedge SysRst)
  194.     begin
  195.         if (!SysRst) begin
  196.             ExRdClk_Q1 = 1'b0;
  197.             ExRdClk_Q2 = 1'b0;
  198.             ExWrClk_Q1 = 1'b0;
  199.             ExWrClk_Q2 = 1'b0;
  200.            
  201.         end else begin
  202.             ExRdClk_Q1 <= ExRdClk_Q;
  203.             ExRdClk_Q2 <= ExRdClk_Q1;
  204.             ExWrClk_Q1 <= ExWrClk_Q;
  205.             ExWrClk_Q2 <= ExWrClk_Q1;
  206.         end
  207.     end

  208.     always @(posedge Clk54 or negedge SysRst)
  209.     begin
  210.         if (!SysRst) begin
  211.             InBusOut_Q  = 16'd0;
  212.             ExBusOut_Q  = 16'd0;
  213.             XRegValue_Q = 9'd0;
  214.             YRegValue_Q = 9'd0;
  215.             SysCmdValue_Q = 16'b0000000000110000;
  216.             WrEn_Q = 1'b0;
  217.             RamWeReg_Q = 1'b1;
  218.             RamTriState_Q = 1'b1;
  219.             RGB_Q = 16'd0;
  220.             FillCount_Q = 3'd7;
  221.             BRGBValue_Q  = 16'd0;
  222.             FRGBValue_Q  = 16'd0;
  223.             RamAddrBus_Q = 18'd0;
  224.             RamCsReg_Q = 1'b1;
  225.             PrePareData = 16'd0;
  226.         end else begin
  227.             if (ExRdClk_Q2 ^ ExRdClk_Q1) begin
  228.                 IncAddr = 1'b1;
  229.             end else begin
  230.                 IncAddr = 1'b0;
  231.             end
  232.             if (ExWrClk_Q2 ^ ExWrClk_Q1) begin
  233.                 AskWr = 1'b1;
  234.             end else begin
  235.                 AskWr = WrEn_Q;
  236.             end
  237.             XRegOver = (XRegValue_Q == 9'b111011111)?1'b1:1'b0;
  238.             YRegOver = (YRegValue_Q == 9'b100001111)?1'b1:1'b0;
  239.             PrePareData = WriteRgb_Q;
  240.             IndexData[7:0] = WriteRgb_Q[7:0];
  241.             InRamWe = 1'b1;
  242.             if (!ClkCnt_Q3[0]) begin
  243.                 if (AskWr) begin
  244.                     case (RegAddr_Q)
  245.                     3'b000:begin
  246.                             XRegValue_Q <= PrePareData[8:0];
  247.                             WrEn_Q <= 1'b0;
  248.                         end
  249.                     3'b001:begin
  250.                             YRegValue_Q <= PrePareData[8:0];
  251.                             WrEn_Q <= 1'b0;
  252.                         end
  253.                                                   3'b010:begin
  254.                             InRamWe = 1'b0;
  255.                             IncAddr = 1'b1;
  256.                             WrEn_Q <= 1'b0;
  257.                         end
  258.                     3'b100:begin
  259.                             FRGBValue_Q <= PrePareData;
  260.                             WrEn_Q <= 1'b0;
  261.                         end
  262.                     3'b101:begin
  263.                             BRGBValue_Q <= PrePareData;
  264.                             WrEn_Q <= 1'b0;
  265.                         end
  266.                     3'b110:begin
  267.                             SysCmdValue_Q <= PrePareData;
  268.                             WrEn_Q <= 1'b0;
  269.                         end
  270.                     
  271.                     3'b011:begin
  272.                             if (!IndexData[FillCount_Q]) begin
  273.                                 PrePareData = BRGBValue_Q;
  274.                                 InRamWe = SysCmdValue_Q[12];
  275.                             end else begin
  276.                                 PrePareData = FRGBValue_Q;
  277.                                 InRamWe = 1'b0;
  278.                             end
  279.                             IncAddr = 1'b1;
  280.                             WrEn_Q <= (FillCount_Q[0] | FillCount_Q[1] | FillCount_Q[2]);
  281.                             FillCount_Q <= FillCount_Q + 3'd7;
  282.                         end
  283.                     3'b111:begin
  284.                             if (FillHead_Q) begin
  285.                                 IncAddr = 1'b1;
  286.                                 InRamWe = 1'b0;
  287.                                 if (YRegOver & XRegOver) begin
  288.                                     WrEn_Q <= 1'b0;
  289.                                 end
  290.                             end else begin
  291.                                 WrEn_Q <= 1'b1;
  292.                             end
  293.                         end
  294.                     endcase
  295.                 end
  296.                 RGB_Q <= (SysCmdValue_Q[3])?16'd0:RamDataBus;
  297.                 SramAddr[12:4] = YRegValue_Q[8:0];
  298.                 SramAddr[3:0] = XRegValue_Q[8:5];
  299.                 RamAddrBus_Q[4:0] <= XRegValue_Q[4:0];
  300.                 RamAddrBus_Q[17] <= SysCmdValue_Q[7];
  301.             end else begin
  302.                 if (AskWr) begin
  303.                     WrEn_Q <= 1'b1;
  304.                 end
  305.                 ExBusOut_Q <= RamDataBus;
  306.                 SramAddr[12:4] = HsCount_Q[8:0];
  307.                 SramAddr[3:0] = DotCount_Q[8:5];
  308.                 RamAddrBus_Q[4:0] <= DotCount_Q[4:0];
  309.                 RamAddrBus_Q[17] <= SelDispRam_Q;
  310.             end
  311.             InBusOut_Q <= PrePareData;
  312.             RamTriState_Q <= InRamWe;
  313.             RamWeReg_Q <= InRamWe;
  314.             SramAddr[12:0] = SramAddr[12:0] - {4'd0,SramAddr[12:4]};
  315.             RamAddrBus_Q[16:5] <= SramAddr[11:0];
  316.      /*根據配置字調整XY*/
  317.             if (IncAddr) begin
  318.                 case (SysCmdValue_Q[6:4])
  319.                 3'b001:begin
  320.                         if (XRegOver) begin
  321.                             XRegValue_Q <= 9'd0;
  322.                         end else begin
  323.                             XRegValue_Q <= XRegValue_Q + 9'd1;
  324.                         end
  325.                     end
  326.                 3'b011:begin
  327.                         if (XRegOver) begin
  328.                             XRegValue_Q <= 9'd0;
  329.                             if (YRegOver) begin
  330.                                 YRegValue_Q <= 9'd0;
  331.                             end else begin
  332.                                 YRegValue_Q <= YRegValue_Q + 9'd1;
  333.                             end
  334.                         end else begin
  335.                             XRegValue_Q <= XRegValue_Q + 9'd1;
  336.                         end
  337.                     end
  338.                 3'b110:begin
  339.                         if (YRegOver) begin
  340.                             YRegValue_Q <= 9'd0;
  341.                         end else begin
  342.                             YRegValue_Q <= YRegValue_Q + 9'd1;
  343.                         end
  344.                      end
  345.                 3'b111:begin
  346.                         if (YRegOver) begin
  347.                             YRegValue_Q <= 9'd0;
  348.                             if (XRegOver) begin
  349.                                 XRegValue_Q <= 9'd0;
  350.                             end else begin
  351.                                 XRegValue_Q <= XRegValue_Q + 9'd1;
  352.                             end
  353.                         end else begin
  354.                             YRegValue_Q <= YRegValue_Q + 9'd1;
  355.                         end
  356.                     end
  357.                 default:begin
  358.                     end
  359.                 endcase
  360.             end
  361.             RamCsReg_Q <= SysCmdValue_Q[3];
  362.         end
  363.     end
  364.     /*--產生TFT行同步*/
  365.     always @(posedge Clk54 or negedge SysRst)
  366.     begin
  367.         if (!SysRst) begin
  368.             DotCount_Q = 9'd0;
  369.             DsState_Q = 2'd0;
  370.             DsMark = 1'b0;
  371.         end else begin
  372.             if (DotClkEn_Q) begin
  373.                 case (DsState_Q)
  374.                 2'd0:/*=>--41 相當于<= 40*/
  375.                     DsMark = (DotCount_Q[5] & DotCount_Q[3]);
  376.                 2'd1:/*when "01" =>--2 相當于<= 1*/
  377.                     DsMark = DotCount_Q[0];
  378.                 2'd2:/*=>--480 相當于<= 479*/
  379.                     DsMark = (DotCount_Q[0] & DotCount_Q[1] & DotCount_Q[2] & DotCount_Q[3] &
  380.                               DotCount_Q[4] & DotCount_Q[6] & DotCount_Q[7] & DotCount_Q[8]);
  381.                 2'd3:/*--2 相當于<= 1*/
  382.                     DsMark = DotCount_Q[0];
  383.                 endcase
  384.                 DsState_Q <= DsState_Q + {1'b0,DsMark};
  385.                 DotCount_Q <= (DsMark)?9'd0:(DotCount_Q + 9'd1);
  386.             end
  387.         end
  388.     end
  389. /*--產生TFT幀同步信號*/
  390.     always @(posedge Clk54 or negedge SysRst)
  391.     begin
  392.         if (!SysRst) begin
  393.             DE_Q  = 1'b0;
  394.         end else begin
  395.             DE_Q <= (SysCmdValue_Q[3])?1'b0:(HsState_Q[1] & (~HsState_Q[0]) & DsState_Q[1] & (~DsState_Q[0]));
  396.         end
  397.     end
  398. /*--產生幀同步時鐘*/
  399.     always @(posedge Clk54 or negedge SysRst)
  400.     begin
  401.         if (!SysRst) begin
  402.             HsCount_Q = 9'd0;
  403.             HsState_Q = 2'd0;
  404.             FillHead_Q = 1'b0;
  405.             SelDispRam_Q = 1'b0;
  406.             LedCount_Q = 5'd0;
  407.         end else begin
  408. ……………………

  409. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

所有資料51hei提供下載:
tft43.rar (9.52 MB, 下載次數: 112)
stm32程序.7z (559.44 KB, 下載次數: 87)




作者: xuzhien    時間: 2019-9-6 11:47
謝謝分享
作者: xuzhien    時間: 2019-9-6 13:51
正好需要,放謝分享
作者: lwk51h    時間: 2019-10-10 15:05
SramAddr[12:4] = YRegValue_Q[8:0];
                SramAddr[3:0] = XRegValue_Q[8:5];
                RamAddrBus_Q[4:0] <= XRegValue_Q[4:0];
                RamAddrBus_Q[17] <= SysCmdValue_Q[7];
版主能解釋一下這段代碼嗎

作者: lwk51h    時間: 2019-10-23 14:42
這個板子哪里有賣
作者: jovew    時間: 2019-12-8 14:08
這個板子有的賣嗎? 想買一個看看,找了很久才發現
作者: stickvc    時間: 2020-1-2 17:01
這個板子有的賣嗎? 想買一個看看,找了很久才發現
作者: ndht    時間: 2020-4-11 08:24
寫的不錯,謝謝樓主開源
作者: dl_gyj    時間: 2020-5-28 11:50
我也想買一個?板子有買的嗎?
作者: dl_gyj    時間: 2020-5-29 23:31
ExOutM = (ExRs)?ExBusOut_Q:({15'd0,WrEn_Q}
作者: dl_gyj    時間: 2020-5-29 23:33
是什么意思?
作者: dl_gyj    時間: 2020-5-29 23:43
ExOutM = (ExRs)?ExBusOut_Q:({15'd0,WrEn_Q});
作者: dl_gyj    時間: 2020-6-11 23:42
是拼接
作者: eemkutay    時間: 2020-8-17 05:10
thanks very good
作者: mcza30    時間: 2020-9-4 08:27
板子有買的嗎?
作者: zuochunhua2009    時間: 2020-10-5 21:58
剛學一個月,感覺這代碼問題挺多, 時序邏輯語句塊中間使用了阻塞賦值,這樣不對吧?!  另外這些塊內部描述的語句過多,估計很難綜合出正確的結果
作者: frank_tw    時間: 2022-7-17 10:19
看看!
寫的不錯!
作者: jovew    時間: 2022-9-14 12:13
好東西!值得收藏
作者: jovew    時間: 2022-9-14 12:16
樓主,能夠分享一下原理圖和PCB嗎?




歡迎光臨 (http://www.izizhuan.cn/bbs/) Powered by Discuz! X3.1
亚洲国产综合在线观看| 爱情岛论坛亚洲品质自拍视频网站| 黄色片一级视频| 91精品国产乱码| 一本色道久久综合亚洲精品高清| 在线视频您懂的| 亚洲av综合一区| 91嫩草视频在线观看| 欧美亚洲一区三区| 青青草97国产精品免费观看| 欧美xoxoxo| 日韩欧美性视频| 国产三级中文字幕| 欧美激情久久久久| 亚洲综合免费观看高清完整版 | 日本少妇激情视频| 一区二区三区四区免费观看| 日本特黄特色aaa大片免费| 亚洲欧美成人网| 成人a区在线观看| 精精国产xxxx视频在线| 欧美性猛交 xxxx| 久久福利小视频| 欧美日韩一区二区视频在线| 色婷婷av一区二区三区大白胸| 一本色道久久精品| 久久免费影院| 成人三级视频在线观看| 久久99精品国产麻豆不卡| 久久久精品视频免费| av中文字幕av| 欧美激情视频三区| 色婷婷av一区二区三区gif| 青青草国产成人av片免费| 欧美成人高清视频在线观看| 在线看片你懂得| 少妇人妻一区二区| 深爱五月激情网| 一级特黄录像免费播放全99| 国模视频一区二区三区| 欧美video巨大粗暴18| 亚洲女同二女同志奶水| 国产1区2区3区中文字幕| 欧洲午夜精品久久久| 日韩女优视频免费观看| 亚洲色欲色欲www在线观看| 国产麻豆综合| 久久久伦理片| 久久久男人天堂| 传媒在线观看| 91野花视频| www.五月婷| 欧美日韩黄色网| 国产成人精品久久二区二区| 亚洲伊人影院| 欧美孕妇孕交| 久久久久久久久久久久久91| 69视频免费看| 中国极品少妇xxxx| 欧美 日本 亚洲| 成人免费看片网址| 国精产品一区一区三区有限在线| 欧美日韩夫妻久久| 亚洲欧美日韩久久| 成人在线综合网站| 久久久国产亚洲精品| 国产一区二区三区四区大秀| 91在线成人| 黄网页免费在线观看| 无码人妻精品一区二区中文| 欧美 日韩 亚洲 一区| 国产精品12| 2019日本中文字幕| 一区二区福利视频| 在线观看不卡一区| 亚洲欧美激情一区二区| 99久久综合国产精品| 日本vs亚洲vs韩国一区三区二区| 久久一级电影| 久久草在线视频| 久久婷婷五月综合色丁香| 成年人网站在线| 色视频在线观看| 最近中文字幕mv2018在线高清| 日本黄色免费| 欧美黑人xxxxx性受| 亚洲免费国产视频| 精人妻无码一区二区三区| 乱h高h女3p含苞待放| 天堂www中文在线资源| 极品粉嫩美女露脸啪啪| 无码专区aaaaaa免费视频| 日韩视频在线免费播放| 日本免费高清一区二区| 精品一区二区三区自拍图片区 | 国产又粗又黄视频| 欧美三级免费| 一级aaaa毛片| 午夜写真片福利电影网| www.黄色网| 亚洲综合123| 国产九九热视频| 国产一级爱c视频| 成人在线视频一区二区三区| 久久天天躁日日躁| 亚洲天堂av在线免费| 亚洲第一福利网站| 欧美高清性hdvideosex| 蜜桃一区二区| 国产精品第一| 蜜桃视频在线观看免费视频| 日色在线视频| 亚洲夫妻av| 全部孕妇毛片丰满孕妇孕交 | 18精品爽视频在线观看| theporn国产精品| 欧美男女爱爱视频| 性高湖久久久久久久久aaaaa| 久久久成人精品一区二区三区| 欧美精品一二区| 精品国产一区二区三区久久狼5月| 亚洲欧美日韩第一区| av永久免费观看| 国产狼人综合免费视频| 69久久夜色精品国产69| 亚洲精品国产福利| 亚洲精品狠狠操| 精品久久久久久无| 日韩高清有码在线| 欧美性一二三区| 9191精品国产综合久久久久久| 欧美午夜xxx| 精品国产乱码久久久久久天美| 黑人巨大亚洲一区二区久| 成码无人av片在线观看网站| 国产天堂资源| 91精品国产福利尤物| 国产精品入口麻豆完整版| 成人亚洲国产| 欧美精品xx| 色妇色综合久久夜夜| 欧美色图第二页| 欧美日韩亚洲国内综合网| 国产精品冒白浆免费视频 | 毛片在线免费播放| 亚洲高清视频免费观看| 午夜精品福利视频| 在线观看91精品国产麻豆| 欧美三片在线视频观看 | 国产成人免费电影| 欧美日韩在线一区二区三区| 欧美日韩系列| 国产精品一二三在线观看| 日本在线xxx| 国产探花在线看| 91社区视频在线观看| 国产精品第九页| a级片免费视频| 亚洲日韩色图| 麻豆资源在线| 久久久久久久久免费视频| 韩国精品主播一区二区在线观看 | 国产视频1区2区| 手机av免费观看| 午夜福制92视频| 日韩黄色影院| 国产chinese男男gaygay网站| 四虎黄色影院| 欧洲亚洲两性| 婷婷中文字幕在线观看| 久久精品99国产精| 欧美日溪乱毛片| 免费黄网站在线播放| 国产99亚洲| 91网上在线视频| 777久久久精品| 欧美激情免费在线| 亚洲一区二区少妇| 国产精品美女久久久久av超清| 欧美在线中文字幕| 成人免费福利在线| 日韩av高清在线看片| 精品少妇一区二区三区在线| 欧美极品视频在线观看| 天堂在线免费视频| 麻豆免费版在线观看| 亚洲激情自拍| 午夜精品福利一区二区三区av| 欧美成人免费一级人片100| 神马一区二区影院| 欧美性生给视频| 国产视频2区| 免费观看亚洲| 国产一区二区按摩在线观看| 欧美成人精品3d动漫h| 国产伦精品一区二区| 国产一级免费片| 亚洲激情视频小说| 另类综合图区| 青春草在线视频| 日韩va欧美va亚洲va久久| 欧美日韩的一区二区| av资源站久久亚洲| 欧美三级视频网站| 色视频在线观看在线播放| 欧美一级二级视频| 国产一区二区三区香蕉 | 国产成人精品亚洲日本在线桃色| 欧美一激情一区二区三区| 精品国产乱码久久久久久108| 精品国产无码在线观看| 91在线免费观看| 亚洲精品大片| 91麻豆免费在线观看| 色黄久久久久久| 国产精品沙发午睡系列| 在线观看毛片网站| 97视频在线观看网站| 亚洲人成免费| 精品国产一区二区三区久久影院| 欧美日韩精品三区| 91在线国产电影| 影音先锋男人在线| 极品色影院av| 成人亚洲一区二区| 欧美日韩激情小视频| 国产欧美va欧美va香蕉在线| 水蜜桃av无码| 人善交vide欧美| 国产成人免费9x9x人网站视频| av在线这里只有精品| 久久91精品国产| 韩国三级hd中文字幕有哪些| 国产精品外围在线观看| 亚洲日本va中文字幕| 中文字幕一区二区三区乱码在线 | 国产黄色录像视频| xxx在线视频| 日韩成人久久| 一区二区三区国产豹纹内裤在线| 国产精品丝袜视频| 亚洲色图27p| 伊人75在线| 老鸭窝91久久精品色噜噜导演| 亚洲成人黄色网址| 黄色片视频在线免费观看| 国产伦精品一区二区三区四区 | 中国一级黄色录像| 国产人妖在线播放| 日韩欧美看国产| 国产三级一区二区| 国产精品自产拍在线观| 登山的目的在线| 亚洲男人都懂的网站| 三级一区在线视频先锋 | 午夜精品免费在线| 国产精品久久久久免费| 国产污片在线观看| 欧美性videos| 久久99国产精品免费网站| 欧美日韩国产二区| 久久国产劲爆∧v内射| 国产白浆在线| 中文字幕av一区二区三区人| 色婷婷亚洲婷婷| 在线视频不卡国产| 亚洲第一成年人网站| 美女91在线看| 中文字幕第一区二区| 91久久精品www人人做人人爽| 久久精品视频免费在线观看| 第一页在线观看| 九九九久久久精品| 欧美国产日本高清在线 | 国产69精品久久久久久久| 4hu四虎永久在线观看| 九九热爱视频精品视频| 精品少妇一区二区三区日产乱码| 爱情岛论坛成人| 日本特级黄色片| 女人黄色免费在线观看| 日本一二三不卡| 精品国产综合久久| 亚洲成人中文字幕在线| 在这里有精品| 日韩一区二区中文字幕| 色多多视频在线播放| av观看成片免费网站| 欧美日韩日本国产亚洲在线| 国产一区二区三区在线观看网站| 免费网站在线观看黄| 日本在线中文电影| 国内精品伊人久久久久影院对白| 自拍亚洲一区欧美另类| 欧洲一级黄色片| 国产九九在线| 欧美激情在线免费观看| 亚洲高清视频在线观看| 中文字幕第一页在线| 日韩一区亚洲二区| 日韩中文在线观看| 日韩在线不卡av| 美女视频在线免费| 国产精品蜜臀在线观看| 亚洲精品在线免费看| 欧美做爰猛烈大尺度视频| 狠狠入ady亚洲精品经典电影| 激情综合五月婷婷| 91久久久在线| 欧美 日韩 人妻 高清 中文| 国产精品欧美在线观看| 国产亚洲欧美日韩美女| 蜜桃视频最新网址| 成人福利视频| 欧美一区二区女人| 性久久久久久久久久久久久久| 中文字字幕在线中文乱码电影| 不卡电影一区二区三区| 国产一区二区在线免费| 国产女人高潮时对白| 精品久久久久久久| 久久综合久久美利坚合众国| 国产真人真事毛片| 久久精品九色| 亚洲午夜国产成人av电影男同| 人妻无码一区二区三区免费| 欧美成人精品一区二区男人小说| 欧美精品三级在线观看| 一区二区三区少妇| 色在线中文字幕| 日韩欧美一二三| 欧美 日本 国产| 天堂中文最新版在线中文| 在线观看中文字幕不卡| 乱码一区二区三区| 欧美91精品久久久久国产性生爱| 中文字幕在线不卡一区| 国产91对白刺激露脸在线观看| 黄色av免费| 中文字幕亚洲综合久久菠萝蜜| 人妻熟妇乱又伦精品视频| 欧美12一14sex性hd| 一区二区三区在线免费| 999在线免费视频| www.中文字幕久久久| 欧美日韩国产专区| 国产亚洲色婷婷久久| 欧美性爽视频| 欧美体内she精视频| 女尊高h男高潮呻吟| 久草成色在线| 亚洲福利视频二区| 亚洲少妇一区二区| 91老司机福利在线| 精品亚洲va在线va天堂资源站| 日韩精品一区二区av| 精品国产一区二区三区久久久蜜臀 | 午夜一级在线看亚洲| 成人免费看片网站| 黄页在线免费观看| 波多野洁衣一区| 777久久久精品一区二区三区| 男同在线观看| 亚洲一区二区三区精品在线| 自拍偷拍21p| 一区二区电影免费观看| 亚洲人在线视频| 日韩手机在线视频| 伊人久久大香线蕉精品组织观看| 91系列在线播放| www五月天com| 91精品国产麻豆国产在线观看| 成人午夜在线视频一区| 91免费看片| 93久久精品日日躁夜夜躁欧美| 已婚少妇美妙人妻系列| 日本高清视频在线观看| 欧美性受xxxx黑人xyx性爽| 一二三四国产精品| 先锋影音国产精品| 国产免费成人av| 日本影音先锋电影| 国产嫩草影院久久久久| 一级片免费在线观看视频| 精品福利在线| 久久免费精品日本久久中文字幕| 先锋影音二区| 成人久久久久久久久| 久久青草伊人| 精品中文字幕视频| 亚洲av成人无码久久精品老人| 极品美女销魂一区二区三区免费| 国产精品12345| 男女羞羞视频在线观看| 亚洲男人第一网站| 国产精品久久影视| 玖玖国产精品视频| 国产精品一区在线播放| 一级毛片国产| 色婷婷一区二区三区四区|