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

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

?? openclos.c

?? 這個是一個開源項目, 有能力的人可以一起來寫
?? C
字號:
/*
 * $Id: openclos.c,v 1.15 2006/06/23 11:44:52 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: openclos.c,v $
 * Revision 1.15  2006/06/23 11:44:52  vfrolov
 * Mass replacement pDevExt by pIoPort
 *
 * Revision 1.14  2006/06/21 16:23:57  vfrolov
 * Fixed possible BSOD after one port of pair removal
 *
 * Revision 1.13  2006/06/08 11:33:35  vfrolov
 * Fixed bugs with amountInWriteQueue
 *
 * Revision 1.12  2006/04/05 07:22:15  vfrolov
 * Replaced flipXoffLimit flag by writeHoldingRemote to correct handFlow changing
 *
 * Revision 1.11  2006/02/17 07:55:13  vfrolov
 * Implemented IOCTL_SERIAL_SET_BREAK_ON and IOCTL_SERIAL_SET_BREAK_OFF
 *
 * Revision 1.10  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.9  2005/11/30 16:04:12  vfrolov
 * Implemented IOCTL_SERIAL_GET_STATS and IOCTL_SERIAL_CLEAR_STATS
 *
 * Revision 1.8  2005/11/29 12:33:21  vfrolov
 * Changed SetModemStatus() to ability set and clear bits simultaneously
 *
 * Revision 1.7  2005/11/28 12:57:16  vfrolov
 * Moved some C0C_BUFFER code to bufutils.c
 *
 * Revision 1.6  2005/09/06 07:23:44  vfrolov
 * Implemented overrun emulation
 *
 * Revision 1.5  2005/05/14 17:07:02  vfrolov
 * Implemented SERIAL_LSRMST_MST insertion
 *
 * Revision 1.4  2005/05/13 16:58:03  vfrolov
 * Implemented IOCTL_SERIAL_LSRMST_INSERT
 *
 * Revision 1.3  2005/02/01 16:51:51  vfrolov
 * Used C0C_BUFFER_PURGE()
 *
 * Revision 1.2  2005/02/01 08:37:55  vfrolov
 * Changed SetModemStatus() to set multiple bits
 *
 * Revision 1.1  2005/01/26 12:18:54  vfrolov
 * Initial revision
 *
 */

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

NTSTATUS FdoPortOpen(IN PC0C_FDOPORT_EXTENSION pDevExt)
{
  LIST_ENTRY queueToComplete;
  PUCHAR pBase;
  ULONG size;
  KIRQL oldIrql;
  PC0C_IO_PORT pIoPort;

  if (InterlockedIncrement(&pDevExt->openCount) != 1) {
    InterlockedDecrement(&pDevExt->openCount);
    return STATUS_ACCESS_DENIED;
  }

  pIoPort = pDevExt->pIoPortLocal;

  switch (MmQuerySystemSize()) {
  case MmLargeSystem:
    size = 4096;
    pBase = (PUCHAR)ExAllocatePool(NonPagedPool, size);
    if (pBase)
      break;
  case MmMediumSystem:
    size = 1024;
    pBase = (PUCHAR)ExAllocatePool(NonPagedPool, size);
    if (pBase)
      break;
  case MmSmallSystem:
    size = 128;
    pBase = (PUCHAR)ExAllocatePool(NonPagedPool, size);
    if (pBase)
      break;
  default:
    size = 0;
    pBase = NULL;
  }

  InitializeListHead(&queueToComplete);

#if DBG
  if (pIoPort->amountInWriteQueue) {
    NTSTATUS status;
    UNICODE_STRING msg;

    status = STATUS_SUCCESS;
    RtlInitUnicodeString(&msg, NULL);
    StrAppendStr0(&status, &msg, L"!!!WARNING!!! amountInWriteQueue = ");
    StrAppendNum(&status, &msg, pIoPort->amountInWriteQueue, 10);

    Trace0((PC0C_COMMON_EXTENSION)pDevExt, msg.Buffer);

    StrFree(&msg);
  }
#endif /* DBG */

  KeAcquireSpinLock(pIoPort->pIoLock, &oldIrql);

  InitBuffer(&pIoPort->readBuf, pBase, size);

  pIoPort->amountInWriteQueue = 0;
  pIoPort->tryWrite = FALSE;
  pIoPort->errors = 0;
  pIoPort->waitMask = 0;
  pIoPort->eventMask = 0;
  pIoPort->escapeChar = 0;
  RtlZeroMemory(&pIoPort->perfStats, sizeof(pIoPort->perfStats));
  pIoPort->handFlow.XoffLimit = size >> 3;
  pIoPort->handFlow.XonLimit = size >> 1;

  SetHandFlow(pIoPort, NULL, &queueToComplete);

  KeReleaseSpinLock(pIoPort->pIoLock, oldIrql);

  FdoPortCompleteQueue(&queueToComplete);

  return STATUS_SUCCESS;
}

