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

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

?? handflow.c

?? 這個是一個開源項目, 有能力的人可以一起來寫
?? C
字號:
/*
 * $Id: handflow.c,v 1.7 2006/06/21 16:23:57 vfrolov Exp $
 *
 * Copyright (c) 2005-2006 Vyacheslav Frolov
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 *
 * $Log: handflow.c,v $
 * Revision 1.7  2006/06/21 16:23:57  vfrolov
 * Fixed possible BSOD after one port of pair removal
 *
 * Revision 1.6  2006/05/19 12:16:19  vfrolov
 * Implemented SERIAL_XOFF_CONTINUE
 *
 * Revision 1.5  2006/05/17 15:31:14  vfrolov
 * Implemented SERIAL_TRANSMIT_TOGGLE
 *
 * Revision 1.4  2006/04/05 07:22:15  vfrolov
 * Replaced flipXoffLimit flag by writeHoldingRemote to correct handFlow changing
 *
 * Revision 1.3  2006/03/15 13:49:15  vfrolov
 * Fixed [1446861] Problems with setting DCB.fOutxCtsFlow and DCB.fRtsControl
 * Thanks to Brad (bdwade100 at users.sourceforge.net)
 *
 * Revision 1.2  2006/02/17 07:55:13  vfrolov
 * Implemented IOCTL_SERIAL_SET_BREAK_ON and IOCTL_SERIAL_SET_BREAK_OFF
 *
 * Revision 1.1  2006/01/10 10:12:05  vfrolov
 * Initial revision
 *
 *
 */

#include "precomp.h"
#include "handflow.h"
#include "bufutils.h"

/*
 * FILE_ID used by HALT_UNLESS to put it on BSOD
 */
#define FILE_ID 9

