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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ocrw.c

?? DDK 開發(fā)程序面美觀
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*++

Copyright (c) 1995  Microsoft Corporation

Module Name:

   ocrw.c

Abstract:

   read/write io test code

Environment:

    kernel mode only

Notes:

  THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
  KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
  PURPOSE.

  Copyright (c) 1996 Microsoft Corporation.  All Rights Reserved.


Revision History:

    5-4-96 : created

--*/

#define DRIVER

#include "wdm.h"
#include "stdarg.h"
#include "stdio.h"

#include "usbdi.h"
#include "usbdlib.h"
#include "D12.h"
#include "d12irp.h"


//******************************************************************************
//
// D12_CompletionStop()
//
// IO Completion Routine which just stops further completion of the Irp
//
//******************************************************************************

NTSTATUS
D12_CompletionStop (
    IN PDEVICE_OBJECT   DeviceObject,
    IN PIRP             Irp,
    IN PVOID            Context
    )
{
    return STATUS_MORE_PROCESSING_REQUIRED;
}

//******************************************************************************
//
// D12_GetCurrentFrame()
//
//******************************************************************************

ULONG
D12_GetCurrentFrame (
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    )
{
    PDEVICE_EXTENSION           deviceExtension;
    PIO_STACK_LOCATION          nextStack;
    NTSTATUS                    ntStatus;
    struct _URB_GET_CURRENT_FRAME_NUMBER urb;

    deviceExtension   = DeviceObject->DeviceExtension;

    // Initialize the URB
    //
    urb.Hdr.Function = URB_FUNCTION_GET_CURRENT_FRAME_NUMBER;
    urb.Hdr.Length   = sizeof(urb);
    urb.FrameNumber = (ULONG)-1;

    // Set the IRP parameters to pass the URB down the stack
    //
    nextStack = IoGetNextIrpStackLocation(Irp);

    nextStack->Parameters.Others.Argument1 = &urb;

    nextStack->Parameters.DeviceIoControl.IoControlCode = 
        IOCTL_INTERNAL_USB_SUBMIT_URB;                    

    nextStack->MajorFunction = IRP_MJ_INTERNAL_DEVICE_CONTROL;

    // Since this Irp is borrowed for URB_FUNCTION_GET_CURRENT_FRAME_NUMBER
    // before it is passed down later for the real URB request after this
    // routine returns, set a completion routine which stop further completion
    // of the Irp.
    //
    IoSetCompletionRoutine(
        Irp,
        D12_CompletionStop,
        NULL,   // Context
        TRUE,   // InvokeOnSuccess
        TRUE,   // InvokeOnError
        TRUE    // InvokeOnCancel
        );

    // Now pass the Irp down the stack
    //
    ntStatus = IoCallDriver(
                   deviceExtension->TopOfStackDeviceObject, 
                   Irp
                   );

    // Don't need to wait for completion because JD guarantees that
    // URB_FUNCTION_GET_CURRENT_FRAME_NUMBER will never return STATUS_PENDING

    return urb.FrameNumber;
}


//******************************************************************************
//
// D12_BuildIsoRequest()
//
//******************************************************************************

PURB
D12_BuildIsoRequest(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PD12_PIPE PipeHandle,
    IN BOOLEAN Read
    )