NTSTATUS FdoPortClose(IN PC0C_FDOPORT_EXTENSION pDevExt)
{
  LIST_ENTRY queueToComplete;
  KIRQL oldIrql;
  PC0C_IO_PORT pIoPort;

  pIoPort = pDevExt->pIoPortLocal;

  InitializeListHead(&queueToComplete);

  KeAcquireSpinLock(pIoPort->pIoLock, &oldIrql);

  pIoPort->writeHoldingRemote = 0;
  pIoPort->sendXonXoff = 0;
  SetModemStatus(pIoPort->pIoPortRemote, 0, C0C_MSB_CTS | C0C_MSB_DSR, &queueToComplete);
  FreeBuffer(&pIoPort->readBuf);
  SetBreakHolding(pIoPort, FALSE);

  KeReleaseSpinLock(pIoPort->pIoLock, oldIrql);

  FdoPortCompleteQueue(&queueToComplete);

  InterlockedDecrement(&pDevExt->openCount);

  return STATUS_SUCCESS;
}

NTSTATUS c0cOpen(IN PDEVICE_OBJECT pDevObj, IN PIRP pIrp)
{
  NTSTATUS status;
  PC0C_COMMON_EXTENSION pDevExt = pDevObj->DeviceExtension;

  TraceIrp("--- Open ---", pIrp, NULL, TRACE_FLAG_PARAMS);

  switch (pDevExt->doType) {
  case C0C_DOTYPE_FP:
    status = FdoPortOpen((PC0C_FDOPORT_EXTENSION)pDevExt);
    break;
  default:
    status = STATUS_INVALID_DEVICE_REQUEST;
  }

  pIrp->IoStatus.Information = 0;

  if (!NT_SUCCESS(status))
    TraceIrp("c0cOpen", pIrp, &status, TRACE_FLAG_RESULTS);

  pIrp->IoStatus.Status = status;
  IoCompleteRequest(pIrp, IO_NO_INCREMENT);

  return status;
}

NTSTATUS c0cClose(IN PDEVICE_OBJECT pDevObj, IN PIRP pIrp)
{
  NTSTATUS status;
  PC0C_COMMON_EXTENSION pDevExt = pDevObj->DeviceExtension;

  TraceIrp("--- Close ---", pIrp, NULL, TRACE_FLAG_PARAMS);

  switch (pDevExt->doType) {
  case C0C_DOTYPE_FP:
    status = FdoPortClose((PC0C_FDOPORT_EXTENSION)pDevExt);
    break;
  default:
    status = STATUS_INVALID_DEVICE_REQUEST;
  }

  pIrp->IoStatus.Information = 0;

  if (!NT_SUCCESS(status))
    TraceIrp("c0cClose", pIrp, &status, TRACE_FLAG_RESULTS);

  pIrp->IoStatus.Status = status;
  IoCompleteRequest(pIrp, IO_NO_INCREMENT);

  return status;
}