NTSTATUS SetHandFlow(
    PC0C_IO_PORT pIoPort,
    PSERIAL_HANDFLOW pHandFlow,
    PLIST_ENTRY pQueueToComplete)
{
  ULONG bits, mask;
  PC0C_BUFFER pReadBuf;
  PSERIAL_HANDFLOW pNewHandFlow;
  BOOLEAN setModemStatusHolding;

  pReadBuf = &pIoPort->readBuf;

  if (pHandFlow) {
    if ((pIoPort->escapeChar && (pHandFlow->FlowReplace & SERIAL_ERROR_CHAR)) ||
        ((SIZE_T)pHandFlow->XonLimit > C0C_BUFFER_SIZE(pReadBuf)) ||
        ((SIZE_T)pHandFlow->XoffLimit > C0C_BUFFER_SIZE(pReadBuf)))
    {
      return STATUS_INVALID_PARAMETER;
    }

    pNewHandFlow = pHandFlow;
  } else {
    pNewHandFlow = &pIoPort->handFlow;
  }

  // Set local side
  if (pHandFlow &&
      ((pIoPort->handFlow.FlowReplace & SERIAL_AUTO_TRANSMIT) != 0) &&
      ((pHandFlow->FlowReplace & SERIAL_AUTO_TRANSMIT) == 0))
  {
    SetXonXoffHolding(pIoPort, C0C_XCHAR_ON);
  }

  if (!pHandFlow ||
      (pIoPort->handFlow.ControlHandShake & SERIAL_OUT_HANDSHAKEMASK) !=
          (pHandFlow->ControlHandShake & SERIAL_OUT_HANDSHAKEMASK))
  {
    setModemStatusHolding = TRUE;
  } else {
    setModemStatusHolding = FALSE;
  }

  // Set remote side
  bits = mask = 0;

  if (!pHandFlow ||
      (pIoPort->handFlow.FlowReplace & SERIAL_RTS_MASK) !=
          (pHandFlow->FlowReplace & SERIAL_RTS_MASK))
  {
    switch (pNewHandFlow->FlowReplace & SERIAL_RTS_MASK) {
    case 0:
      pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_CTS;
      mask |= C0C_MSB_CTS; // Turn off CTS on remote side if RTS is disabled
      break;
    case SERIAL_RTS_CONTROL:
      pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_CTS;
      bits |= C0C_MSB_CTS;
      mask |= C0C_MSB_CTS;
      break;
    case SERIAL_RTS_HANDSHAKE:
      if (C0C_BUFFER_BUSY(pReadBuf) > (C0C_BUFFER_SIZE(pReadBuf) - pNewHandFlow->XoffLimit)) {
        pIoPort->writeHoldingRemote |= SERIAL_TX_WAITING_FOR_CTS;
        mask |= C0C_MSB_CTS;
      }
      else
      if (pIoPort->writeHoldingRemote & SERIAL_TX_WAITING_FOR_CTS) {
        if (C0C_BUFFER_BUSY(pReadBuf) <= (SIZE_T)pNewHandFlow->XonLimit) {
          pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_CTS;
          bits |= C0C_MSB_CTS;
          mask |= C0C_MSB_CTS;
        }
      }
      else {
        bits |= C0C_MSB_CTS;
        mask |= C0C_MSB_CTS;
      }
    }
  }

  if (!pHandFlow ||
      (pIoPort->handFlow.ControlHandShake & SERIAL_DTR_MASK) !=
          (pHandFlow->ControlHandShake & SERIAL_DTR_MASK))
  {
    switch (pNewHandFlow->ControlHandShake & SERIAL_DTR_MASK) {
    case 0:
      pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_DSR;
      mask |= C0C_MSB_DSR; // Turn off DSR on remote side if DTR is disabled
      break;
    case SERIAL_DTR_CONTROL:
      pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_DSR;
      bits |= C0C_MSB_DSR;
      mask |= C0C_MSB_DSR;
      break;
    case SERIAL_DTR_HANDSHAKE:
      if (C0C_BUFFER_BUSY(pReadBuf) > (C0C_BUFFER_SIZE(pReadBuf) - pNewHandFlow->XoffLimit)) {
        pIoPort->writeHoldingRemote |= SERIAL_TX_WAITING_FOR_DSR;
        mask |= C0C_MSB_DSR;
      }
      else
      if (pIoPort->writeHoldingRemote & SERIAL_TX_WAITING_FOR_DSR) {
        if (C0C_BUFFER_BUSY(pReadBuf) <= (SIZE_T)pNewHandFlow->XonLimit) {
          pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_DSR;
          bits |= C0C_MSB_DSR;
          mask |= C0C_MSB_DSR;
        }
      }
      else {
        bits |= C0C_MSB_DSR;
        mask |= C0C_MSB_DSR;
      }
    }
  }

  if (!pHandFlow ||
      (pIoPort->handFlow.FlowReplace & SERIAL_AUTO_RECEIVE) !=
          (pHandFlow->FlowReplace & SERIAL_AUTO_RECEIVE))
  {
    if (pNewHandFlow->FlowReplace & SERIAL_AUTO_RECEIVE) {
      if (C0C_BUFFER_BUSY(pReadBuf) > (C0C_BUFFER_SIZE(pReadBuf) - pNewHandFlow->XoffLimit)) {
        pIoPort->writeHoldingRemote |= SERIAL_TX_WAITING_FOR_XON;
        if ((pNewHandFlow->FlowReplace & SERIAL_XOFF_CONTINUE) == 0)
          pIoPort->writeHolding |= SERIAL_TX_WAITING_FOR_XON;
        pIoPort->sendXonXoff = C0C_XCHAR_OFF;
        pIoPort->tryWrite = TRUE;
      }
    }
    else
    if (pIoPort->writeHoldingRemote & SERIAL_TX_WAITING_FOR_XON) {
      pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_XON;
      pIoPort->writeHolding &= ~SERIAL_TX_WAITING_FOR_XON;
      if (pIoPort->sendXonXoff != C0C_XCHAR_OFF) {
        // XOFF was sent so send XON
        pIoPort->sendXonXoff = C0C_XCHAR_ON;
        pIoPort->tryWrite = TRUE;
      } else {
        // XOFF still was not sent so cancel it
        pIoPort->sendXonXoff = 0;
      }
    }
  }

  if (pHandFlow)
    pIoPort->handFlow = *pHandFlow;

  if (setModemStatusHolding)
    SetModemStatusHolding(pIoPort);

  if (mask)
    SetModemStatus(pIoPort->pIoPortRemote, bits, mask, pQueueToComplete);

  UpdateTransmitToggle(pIoPort, pQueueToComplete);

  SetLimit(pIoPort->pIoPortRemote);
  SetLimit(pIoPort);

  if (pIoPort->pIoPortRemote->tryWrite) {
    ReadWrite(
        pIoPort, FALSE,
        pIoPort->pIoPortRemote, FALSE,
        pQueueToComplete);
  }

  if (pIoPort->tryWrite) {
    ReadWrite(
        pIoPort->pIoPortRemote, FALSE,
        pIoPort, FALSE,
        pQueueToComplete);
  }

  return STATUS_SUCCESS;
}

