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

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

?? bufutils.c

?? 這個是一個開源項目, 有能力的人可以一起來寫
?? C
字號:
/*
 * $Id: bufutils.c,v 1.7 2006/06/21 16:23:57 vfrolov Exp $
 *
 * Copyright (c) 2004-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: bufutils.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/17 15:28:03  vfrolov
 * Implemented SERIAL_DSR_SENSITIVITY
 *
 * Revision 1.5  2006/01/10 10:17:23  vfrolov
 * Implemented flow control and handshaking
 * Implemented IOCTL_SERIAL_SET_XON and IOCTL_SERIAL_SET_XOFF
 * Added setting of HoldReasons, WaitForImmediate and AmountInOutQueue
 *   fields of SERIAL_STATUS for IOCTL_SERIAL_GET_COMMSTATUS
 *
 * Revision 1.4  2005/11/29 08:35:14  vfrolov
 * Implemented SERIAL_EV_RX80FULL
 *
 * Revision 1.3  2005/11/28 12:57:16  vfrolov
 * Moved some C0C_BUFFER code to bufutils.c
 *
 * Revision 1.2  2005/09/06 07:23:44  vfrolov
 * Implemented overrun emulation
 *
 * Revision 1.1  2005/08/25 15:38:17  vfrolov
 * Some code moved from io.c to bufutils.c
 *
 */

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

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

/********************************************************************/
VOID CompactRawData(PC0C_RAW_DATA pRawData, SIZE_T writeDone)
{
  if (writeDone) {
    pRawData->size = (UCHAR)(pRawData->size - writeDone);

    if (pRawData->size) {
      HALT_UNLESS3((pRawData->size + writeDone) <= sizeof(pRawData->data),
          pRawData->size, writeDone, sizeof(pRawData->data));

      RtlMoveMemory(pRawData->data, pRawData->data + writeDone, pRawData->size);
    }
  }
}

NTSTATUS MoveRawData(PC0C_RAW_DATA pDstRawData, PC0C_RAW_DATA pSrcRawData)
{
  SIZE_T free;

  if (!pSrcRawData->size)
    return STATUS_SUCCESS;

  HALT_UNLESS2(pDstRawData->size <= sizeof(pDstRawData->data),
      pDstRawData->size, sizeof(pDstRawData->data));

  free = sizeof(pDstRawData->data) - pDstRawData->size;

  if (free) {
    SIZE_T length;

    if (free > pSrcRawData->size)
      length = pSrcRawData->size;
    else
      length = free;

    HALT_UNLESS3((pDstRawData->size + length) <= sizeof(pDstRawData->data),
        pDstRawData->size, length, sizeof(pDstRawData->data));

    RtlCopyMemory(pDstRawData->data + pDstRawData->size, pSrcRawData->data, length);
    pDstRawData->size = (UCHAR)(pDstRawData->size + length);
    CompactRawData(pSrcRawData, length);
  }
  return pSrcRawData->size ? STATUS_PENDING : STATUS_SUCCESS;
}
/********************************************************************/

VOID FlowFilterInit(PC0C_IO_PORT pIoPort, PC0C_FLOW_FILTER pFlowFilter)
{
  PSERIAL_HANDFLOW pHandFlow;

  RtlZeroMemory(pFlowFilter, sizeof(*pFlowFilter));

  pHandFlow = &pIoPort->handFlow;

  if ((pHandFlow->ControlHandShake & SERIAL_DSR_SENSITIVITY) &&
      (pIoPort->modemStatus & C0C_MSB_DSR) == 0)
  {
    pFlowFilter->flags |= C0C_FLOW_FILTER_IGNORE_RECEIVED;
    return;
  }

  if (pHandFlow->FlowReplace & SERIAL_AUTO_TRANSMIT) {
    pFlowFilter->flags |= C0C_FLOW_FILTER_AUTO_TRANSMIT;
    pFlowFilter->xonChar = pIoPort->specialChars.XonChar;
    pFlowFilter->xoffChar = pIoPort->specialChars.XoffChar;
  }

  if (pHandFlow->FlowReplace & SERIAL_NULL_STRIPPING)
    pFlowFilter->flags |= C0C_FLOW_FILTER_NULL_STRIPPING;

  if (pIoPort->waitMask & SERIAL_EV_RXCHAR)
    pFlowFilter->flags |= C0C_FLOW_FILTER_EV_RXCHAR;

  if (pIoPort->waitMask & SERIAL_EV_RXFLAG) {
    pFlowFilter->flags |= C0C_FLOW_FILTER_EV_RXFLAG;
    pFlowFilter->eventChar = pIoPort->specialChars.EventChar;
  }

  pFlowFilter->escapeChar = pIoPort->escapeChar;
}
/********************************************************************/