/*++

Routine Description:

Arguments:

    DeviceObject - pointer to the device extension for this instance of the
                     82930 device.

    Irp -

    PipeHandle -

Return Value:

    initialized async urb.

--*/
{
    ULONG siz;
    ULONG length, packetSize, numPackets, i;
    PURB urb = NULL;
    PIO_STACK_LOCATION irpSp;
    LARGE_INTEGER byteOffset;

    irpSp = IoGetCurrentIrpStackLocation(Irp);

    D12_KdPrint (("D12TEST.SYS: handle = 0x%x\n", PipeHandle));

    length = MmGetMdlByteCount(Irp->MdlAddress);

    D12_KdPrint (("D12TEST.SYS: length = 0x%x\n", length));

    byteOffset = irpSp->Parameters.Read.ByteOffset;

    D12_KdPrint (("D12TEST.SYS: offset = 0x%08X.%08X\n",
                     byteOffset.HighPart,
                     byteOffset.LowPart));

    packetSize = PipeHandle->PipeInfo->MaximumPacketSize;
    numPackets = length/packetSize;
    if (numPackets*packetSize < length) {
        numPackets++;
    }

    siz = GET_ISO_URB_SIZE(numPackets);
    urb = ExAllocatePool(NonPagedPool, siz);

    D12_KdPrint (("D12TEST.SYS: siz = 0x%x urb 0x%x\n", siz, urb));

    if (urb) {
        RtlZeroMemory(urb, siz);

        urb->UrbIsochronousTransfer.Hdr.Length = (USHORT) siz;
        urb->UrbIsochronousTransfer.Hdr.Function =
                    URB_FUNCTION_ISOCH_TRANSFER;
        urb->UrbIsochronousTransfer.PipeHandle =
                   PipeHandle->PipeInfo->PipeHandle;
        urb->UrbIsochronousTransfer.TransferFlags =
            Read ? USBD_TRANSFER_DIRECTION_IN : 0;

        urb->UrbIsochronousTransfer.TransferBufferMDL =
            Irp->MdlAddress;
        urb->UrbIsochronousTransfer.TransferBufferLength =
            length;

        if (byteOffset.HighPart)
        {
            urb->UrbIsochronousTransfer.StartFrame =
                D12_GetCurrentFrame(DeviceObject, Irp) +
                byteOffset.LowPart;
        }
        else
        {
            // start sending/receiving right away
            urb->UrbIsochronousTransfer.TransferFlags |=
                USBD_START_ISO_TRANSFER_ASAP;
        }

        urb->UrbIsochronousTransfer.NumberOfPackets = numPackets;
        urb->UrbIsochronousTransfer.UrbLink = NULL;

        for (i=0; i< urb->UrbIsochronousTransfer.NumberOfPackets; i++) {
            urb->UrbIsochronousTransfer.IsoPacket[i].Offset
                        = i * packetSize;
        }

        D12_KdPrint (("D12TEST.SYS: Init iso urb Length = 0x%x buf = 0x%x\n",
            urb->UrbIsochronousTransfer.TransferBufferLength,
            urb->UrbIsochronousTransfer.TransferBuffer));
    }

    D12_KdPrint (("D12TEST.SYS: exit D12_BuildIsoRequest\n"));

    return urb;
}


PURB
D12_BuildAsyncRequest(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PD12_PIPE PipeHandle,
    IN BOOLEAN Read
    )