VOID UpdateHandFlow(
    PC0C_IO_PORT pIoPort,
    BOOLEAN freed,
    PLIST_ENTRY pQueueToComplete)
{
  ULONG bits, mask;
  PC0C_BUFFER pReadBuf;
  PSERIAL_HANDFLOW pHandFlowLocal, pHandFlowRemote;

  pHandFlowLocal = &pIoPort->handFlow;
  pHandFlowRemote = &pIoPort->pIoPortRemote->handFlow;
  pReadBuf = &pIoPort->readBuf;

  bits = mask = 0;

  if (!pIoPort->writeHoldingRemote) {
    if (!freed && C0C_BUFFER_BUSY(pReadBuf) > (C0C_BUFFER_SIZE(pReadBuf) - pHandFlowLocal->XoffLimit)) {
      if ((pHandFlowLocal->FlowReplace & SERIAL_RTS_MASK) == SERIAL_RTS_HANDSHAKE) {
        pIoPort->writeHoldingRemote |= SERIAL_TX_WAITING_FOR_CTS;
        mask |= C0C_MSB_CTS;
      }

      if ((pHandFlowLocal->ControlHandShake & SERIAL_DTR_MASK) == SERIAL_DTR_HANDSHAKE) {
        pIoPort->writeHoldingRemote |= SERIAL_TX_WAITING_FOR_DSR;
        mask |= C0C_MSB_DSR;
      }

      if (pHandFlowLocal->FlowReplace & SERIAL_AUTO_RECEIVE) {
        pIoPort->writeHoldingRemote |= SERIAL_TX_WAITING_FOR_XON;
        if ((pHandFlowLocal->FlowReplace & SERIAL_XOFF_CONTINUE) == 0)
          pIoPort->writeHolding |= SERIAL_TX_WAITING_FOR_XON;
        pIoPort->sendXonXoff = C0C_XCHAR_OFF;
        pIoPort->tryWrite = TRUE;
      }
    }
  } else {
    if (freed && C0C_BUFFER_BUSY(pReadBuf) <= (SIZE_T)pHandFlowLocal->XonLimit) {
      if ((pHandFlowLocal->FlowReplace & SERIAL_RTS_MASK) == SERIAL_RTS_HANDSHAKE) {
        pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_CTS;
        bits |= C0C_MSB_CTS;
        mask |= C0C_MSB_CTS;
      }

      if ((pHandFlowLocal->ControlHandShake & SERIAL_DTR_MASK) == SERIAL_DTR_HANDSHAKE) {
        pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_DSR;
        bits |= C0C_MSB_DSR;
        mask |= C0C_MSB_DSR;
      }

      if (pHandFlowLocal->FlowReplace & SERIAL_AUTO_RECEIVE) {
        pIoPort->writeHoldingRemote &= ~SERIAL_TX_WAITING_FOR_XON;
        pIoPort->writeHolding &= ~SERIAL_TX_WAITING_FOR_XON;
        pIoPort->sendXonXoff = C0C_XCHAR_ON;
        pIoPort->tryWrite = TRUE;
      }
    }
  }

  if (mask)
    SetModemStatus(pIoPort->pIoPortRemote, bits, mask, pQueueToComplete);
}