VOID CopyCharsWithEscape(
    PC0C_BUFFER pBuf,
    PC0C_FLOW_FILTER pFlowFilter,
    PUCHAR pReadBuf, SIZE_T readLength,
    PUCHAR pWriteBuf, SIZE_T writeLength,
    PSIZE_T pReadDone,
    PSIZE_T pWriteDone)
{
  SIZE_T readDone;
  SIZE_T writeDone;

  HALT_UNLESS(pReadBuf || (pFlowFilter && !readLength));

  readDone = 0;

  if (pBuf->escape && readLength) {
    pBuf->escape = FALSE;
    *pReadBuf++ = SERIAL_LSRMST_ESCAPE;
    readDone++;
    readLength--;
  }

  if (pBuf->insertData.size && readLength) {
    SIZE_T length = pBuf->insertData.size;

    HALT_UNLESS2(length <= sizeof(pBuf->insertData.data),
        length, sizeof(pBuf->insertData.data));

    if (length > readLength)
      length = readLength;

    RtlCopyMemory(pReadBuf, pBuf->insertData.data, length);
    pReadBuf += length;
    readDone += length;
    readLength -= length;
    CompactRawData(&pBuf->insertData, length);
  }

  if (!pFlowFilter) {
    writeDone = writeLength < readLength ? writeLength : readLength;

    if (writeDone) {
      RtlCopyMemory(pReadBuf, pWriteBuf, writeDone);
      readDone += writeDone;
    }
  }
  else
  if (pFlowFilter->flags & C0C_FLOW_FILTER_IGNORE_RECEIVED) {
    writeDone = writeLength;
  }
  else {
    writeDone = 0;

    while (writeLength--) {
      UCHAR curChar;

      curChar = *pWriteBuf++;

      if (!curChar && (pFlowFilter->flags & C0C_FLOW_FILTER_NULL_STRIPPING)) {
      }
      else
      if ((pFlowFilter->flags & C0C_FLOW_FILTER_AUTO_TRANSMIT) &&
          (curChar == pFlowFilter->xoffChar || curChar == pFlowFilter->xonChar))
      {
        if (curChar == pFlowFilter->xoffChar)
          pFlowFilter->lastXonXoff = C0C_XCHAR_OFF;
        else
          pFlowFilter->lastXonXoff = C0C_XCHAR_ON;
      }
      else {
        if (pReadBuf) {
          if (!readLength--)
            break;

          *pReadBuf++ = curChar;

          if (pFlowFilter->flags & C0C_FLOW_FILTER_EV_RXCHAR)
            pFlowFilter->events |= C0C_FLOW_FILTER_EV_RXCHAR;

          if ((pFlowFilter->flags & C0C_FLOW_FILTER_EV_RXFLAG) &&
              curChar == pFlowFilter->eventChar)
          {
            pFlowFilter->events |= C0C_FLOW_FILTER_EV_RXFLAG;
          }

          if (pFlowFilter->escapeChar && curChar == pFlowFilter->escapeChar) {
            if (!readLength--) {
              pBuf->escape = TRUE;
              readLength++;
            } else {
              *pReadBuf++ = SERIAL_LSRMST_ESCAPE;
              readDone++;
            }
          }
        }
        readDone++;
      }
      writeDone++;
    }
  }

  *pReadDone = readDone;
  *pWriteDone = writeDone;
}

SIZE_T ReadFromBuffer(PC0C_BUFFER pBuf, PVOID pRead, SIZE_T readLength)
{
  PUCHAR pReadBuf = (PUCHAR)pRead;

  while (readLength) {
    SIZE_T length, writeLength;
    PVOID pWriteBuf;

    if (!pBuf->busy) {
      if (pBuf->escape) {
        pBuf->escape = FALSE;
        *pReadBuf++ = SERIAL_LSRMST_ESCAPE;
        readLength--;
        if (!readLength)
          break;
      }
      if (pBuf->insertData.size) {
        length = pBuf->insertData.size;

        HALT_UNLESS2(length <= sizeof(pBuf->insertData.data),
            length, sizeof(pBuf->insertData.data));

        if (length > readLength)
          length = readLength;

        RtlCopyMemory(pReadBuf, pBuf->insertData.data, length);
        pReadBuf += length;
        readLength -= length;
        CompactRawData(&pBuf->insertData, length);
        if (!readLength)
          break;
      }
      break;
    }

    HALT_UNLESS(pBuf->pBase);

    writeLength = pBuf->pFree <= pBuf->pBusy ?
        pBuf->pEnd - pBuf->pBusy : pBuf->busy;

    pWriteBuf = pBuf->pBusy;

    length = writeLength < readLength ? writeLength : readLength;

    RtlCopyMemory(pReadBuf, pWriteBuf, length);

    pBuf->busy -= length;
    pBuf->pBusy += length;
    if (pBuf->pBusy == pBuf->pEnd)
      pBuf->pBusy = pBuf->pBase;

    pReadBuf += length;
    readLength -= length;
  }

  return pReadBuf - (PUCHAR)pRead;
}