NTSTATUS c0cCleanup(IN PDEVICE_OBJECT pDevObj, IN PIRP pIrp)
{
  NTSTATUS status;
  PC0C_COMMON_EXTENSION pDevExt = pDevObj->DeviceExtension;

  TraceIrp("c0cCleanup", pIrp, NULL, TRACE_FLAG_PARAMS);

  switch (pDevExt->doType) {
  case C0C_DOTYPE_FP:
    FdoPortCancelQueues(((PC0C_FDOPORT_EXTENSION)pDevExt)->pIoPortLocal);

    status = STATUS_SUCCESS;
    break;
  default:
    status = STATUS_INVALID_DEVICE_REQUEST;
  }

  pIrp->IoStatus.Information = 0;

  TraceIrp("c0cCleanup", pIrp, &status, TRACE_FLAG_RESULTS);

  pIrp->IoStatus.Status = status;
  IoCompleteRequest(pIrp, IO_NO_INCREMENT);

  return status;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线啊v一区| 亚洲三级小视频| 中文字幕一区二区三区在线观看| 亚洲自拍偷拍麻豆| 国产精品一区二区免费不卡| 色先锋久久av资源部| 久久久国产一区二区三区四区小说 | 亚洲欧洲www| 久久国产福利国产秒拍| 欧美亚洲日本一区| 国产精品沙发午睡系列990531| 水蜜桃久久夜色精品一区的特点| www.在线欧美| 国产拍揄自揄精品视频麻豆| 麻豆成人av在线| 欧美日韩一区视频| 一区二区三区丝袜| 91麻豆精品秘密| 国产精品久线在线观看| 国产精品中文欧美| 久久综合999| 国产一区二区精品久久99| 9191成人精品久久| 无吗不卡中文字幕| 欧美精品高清视频| 亚洲h动漫在线| 欧美日韩精品久久久| 亚洲国产裸拍裸体视频在线观看乱了| av影院午夜一区| 综合久久国产九一剧情麻豆| 波多野结衣中文字幕一区二区三区| 精品国产人成亚洲区| 精品在线一区二区| 亚洲精品一区二区三区在线观看 | 国产老肥熟一区二区三区| 欧美一区二区视频在线观看2020| 亚洲一二三四区不卡| 欧美日韩一卡二卡| 老司机免费视频一区二区 | 久久成人av少妇免费| 日韩欧美成人激情| 国产精品中文欧美| 国产精品理伦片| 欧洲精品中文字幕| 婷婷国产在线综合| 精品福利一区二区三区免费视频| 麻豆国产一区二区| 国产偷国产偷亚洲高清人白洁 | 久久精品国产澳门| 久久综合久久综合久久| youjizz久久| 亚洲成人av福利| 精品国产免费视频| 99精品视频一区二区三区| 亚洲国产精品人人做人人爽| 777精品伊人久久久久大香线蕉| 麻豆freexxxx性91精品| 久久久久97国产精华液好用吗| 99免费精品视频| 丝袜美腿亚洲综合| 久久理论电影网| 日本精品免费观看高清观看| 日韩国产欧美在线观看| 久久精品亚洲精品国产欧美 | 国产二区国产一区在线观看| 最新不卡av在线| 日韩女同互慰一区二区| 不卡一区二区三区四区| 日韩av一区二区在线影视| 欧美国产精品专区| 在线播放一区二区三区| 成人午夜私人影院| 日精品一区二区三区| 中文字幕中文字幕一区二区| 日韩一区二区三区在线观看| 成人av资源在线| 免费精品视频最新在线| 亚洲欧洲性图库| 久久久国产一区二区三区四区小说 | 国产精品福利在线播放| 91精品国产91久久久久久最新毛片 | 欧美色偷偷大香| 成人精品一区二区三区四区| 青草国产精品久久久久久| 玉米视频成人免费看| 久久精品男人天堂av| 91精品国产综合久久久蜜臀粉嫩| 99精品视频一区| 国产激情偷乱视频一区二区三区| 三级一区在线视频先锋| 国产精品理伦片| 国产日韩欧美一区二区三区综合| 91精品国产综合久久福利| 欧美在线制服丝袜| 91丨九色porny丨蝌蚪| 国产成人无遮挡在线视频| 看电影不卡的网站| 五月婷婷久久丁香| 亚洲午夜在线观看视频在线| 亚洲色图欧洲色图| 国产精品每日更新在线播放网址| 日韩精品一区二区三区四区 | 国产精品久久久久久妇女6080| 久久综合九色综合欧美98| 欧美一区二区三区四区五区| 欧美日韩在线不卡| 色婷婷狠狠综合| 在线观看网站黄不卡| 91色综合久久久久婷婷| 99久久夜色精品国产网站| 国产高清在线精品| 成人综合婷婷国产精品久久| 国产美女主播视频一区| 国内成人自拍视频| 狠狠色丁香久久婷婷综| 国产麻豆9l精品三级站| 国产一区二区精品久久99| 国产精品一区二区三区四区| 国产精品一区二区你懂的| 国产精品一级二级三级| 成人sese在线| 91福利在线播放| 欧洲视频一区二区| 91麻豆精品国产91久久久资源速度 | av中文字幕亚洲| 成人99免费视频| 91亚洲永久精品| 欧美在线观看一二区| 欧美日本在线一区| 日韩一区二区免费高清| 精品入口麻豆88视频| 久久在线观看免费| 国产精品美女久久久久久久久 | 日韩欧美一二区| 欧美大度的电影原声| 久久久久9999亚洲精品| 国产精品久久久久影视| 伊人色综合久久天天| 天堂精品中文字幕在线| 国产在线乱码一区二区三区| 成人一道本在线| 欧美影视一区二区三区| 精品少妇一区二区三区免费观看| 久久久精品欧美丰满| 一区二区三区四区在线| 蜜乳av一区二区| 成人爱爱电影网址| 欧美精品第1页| 国产精品狼人久久影院观看方式| 亚洲高清视频的网址| 激情亚洲综合在线| 91女厕偷拍女厕偷拍高清| 欧美一区日本一区韩国一区| 国产精品污www在线观看| 亚洲大片免费看| 国产一本一道久久香蕉| 欧美性videosxxxxx| 久久久久久麻豆| 亚洲国产aⅴ天堂久久| 国产馆精品极品| 91精品国产欧美一区二区| 日韩美女久久久| 国产成a人亚洲精| 69av一区二区三区| 亚洲欧美区自拍先锋| 国产真实乱子伦精品视频| 欧美午夜精品久久久久久孕妇| 久久久精品国产免费观看同学| 婷婷国产在线综合| 色综合久久久久网| 国产日韩成人精品| 日本美女一区二区三区视频| 91麻豆免费视频| 国产日韩欧美精品在线| 久久精品国产免费| 欧美日韩国产高清一区二区三区 | 天天色图综合网| 97成人超碰视| 国产精品亲子伦对白| 久久精品噜噜噜成人88aⅴ| 在线影院国内精品| 国产精品国产a| 成人精品国产福利| 2020日本不卡一区二区视频| 蜜臀91精品一区二区三区| 欧美亚洲综合一区| 亚洲欧美国产毛片在线| 成人av综合在线| 国产精品丝袜在线| 精品一区二区免费在线观看| 91精品国产色综合久久ai换脸| 亚洲一区视频在线| 欧美综合久久久| 一区二区在线免费| 欧洲一区二区av| 亚洲va中文字幕| 日韩欧美一区在线| 蜜桃视频在线观看一区二区| 日韩欧美一级二级三级| 久久爱www久久做|