VOID UpdateTransmitToggle(
    PC0C_IO_PORT pIoPort,
    PLIST_ENTRY pQueueToComplete)
{
  if ((pIoPort->handFlow.FlowReplace & SERIAL_RTS_MASK) == SERIAL_TRANSMIT_TOGGLE) {
    ULONG bits;

    if ((pIoPort->writeHolding & SERIAL_TX_WAITING_ON_BREAK) == 0 &&
        (pIoPort->sendXonXoff || pIoPort->irpQueues[C0C_QUEUE_WRITE].pCurrent))
    {
      bits = C0C_MSB_CTS;
    } else {
      bits = 0;
    }

    SetModemStatus(pIoPort->pIoPortRemote, bits, C0C_MSB_CTS, pQueueToComplete);
  }
}

VOID SetLimit(PC0C_IO_PORT pIoPort)
{
  PC0C_BUFFER pReadBuf;
  SIZE_T limit;
  PSERIAL_HANDFLOW pHandFlowLocal, pHandFlowRemote;

  pHandFlowLocal = &pIoPort->handFlow;
  pHandFlowRemote = &pIoPort->pIoPortRemote->handFlow;
  pReadBuf = &pIoPort->readBuf;

  /* DCD = DSR */
  #define C0C_DSR_HANDSHAKE (SERIAL_DSR_HANDSHAKE|SERIAL_DCD_HANDSHAKE)

  if ((((pHandFlowLocal->FlowReplace & SERIAL_RTS_MASK) == SERIAL_RTS_HANDSHAKE) &&
                             (pHandFlowRemote->ControlHandShake & SERIAL_CTS_HANDSHAKE)) ||
      (((pHandFlowLocal->ControlHandShake & SERIAL_DTR_MASK) == SERIAL_DTR_HANDSHAKE) &&
                             (pHandFlowRemote->ControlHandShake & C0C_DSR_HANDSHAKE)))
  {
    limit = C0C_BUFFER_SIZE(pReadBuf) - pHandFlowLocal->XoffLimit + 1;
  } else {
    limit = C0C_BUFFER_SIZE(pReadBuf);
  }
  SetBufferLimit(pReadBuf, limit);
}

VOID SetModemStatusHolding(PC0C_IO_PORT pIoPort)
{
  ULONG writeHolding;
  PSERIAL_HANDFLOW pHandFlow;

  pHandFlow = &pIoPort->handFlow;
  writeHolding = pIoPort->writeHolding;

  if ((pHandFlow->ControlHandShake & SERIAL_CTS_HANDSHAKE) && !(pIoPort->modemStatus & C0C_MSB_CTS))
    writeHolding |= SERIAL_TX_WAITING_FOR_CTS;
  else
    writeHolding &= ~SERIAL_TX_WAITING_FOR_CTS;

  if ((pHandFlow->ControlHandShake & SERIAL_DSR_HANDSHAKE) && !(pIoPort->modemStatus & C0C_MSB_DSR))
    writeHolding |= SERIAL_TX_WAITING_FOR_DSR;
  else
    writeHolding &= ~SERIAL_TX_WAITING_FOR_DSR;

  if ((pHandFlow->ControlHandShake & SERIAL_DCD_HANDSHAKE) && !(pIoPort->modemStatus & C0C_MSB_RLSD))
    writeHolding |= SERIAL_TX_WAITING_FOR_DCD;
  else
    writeHolding &= ~SERIAL_TX_WAITING_FOR_DCD;

  if (!(writeHolding & ~SERIAL_TX_WAITING_FOR_XON) &&
      (pIoPort->writeHolding & ~SERIAL_TX_WAITING_FOR_XON))
  {
    if (pIoPort->sendXonXoff || (!writeHolding && pIoPort->irpQueues[C0C_QUEUE_WRITE].pCurrent))
      pIoPort->tryWrite = TRUE;
  }

  pIoPort->writeHolding = writeHolding;
}

VOID SetXonXoffHolding(PC0C_IO_PORT pIoPort, short xonXoff)
{
  switch (xonXoff) {
  case C0C_XCHAR_ON:
    if (pIoPort->writeHolding & SERIAL_TX_WAITING_FOR_XON) {
      pIoPort->writeHolding &= ~SERIAL_TX_WAITING_FOR_XON;

      if (!pIoPort->writeHolding && pIoPort->irpQueues[C0C_QUEUE_WRITE].pCurrent)
        pIoPort->tryWrite = TRUE;
    }
    break;
  case C0C_XCHAR_OFF:
    pIoPort->writeHolding |= SERIAL_TX_WAITING_FOR_XON;
    break;
  }
}