SIZE_T WriteToBuffer(
    PC0C_BUFFER pBuf,
    PVOID pWrite,
    SIZE_T writeLength,
    PC0C_FLOW_FILTER pFlowFilter)
{
  PUCHAR pWriteBuf = (PUCHAR)pWrite;

  while (writeLength) {
    SIZE_T readDone, writeDone;
    SIZE_T readLength;
    PUCHAR pReadBuf;

    if (pBuf->limit <= pBuf->busy)
      break;

    pReadBuf = pBuf->pFree;

    readLength = pBuf->pBusy <= pReadBuf ?
        pBuf->pEnd - pReadBuf : pBuf->pBusy - pReadBuf;

    if (readLength > (pBuf->limit - pBuf->busy))
      readLength = pBuf->limit - pBuf->busy;

    CopyCharsWithEscape(
        pBuf, pFlowFilter,
        pReadBuf, readLength,
        pWriteBuf, writeLength,
        &readDone, &writeDone);

    pBuf->busy += readDone;
    pBuf->pFree += readDone;
    if (pBuf->pFree == pBuf->pEnd)
      pBuf->pFree = pBuf->pBase;

    pWriteBuf += writeDone;
    writeLength -= writeDone;
  }

  return pWriteBuf - (PUCHAR)pWrite;
}

VOID WriteMandatoryToBuffer(PC0C_BUFFER pBuf, UCHAR mandatoryChar)
{
  if (C0C_BUFFER_SIZE(pBuf) <= pBuf->busy) {
    if (pBuf->pBase) {
      if (pBuf->pFree == pBuf->pBase)
        *(pBuf->pEnd - 1) = mandatoryChar;
      else
        *(pBuf->pFree - 1) = mandatoryChar;
    }
  } else {
    pBuf->busy++;
    *pBuf->pFree = mandatoryChar;
    if (++pBuf->pFree == pBuf->pEnd)
      pBuf->pFree = pBuf->pBase;
  }
}

NTSTATUS WriteRawDataToBuffer(PC0C_RAW_DATA pRawData, PC0C_BUFFER pBuf)
{
  NTSTATUS status;

  if (!pBuf->pBase)
    return STATUS_PENDING;

  status = STATUS_PENDING;

  for (;;) {
    SIZE_T readDone, writeDone;
    SIZE_T writeLength, readLength;
    PVOID pWriteBuf, pReadBuf;

    writeLength = pRawData->size;

    if (!writeLength) {
      status = STATUS_SUCCESS;
      break;
    }

    HALT_UNLESS2(writeLength <= sizeof(pRawData->data),
        writeLength, sizeof(pRawData->data));

    pWriteBuf = pRawData->data;

    if (C0C_BUFFER_SIZE(pBuf) <= pBuf->busy)
      break;

    readLength = pBuf->pBusy <= pBuf->pFree  ?
        pBuf->pEnd - pBuf->pFree : pBuf->pBusy - pBuf->pFree;

    pReadBuf = pBuf->pFree;

    CopyCharsWithEscape(
        pBuf, NULL,
        pReadBuf, readLength,
        pWriteBuf, writeLength,
        &readDone, &writeDone);

    pBuf->busy += readDone;
    pBuf->pFree += readDone;
    if (pBuf->pFree == pBuf->pEnd)
      pBuf->pFree = pBuf->pBase;

    CompactRawData(pRawData, writeDone);
  }

  return status;
}

SIZE_T WriteRawData(PC0C_RAW_DATA pRawData, PNTSTATUS pStatus, PVOID pReadBuf, SIZE_T readLength)
{
  SIZE_T length, writeLength;
  PVOID pWriteBuf;

  pWriteBuf = pRawData->data;
  writeLength = pRawData->size;

  HALT_UNLESS2(writeLength <= sizeof(pRawData->data),
      writeLength, sizeof(pRawData->data));

  length = writeLength < readLength ? writeLength : readLength;

  RtlCopyMemory(pReadBuf, pWriteBuf, length);

  CompactRawData(pRawData, length);

  if (!pRawData->size)
    *pStatus = STATUS_SUCCESS;

  return length;
}