/*++

Routine Description:

Arguments:

    DeviceObject - pointer to the device extension for this instance of the
                     82930 device.

    Irp -

    PipeHandle -

Return Value:

    initialized async urb.

--*/
{
    ULONG siz;
    ULONG length;
    PURB urb = NULL;

    D12_KdPrint (("D12TEST.SYS: handle = 0x%x\n", PipeHandle));

    length = MmGetMdlByteCount(Irp->MdlAddress);

    D12_KdPrint (("D12TEST.SYS: length = 0x%x\n", length));

    siz = sizeof(struct _URB_BULK_OR_INTERRUPT_TRANSFER);
    urb = ExAllocatePool(NonPagedPool, siz);

    D12_KdPrint (("D12TEST.SYS: siz = 0x%x urb 0x%x\n", siz, urb));

    if (urb) {
        RtlZeroMemory(urb, siz);

        urb->UrbBulkOrInterruptTransfer.Hdr.Length = (USHORT) siz;
        urb->UrbBulkOrInterruptTransfer.Hdr.Function =
                    URB_FUNCTION_BULK_OR_INTERRUPT_TRANSFER;
        urb->UrbBulkOrInterruptTransfer.PipeHandle =
                   PipeHandle->PipeInfo->PipeHandle;
        urb->UrbBulkOrInterruptTransfer.TransferFlags =
            Read ? USBD_TRANSFER_DIRECTION_IN : 0;

        // short packet is not treated as an error.
        urb->UrbBulkOrInterruptTransfer.TransferFlags |= 
            USBD_SHORT_TRANSFER_OK;            
                
        //
        // no linkage for now
        //

        urb->UrbBulkOrInterruptTransfer.UrbLink = NULL;

        urb->UrbBulkOrInterruptTransfer.TransferBufferMDL =
            Irp->MdlAddress;
        urb->UrbBulkOrInterruptTransfer.TransferBufferLength =
            length;

        D12_KdPrint (("D12TEST.SYS: Init async urb Length = 0x%x buf = 0x%x\n",
            urb->UrbBulkOrInterruptTransfer.TransferBufferLength,
            urb->UrbBulkOrInterruptTransfer.TransferBuffer));
    }

    D12_KdPrint (("D12TEST.SYS: exit D12_BuildAsyncRequest\n"));

    return urb;
}


NTSTATUS
D12_AsyncReadWrite_Complete(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Context
    )
/*++

Routine Description:


Arguments:

    DeviceObject - Pointer to the device object for the D12 device.

    Irp - Irp completed.

    Context - Driver defined context.

Return Value:

    The function value is the final status from the operation.

--*/
{
    NTSTATUS			ntStatus = STATUS_SUCCESS;
    PURB				urb;
    PD12_RW_CONTEXT  context = Context;
    PD12_PIPE		pipeHandle;
    PFILE_OBJECT		fileObject;
    PIO_STACK_LOCATION	irpStack;
    PDEVICE_OBJECT      deviceObject;

    if (Irp->PendingReturned) {
        IoMarkIrpPending(Irp);
    }

    urb = context->Urb;
    deviceObject = context->DeviceObject;

	D12_RemovePendingIrp(deviceObject, Irp);

    D12_KdPrint (("D12TEST.SYS: Async Completion: Length 0x%08X, Status 0x%08X\n",
                     urb->UrbBulkOrInterruptTransfer.TransferBufferLength,
                     urb->UrbHeader.Status));

    //
    // set the length based on the TransferBufferLength
    // value in the URB
    //
    Irp->IoStatus.Information =
        urb->UrbBulkOrInterruptTransfer.TransferBufferLength;

    irpStack = IoGetCurrentIrpStackLocation (Irp);
    fileObject = irpStack->FileObject;

	// get pipe handle
	pipeHandle = fileObject->FsContext;


    D12_DecrementIoCount(deviceObject);                       

    ExFreePool(context);
    ExFreePool(urb);

    return ntStatus;
}


NTSTATUS
D12_IsoReadWrite_Complete(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Context
    )
/*++

Routine Description:


Arguments:

    DeviceObject - Pointer to the device object for the D12 device.

    Irp - Irp completed.

    Context - Driver defined context.

Return Value:

    The function value is the final status from the operation.

--*/
{
    NTSTATUS			ntStatus = STATUS_SUCCESS;
    PURB				urb = Context;
    PD12_PIPE		pipeHandle;
    PFILE_OBJECT		fileObject;
    PIO_STACK_LOCATION	irpStack;
    ULONG               i;

    if (Irp->PendingReturned) {
        IoMarkIrpPending(Irp);
    }

    //
    // BUGBUG check here for interesting iso error conditions
    //
    D12_KdPrint (("D12TEST.SYS: Iso Completion: StartFrame 0x%08X, Status 0x%08X\n",
                     urb->UrbIsochronousTransfer.StartFrame,
                     urb->UrbHeader.Status));

    for (i=0; i< urb->UrbIsochronousTransfer.NumberOfPackets; i++)
    {
        D12_KdPrint (("D12TEST.SYS: [%02d] Length 0x%08X, Status 0x%08X\n",
                         i,
                         urb->UrbIsochronousTransfer.IsoPacket[i].Length,
                         urb->UrbIsochronousTransfer.IsoPacket[i].Status
                        ));
    }

    //
    // set the length based on the TransferBufferLength
    // value in the URB
    //
    Irp->IoStatus.Information =
        urb->UrbBulkOrInterruptTransfer.TransferBufferLength;

    irpStack = IoGetCurrentIrpStackLocation (Irp);
    fileObject = irpStack->FileObject;

	// get pipe handle
	pipeHandle = fileObject->FsContext;

    D12_DecrementIoCount(DeviceObject);                       

    ExFreePool(urb);

    return ntStatus;
}