VOID SetBreakHolding(PC0C_IO_PORT pIoPort, BOOLEAN on)
{
  if (on) {
    if ((pIoPort->writeHolding & SERIAL_TX_WAITING_ON_BREAK) == 0) {
      pIoPort->writeHolding |= SERIAL_TX_WAITING_ON_BREAK;
      pIoPort->sendBreak = TRUE;
      pIoPort->tryWrite = TRUE;
    }
  } else {
    if (pIoPort->writeHolding & SERIAL_TX_WAITING_ON_BREAK) {
      pIoPort->writeHolding &= ~SERIAL_TX_WAITING_ON_BREAK;
      pIoPort->sendBreak = FALSE;

      if ((!(pIoPort->writeHolding & ~SERIAL_TX_WAITING_FOR_XON) && pIoPort->sendXonXoff) ||
          !pIoPort->writeHolding && pIoPort->irpQueues[C0C_QUEUE_WRITE].pCurrent)
      {
        pIoPort->tryWrite = TRUE;
      }
    }
  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产又粗又猛又爽又黄91精品| 色美美综合视频| 色婷婷综合视频在线观看| 欧美成人精品高清在线播放| 一区二区高清视频在线观看| 国产a久久麻豆| 日韩女优av电影在线观看| 亚洲一区日韩精品中文字幕| 成人免费视频视频在线观看免费| 日韩免费在线观看| 日韩av在线发布| 精品视频1区2区| 亚洲男人的天堂一区二区| 狠狠色丁香久久婷婷综合丁香| 欧美系列在线观看| 亚洲免费资源在线播放| 成人国产免费视频| 国产色产综合色产在线视频| 激情小说欧美图片| 日韩欧美一二三| 免费视频一区二区| 欧美精品v日韩精品v韩国精品v| 亚洲免费av高清| 95精品视频在线| 亚洲女人小视频在线观看| av一本久道久久综合久久鬼色| 国产亚洲综合av| 国产福利一区二区| 国产欧美精品一区二区色综合朱莉| 狠狠色狠狠色综合系列| 精品成人一区二区三区四区| 精品一区二区三区免费毛片爱| 日韩精品中文字幕一区二区三区 | 国产精品国产三级国产普通话99| 精品一区精品二区高清| 欧美大肚乱孕交hd孕妇| 老司机免费视频一区二区三区| 欧美一区二区三区小说| 另类中文字幕网| 国产欧美日韩综合| 97精品电影院| 亚洲成人av中文| 7777精品伊人久久久大香线蕉最新版 | 99综合影院在线| 综合亚洲深深色噜噜狠狠网站| 91美女视频网站| 亚洲国产毛片aaaaa无费看 | 91国产精品成人| 香蕉成人啪国产精品视频综合网 | 国产一区二区三区综合| 国产日韩欧美一区二区三区综合| 丁香激情综合国产| 一区二区三区在线观看国产| 在线不卡a资源高清| 久久精品国产亚洲a| 国产亚洲短视频| 色噜噜久久综合| 蜜臀av一级做a爰片久久| 国产亚洲婷婷免费| 91黄色在线观看| 麻豆传媒一区二区三区| 国产精品女上位| 欧美日本乱大交xxxxx| 国产乱子伦一区二区三区国色天香| 久久精品亚洲精品国产欧美| 在线看不卡av| 国产精品资源网| 亚洲一区在线观看免费 | 国产成人精品免费一区二区| 亚洲欧美一区二区久久 | 亚洲欧洲国产日韩| 欧美一级专区免费大片| 99视频超级精品| 久久99最新地址| 亚洲精品成人悠悠色影视| 日韩欧美国产午夜精品| 99精品国产99久久久久久白柏| 日本欧美在线观看| 亚洲视频在线一区| 欧美精品一区二区三区视频 | 精品卡一卡二卡三卡四在线| 99免费精品在线观看| 久久99热这里只有精品| 一区二区三区四区高清精品免费观看| 精品国产网站在线观看| 欧美日韩美少妇| 91丨porny丨首页| 国产成人自拍网| 免播放器亚洲一区| 亚洲成a人在线观看| 亚洲色图视频免费播放| 国产欧美日韩精品一区| 精品久久久久久久久久久久包黑料 | eeuss鲁片一区二区三区 | 日韩在线一区二区三区| 中文字幕亚洲欧美在线不卡| 精品国产第一区二区三区观看体验| 欧美视频一区二区三区在线观看| 成人午夜视频在线| 国产精品一二三四| 久久99精品久久久久久动态图| 亚洲福利一二三区| 一区二区久久久久久| 亚洲欧美视频在线观看| 国产精品欧美极品| 亚洲国产精品成人久久综合一区| 精品久久久久久亚洲综合网| 欧美一区二区久久| 91麻豆精品国产综合久久久久久 | 欧美吻胸吃奶大尺度电影| 91网站在线观看视频| 成人h动漫精品一区二区| 福利91精品一区二区三区| 国内精品伊人久久久久av一坑| 久久精品国产第一区二区三区| 日韩高清中文字幕一区| 日日摸夜夜添夜夜添精品视频 | 日韩三级精品电影久久久 | 制服.丝袜.亚洲.中文.综合| 精品视频1区2区| 欧美精选一区二区| 日韩欧美一级二级| xfplay精品久久| 国产亚洲一区字幕| 国产精品国产三级国产aⅴ原创| 中文一区在线播放| 亚洲人成精品久久久久久| 一区二区三区精密机械公司| 亚洲一区二区偷拍精品| 婷婷成人激情在线网| 麻豆视频观看网址久久| 国内精品写真在线观看| 成人激情文学综合网| 日本久久一区二区| 日韩午夜精品电影| 久久久久久久久久久久久女国产乱| 日本一区二区三区高清不卡| 亚洲色图在线播放| 日本vs亚洲vs韩国一区三区| 久久精品理论片| 不卡高清视频专区| 欧美群妇大交群的观看方式| 精品美女被调教视频大全网站| 国产精品国产三级国产aⅴ原创| 亚洲午夜影视影院在线观看| 美国毛片一区二区三区| 波多野洁衣一区| 欧美精品国产精品| 国产精品麻豆视频| 日韩中文欧美在线| 99国产欧美久久久精品| 欧美一区二区精品久久911| 国产精品国产精品国产专区不蜜| 一区二区三区免费观看| 国产精华液一区二区三区| 日本久久电影网| 欧美经典三级视频一区二区三区| 亚洲国产毛片aaaaa无费看| 国产不卡视频在线播放| 在线成人免费观看| 亚洲激情欧美激情| 国产中文字幕一区| 欧美日韩精品欧美日韩精品 | 免费欧美高清视频| 色天使色偷偷av一区二区| 精品久久国产字幕高潮| 亚洲国产综合视频在线观看| 国产成人精品免费网站| 日韩小视频在线观看专区| 亚洲精品视频观看| 成人h动漫精品一区二区| 欧美成人国产一区二区| 一区二区三区四区国产精品| 从欧美一区二区三区| 欧美一区二区播放| 亚洲成人一二三| 91丨porny丨蝌蚪视频| 国产欧美精品一区| 国产一区二区看久久| 91精品国产综合久久精品| 亚洲女人小视频在线观看| aaa亚洲精品| 中文一区在线播放| 国产宾馆实践打屁股91| 久久久99精品免费观看不卡| 另类欧美日韩国产在线| 欧美一区二区三区公司| 亚洲成人动漫在线观看| 欧美三级日韩三级国产三级| 亚洲一区二区三区四区中文字幕| 成人黄色在线看| 国产女主播视频一区二区| 国产馆精品极品| 久久嫩草精品久久久精品一| 韩国三级电影一区二区| 精品福利一区二区三区 | 美女视频一区二区| 欧美一区二区三区四区久久 | 久久亚洲一区二区三区明星换脸| 日本不卡的三区四区五区|