VOID InitBufferBase(PC0C_BUFFER pBuf, PUCHAR pBase, SIZE_T size)
{
  pBuf->pBase = pBase;
  pBuf->pEnd = pBuf->pBase + size;
  pBuf->limit = size;
  pBuf->size80 = (size*4 + 4)/5;
}

BOOLEAN SetNewBufferBase(PC0C_BUFFER pBuf, PUCHAR pBase, SIZE_T size)
{
  C0C_BUFFER newBuf;

  if (size <= C0C_BUFFER_SIZE(pBuf)) {
    ExFreePool(pBase);
    return FALSE;
  }

  InitBufferBase(&newBuf, pBase, size);

  newBuf.pFree = newBuf.pBusy = newBuf.pBase;
  newBuf.busy = 0;

  if (pBuf->pBase) {
    while (pBuf->busy) {
      SIZE_T length;

      length = pBuf->pFree <= pBuf->pBusy ?
          pBuf->pEnd - pBuf->pBusy : pBuf->busy;

      RtlCopyMemory(newBuf.pFree, pBuf->pBusy, length);

      pBuf->busy -= length;
      pBuf->pBusy += length;
      if (pBuf->pBusy == pBuf->pEnd)
        pBuf->pBusy = pBuf->pBase;

      newBuf.busy += length;
      newBuf.pFree += length;
    }

    ExFreePool(pBuf->pBase);
  }

  newBuf.escape = pBuf->escape;
  newBuf.insertData = pBuf->insertData;

  *pBuf = newBuf;

  return TRUE;
}

VOID PurgeBuffer(PC0C_BUFFER pBuf)
{
  pBuf->pFree = pBuf->pBusy = pBuf->pBase;
  pBuf->busy = 0;
  pBuf->escape = FALSE;
  pBuf->insertData.size = 0;
}

VOID InitBuffer(PC0C_BUFFER pBuf, PUCHAR pBase, SIZE_T size)
{
  RtlZeroMemory(pBuf, sizeof(*pBuf));
  InitBufferBase(pBuf, pBase, size);
  PurgeBuffer(pBuf);
}

VOID FreeBuffer(PC0C_BUFFER pBuf)
{
  if (pBuf->pBase)
    ExFreePool(pBuf->pBase);

  RtlZeroMemory(pBuf, sizeof(*pBuf));
}