NTSTATUS
D12_Read(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    )
/*++

Routine Description:

Arguments:

    DeviceObject - pointer to the device object for this instance of the 82930
                    devcice.


Return Value:

    NT status code

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91成人在线免费观看| 欧美又粗又大又爽| 精久久久久久久久久久| 日韩国产在线观看| 日本午夜精品视频在线观看| 免费日本视频一区| 午夜精品久久久久久久99樱桃| 亚洲综合色噜噜狠狠| 亚洲精品成a人| 亚洲一区二区三区影院| 亚洲成人手机在线| 免费观看日韩av| 国产在线播放一区| 国产99精品国产| www.av精品| 日本精品一区二区三区四区的功能| 色综合一个色综合亚洲| 在线一区二区三区做爰视频网站| 欧美三片在线视频观看| 欧美一区在线视频| 精品免费国产一区二区三区四区| 久久久久久亚洲综合影院红桃| 国产亚洲一区二区三区在线观看 | 在线一区二区三区四区五区| 欧美性色黄大片| 欧美一区二区美女| 久久婷婷一区二区三区| 国产精品久久久久影院色老大| 亚洲免费观看高清完整版在线观看| 亚洲一区二区视频在线| 另类调教123区| 成人免费黄色在线| 日本精品免费观看高清观看| 91精选在线观看| 久久网站最新地址| 一区二区在线观看不卡| 琪琪久久久久日韩精品| 成人免费视频一区二区| 在线观看av一区二区| 日韩一区二区三区视频在线观看| 久久影视一区二区| 亚洲一二三四在线观看| 狠狠色丁香久久婷婷综| 91亚洲精品一区二区乱码| 91精品国产综合久久久久久漫画| 久久网站最新地址| 亚洲第一电影网| 国产伦精一区二区三区| 欧美日韩综合不卡| 欧美高清在线一区二区| 午夜一区二区三区在线观看| 狠狠色伊人亚洲综合成人| 91国在线观看| 久久久99精品免费观看| 亚洲自拍都市欧美小说| 国产曰批免费观看久久久| 欧美日韩你懂得| 亚洲欧洲一区二区三区| 麻豆高清免费国产一区| 一本大道久久a久久精二百| 精品国偷自产国产一区| 亚洲久草在线视频| 国产剧情一区二区三区| 欧美色爱综合网| 国产精品久久久久一区| 久久精品国产99国产精品| 色久综合一二码| 亚洲国产精品激情在线观看| 免费成人在线影院| 欧美午夜不卡视频| 亚洲人成7777| 丁香啪啪综合成人亚洲小说 | 日韩毛片精品高清免费| 九色porny丨国产精品| 欧美日韩综合一区| 亚洲日本一区二区| 大尺度一区二区| 久久蜜臀中文字幕| 美女在线观看视频一区二区| 欧美偷拍一区二区| 亚洲精品第1页| av电影一区二区| 国产亚洲人成网站| 精久久久久久久久久久| 欧美一区二区三区人| 午夜欧美大尺度福利影院在线看| 91在线无精精品入口| 中文字幕在线观看一区二区| 国产成人综合在线播放| 久久综合色综合88| 久久99精品久久久久婷婷| 日韩一区二区三区视频在线观看| 三级久久三级久久久| 欧美日韩一区二区三区视频| 一区二区三区日韩精品视频| 色综合夜色一区| 亚洲精品视频在线看| 色综合一区二区| 亚洲激情六月丁香| 在线视频综合导航| 夜色激情一区二区| 精品婷婷伊人一区三区三| 亚洲综合免费观看高清完整版| 91在线你懂得| 亚洲另类在线视频| 欧美亚洲动漫制服丝袜| 性做久久久久久免费观看 | 国产精品萝li| thepron国产精品| 国产精品黄色在线观看| 91在线视频在线| 亚洲综合在线免费观看| 欧美视频一区二区在线观看| 图片区小说区区亚洲影院| 欧美片网站yy| 美女精品自拍一二三四| 精品久久久久久久一区二区蜜臀| 国产一区美女在线| 国产农村妇女精品| 91女厕偷拍女厕偷拍高清| 亚洲一区在线观看免费观看电影高清 | 亚洲欧美综合色| 色妹子一区二区| 午夜精品福利在线| 日韩精品影音先锋| 国产资源精品在线观看| 国产精品久久久久久福利一牛影视| 99精品视频一区二区| 亚洲一卡二卡三卡四卡五卡| 欧美一区二区三区四区久久| 国产精华液一区二区三区| 综合网在线视频| 欧美精三区欧美精三区| 狠狠色综合日日| 亚洲嫩草精品久久| 91精品国产一区二区人妖| 国产一区二区三区在线观看免费 | 色av一区二区| 蜜臀精品久久久久久蜜臀 | 国产麻豆精品一区二区| 中文字幕一区二区不卡| 欧美日韩久久久久久| 韩国三级在线一区| 亚洲欧美激情一区二区| 日韩一区二区免费在线观看| 国产91精品精华液一区二区三区| 亚洲综合一区在线| 精品福利视频一区二区三区| 99国产精品久久久久| 日本不卡一区二区三区高清视频| 国产午夜精品久久| 欧美曰成人黄网| 国产.欧美.日韩| 日韩av电影天堂| 国产精品你懂的| 91精品国产综合久久婷婷香蕉| 成人国产精品视频| 午夜精品久久久久久久| 国产精品成人在线观看| 日韩欧美在线一区二区三区| 色综合天天性综合| 国内精品伊人久久久久影院对白| 一区二区三区四区乱视频| 久久嫩草精品久久久久| 欧美色综合久久| 成人激情小说乱人伦| 日本vs亚洲vs韩国一区三区| 亚洲色图丝袜美腿| 久久夜色精品国产噜噜av| 欧美午夜精品久久久久久超碰| 粉嫩嫩av羞羞动漫久久久| 日韩激情av在线| 一区二区三区在线视频播放 | 麻豆国产欧美一区二区三区| 亚洲一区在线视频观看| 中文字幕亚洲一区二区av在线 | 亚洲欧美偷拍卡通变态| 国产亚洲人成网站| 26uuu亚洲综合色| 日韩一区二区电影网| 欧美视频在线观看一区二区| 91香蕉视频黄| 粗大黑人巨茎大战欧美成人| 国产主播一区二区三区| 日本视频一区二区| 天堂久久一区二区三区| 怡红院av一区二区三区| 中文字幕一区二区在线观看| 国产亚洲欧洲一区高清在线观看| 日韩精品最新网址| 日韩免费看网站| 日韩一区二区麻豆国产| 欧美巨大另类极品videosbest | 91小视频在线免费看| av在线不卡观看免费观看| 国产一区二区调教| 国产福利电影一区二区三区| 国产真实乱对白精彩久久| 久久99精品一区二区三区 | 在线观看一区二区视频|