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

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

?? ocrw.c

?? 完成uc/os-ii下usb固件驅(qū)動
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*++

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
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日欧美一区二区| 中文字幕一区二区三区色视频| 亚洲伦理在线精品| 色婷婷激情久久| 一区二区三区四区乱视频| 91高清在线观看| 爽好多水快深点欧美视频| 日韩一区二区视频| 国产69精品久久久久毛片| 日韩一区中文字幕| 欧美日韩午夜精品| 黑人巨大精品欧美一区| 中文字幕精品三区| 日本福利一区二区| 日韩黄色在线观看| 国产精品丝袜久久久久久app| 91美女福利视频| 视频在线在亚洲| 国产欧美精品一区二区色综合| 一本色道综合亚洲| 日本成人在线不卡视频| 久久精品网站免费观看| 91蝌蚪porny| 日本成人在线一区| 中文字幕一区不卡| 在线不卡的av| 国产·精品毛片| 亚洲成人福利片| 久久久久久久久久久电影| 99国产精品久久久| 奇米色一区二区| 国产精品传媒入口麻豆| 日韩视频一区二区在线观看| 不卡的电影网站| 奇米888四色在线精品| 中文字幕中文字幕中文字幕亚洲无线| 欧美日韩一区二区三区高清| 福利视频网站一区二区三区| 日本成人在线一区| 亚洲欧美一区二区三区久本道91| 欧美va亚洲va| 欧美日韩mp4| 91香蕉视频在线| 国产一区高清在线| 亚洲成人一区二区在线观看| 国产精品视频一区二区三区不卡| 91精选在线观看| 91免费视频大全| 国产成人精品一区二| 日韩精品成人一区二区在线| 亚洲免费成人av| 国产精品久久久久三级| 精品福利av导航| 欧美日韩国产不卡| 在线看日本不卡| www..com久久爱| 懂色av一区二区三区蜜臀| 日韩成人免费看| 亚洲成人自拍一区| 亚洲最大成人综合| 国产精品久久久久aaaa樱花 | 免费在线看成人av| 一区二区高清在线| 最新国产の精品合集bt伙计| 国产午夜亚洲精品不卡| 日韩一区二区免费高清| 欧美精品aⅴ在线视频| 欧洲另类一二三四区| 一本一道久久a久久精品综合蜜臀| 国产精华液一区二区三区| 久久国产剧场电影| 麻豆精品视频在线观看视频| 亚洲电影视频在线| 亚洲自拍偷拍av| 亚洲国产精品影院| 午夜久久久久久电影| 亚洲小少妇裸体bbw| 亚洲风情在线资源站| 国内精品在线播放| 欧美96一区二区免费视频| 日韩中文字幕亚洲一区二区va在线 | 五月婷婷综合激情| 午夜在线成人av| 亚洲国产精品久久不卡毛片 | 国产成人av一区二区三区在线 | 国产成人av资源| 成人av资源下载| 不卡免费追剧大全电视剧网站| av日韩在线网站| 色网综合在线观看| 欧美性极品少妇| 日韩欧美一级在线播放| 精品成人a区在线观看| 久久亚洲一级片| 中文字幕一区二区5566日韩| 亚洲综合激情网| 日韩中文字幕区一区有砖一区 | 天堂蜜桃一区二区三区| 免费观看成人鲁鲁鲁鲁鲁视频| 麻豆91免费观看| 国产成人高清视频| 91久久一区二区| 91精品免费在线| 国产亚洲欧美日韩日本| 国产精品久99| 日韩av网站免费在线| 国产成人精品综合在线观看| 在线免费观看日韩欧美| 日韩欧美国产一区在线观看| 中文在线资源观看网站视频免费不卡| 亚洲色图视频网站| 视频在线观看91| 成人av在线一区二区| 在线不卡免费欧美| 国产精品私房写真福利视频| 亚洲福利一区二区三区| 国产成人精品一区二区三区四区 | 国产精品18久久久久久久久久久久| 久久综合久久鬼色| 亚洲图片你懂的| 男女男精品网站| 91浏览器打开| 欧美精品一区二区高清在线观看| 中文字幕中文乱码欧美一区二区| 日韩高清在线电影| 99久免费精品视频在线观看| 在线播放中文字幕一区| 亚洲欧洲日韩一区二区三区| 免费一级欧美片在线观看| 91女人视频在线观看| 精品福利一区二区三区免费视频| 亚洲一区二区三区小说| 国产电影精品久久禁18| 9191精品国产综合久久久久久| 国产精品理伦片| 国产美女娇喘av呻吟久久| 91精品国产综合久久婷婷香蕉| 国产精品福利在线播放| 激情综合五月天| 欧美久久一区二区| 亚洲黄色免费电影| 成人免费看的视频| 2020国产成人综合网| 首页国产欧美久久| 在线免费一区三区| 国产精品福利在线播放| 国产成人亚洲综合a∨婷婷图片| 欧美日韩在线观看一区二区| 亚洲欧美偷拍卡通变态| 欧美xfplay| 日韩和欧美的一区| 欧美日韩www| 一区二区三区中文在线| 成人动漫视频在线| 国产午夜精品美女毛片视频| 丝袜诱惑制服诱惑色一区在线观看 | 看电视剧不卡顿的网站| 欧美图片一区二区三区| 中文字幕在线不卡一区| 国产一区二区三区免费| 精品国产免费一区二区三区香蕉 | 久久免费视频色| 免费看欧美美女黄的网站| 欧美精品高清视频| 日本亚洲最大的色成网站www| 欧美视频一区二区三区四区| 亚洲精品高清在线| 91久久奴性调教| 玉米视频成人免费看| 91香蕉视频mp4| 亚洲精品成人悠悠色影视| 一本一本大道香蕉久在线精品 | 丁香网亚洲国际| 国产精品丝袜一区| 99精品国产热久久91蜜凸| 日韩美女精品在线| 色婷婷综合久久久中文字幕| 亚洲精品自拍动漫在线| 91免费看视频| 午夜一区二区三区视频| 日韩欧美色综合| 国产成a人亚洲精品| 亚洲免费毛片网站| 欧美乱妇20p| 久久99最新地址| 中文字幕不卡三区| 色偷偷久久一区二区三区| 午夜精品久久久久影视| 日韩精品一区在线观看| 国产成人精品亚洲日本在线桃色| 综合欧美一区二区三区| 色狠狠综合天天综合综合| 视频一区视频二区中文字幕| 欧美精品一区二区在线播放| 丁香五精品蜜臀久久久久99网站 | 91啪九色porn原创视频在线观看| 亚洲国产精品精华液网站| 日韩免费视频一区| 99久久婷婷国产综合精品| 亚洲福利电影网|