VOID SetBufferLimit(PC0C_BUFFER pBuf, SIZE_T limit)
{
  if (limit > C0C_BUFFER_SIZE(pBuf))
    limit = C0C_BUFFER_SIZE(pBuf);

  pBuf->limit = limit;
}
/********************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人动漫精品| 久久成人av少妇免费| 欧美一区二区三区婷婷月色| 国产精品一二三四区| 日韩电影在线一区| 国产精品福利一区| 欧美一卡2卡3卡4卡| 91视频com| 国产成人亚洲综合色影视| 亚洲成在人线在线播放| 国产精品动漫网站| 国产欧美视频在线观看| 欧美岛国在线观看| 在线观看av一区二区| 波多野结衣中文一区| 精品中文字幕一区二区小辣椒| 国产精品一区专区| 丝袜美腿亚洲综合| 亚洲女人的天堂| 国产精品色眯眯| 久久久精品tv| 久久午夜电影网| 精品国产一区二区在线观看| 欧美精品成人一区二区三区四区| aaa亚洲精品一二三区| 国产一区二区福利| 麻豆精品蜜桃视频网站| 日韩一区欧美二区| 亚洲成人av在线电影| 亚洲人一二三区| 亚洲欧洲在线观看av| 国产亚洲精品bt天堂精选| 精品乱人伦小说| 日韩美女一区二区三区| 91精品国产一区二区| 欧美欧美欧美欧美首页| 欧美日韩久久久久久| 欧美三级资源在线| 欧美视频日韩视频| 欧美性生活久久| 欧美日韩免费在线视频| 欧美午夜一区二区| 欧美久久一二三四区| 欧美日韩视频专区在线播放| 欧美日韩不卡一区| 欧美一二三四区在线| 欧美大尺度电影在线| 欧美xxxxxxxx| 久久久久久影视| 国产日韩精品一区二区三区在线| 日本一区二区综合亚洲| 国产精品国产精品国产专区不蜜| 国产精品福利影院| 亚洲免费在线视频一区 二区| 亚洲三级在线观看| 亚洲高清不卡在线| 青青草97国产精品免费观看无弹窗版| 人人爽香蕉精品| 国内外精品视频| a4yy欧美一区二区三区| 91久久奴性调教| 337p亚洲精品色噜噜| 精品免费日韩av| 国产精品乱码人人做人人爱| 亚洲精品中文字幕乱码三区| 天天综合日日夜夜精品| 久久爱www久久做| 成人午夜激情在线| 欧美日韩免费高清一区色橹橹| 欧美一级片在线观看| 国产拍欧美日韩视频二区| 亚洲免费观看高清| 青青草成人在线观看| 国产aⅴ精品一区二区三区色成熟| 91免费国产视频网站| 91精品一区二区三区在线观看| 久久久亚洲精品石原莉奈| 最新不卡av在线| 男女激情视频一区| av高清不卡在线| 欧美一级搡bbbb搡bbbb| 国产精品青草久久| 午夜视频久久久久久| 国产aⅴ精品一区二区三区色成熟| 91成人在线精品| 久久亚洲影视婷婷| 夜夜嗨av一区二区三区网页| 久久99精品久久久久久久久久久久| av日韩在线网站| 91精品国产一区二区三区蜜臀| 中文一区二区在线观看| 免费高清不卡av| 91网址在线看| 久久久一区二区三区| 亚洲成在人线在线播放| 成人sese在线| 欧美不卡在线视频| 亚洲一区二区视频在线| 成人av在线网| xnxx国产精品| 日韩精品五月天| 99久久精品免费| 国产欧美一区二区在线| 日韩avvvv在线播放| 日本乱码高清不卡字幕| 久久久久国产精品麻豆ai换脸 | 色网综合在线观看| 久久久91精品国产一区二区精品| 亚洲国产日韩a在线播放| 丁香激情综合国产| 精品欧美一区二区三区精品久久| 一区二区三区美女| 9色porny自拍视频一区二区| 精品国产乱子伦一区| 奇米精品一区二区三区在线观看一 | 亚洲精品一二三| 国产精品综合久久| 欧美大片免费久久精品三p| 亚洲电影中文字幕在线观看| 国产麻豆精品一区二区| 日韩午夜中文字幕| 天天操天天综合网| 欧美三日本三级三级在线播放| 亚洲图片另类小说| 成人网男人的天堂| 国产欧美一区二区三区鸳鸯浴| 激情综合五月婷婷| 欧美大黄免费观看| 精品中文字幕一区二区小辣椒| 91精品国产丝袜白色高跟鞋| 婷婷国产在线综合| 欧美一区二区在线看| 手机精品视频在线观看| 欧美疯狂做受xxxx富婆| 日韩中文欧美在线| 欧美福利视频导航| 久久精品国产一区二区| 久久影院午夜片一区| 国内成人自拍视频| 国产亚洲美州欧州综合国| 国产成人h网站| 欧美国产成人精品| 99久久精品一区| 亚洲欧美国产高清| 欧美曰成人黄网| 日韩精品久久理论片| 欧美成人女星排行榜| 精品亚洲成a人| 国产日韩精品一区| av亚洲精华国产精华| 亚洲另类春色国产| 5月丁香婷婷综合| 精品一区二区三区在线播放 | 色狠狠一区二区三区香蕉| 一区二区三区四区亚洲| 欧美夫妻性生活| 国产在线视视频有精品| 国产精品免费网站在线观看| 99国产精品视频免费观看| 亚洲国产sm捆绑调教视频 | 欧美一区在线视频| 国产传媒欧美日韩成人| 亚洲黄色免费网站| 欧美精选在线播放| 国产一区二区成人久久免费影院| 国产精品成人午夜| 欧美乱妇15p| 国产成人一区在线| 亚洲一区二区三区四区在线观看| 日韩欧美二区三区| 成a人片亚洲日本久久| 午夜欧美视频在线观看| 精品国产sm最大网站免费看| 成人av影视在线观看| 丝袜美腿成人在线| 久久精品欧美日韩精品| 在线观看亚洲一区| 国产在线视频精品一区| 亚洲激情在线激情| 亚洲精品在线观看网站| 91蜜桃网址入口| 久久精品国产精品亚洲红杏| 亚洲特级片在线| 26uuu亚洲综合色| 色哟哟国产精品| 韩国一区二区三区| 亚洲午夜激情网页| 欧美国产精品中文字幕| 欧美精品免费视频| gogogo免费视频观看亚洲一| 日本va欧美va精品发布| 日韩毛片一二三区| 久久久久久久综合日本| 欧美日韩激情在线| 色综合天天综合在线视频| 精品一区二区三区免费播放| 亚洲精品成人天堂一二三| 久久精品视频一区二区三区| 欧美麻豆精品久久久久久| 成人av片在线观看|