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

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

?? ocrw.c

?? ARM7的一些試驗程序
?? 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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品播放一区二区| 欧美午夜电影在线播放| 久久免费偷拍视频| 国模一区二区三区白浆| 国产三级精品三级在线专区| 国产成人在线看| 国产欧美视频在线观看| 成人av小说网| 亚洲男人电影天堂| 欧美日韩国产影片| 秋霞电影一区二区| 久久人人97超碰com| 成人午夜视频在线观看| 亚洲精品中文在线观看| 欧美电影影音先锋| 国产一区二区在线视频| 国产精品精品国产色婷婷| 色婷婷一区二区三区四区| 亚洲123区在线观看| 精品国产成人系列| 91在线看国产| 日韩成人一区二区| 国产免费成人在线视频| 欧美色偷偷大香| 韩国三级中文字幕hd久久精品| 国产精品天干天干在线综合| 欧美综合欧美视频| 99麻豆久久久国产精品免费 | 免费看黄色91| 国产亚洲精品免费| 在线观看www91| 激情综合色播五月| 亚洲欧美激情一区二区| 日韩欧美色综合| 在线亚洲高清视频| 国产一区二区不卡| 天天做天天摸天天爽国产一区| 26uuu精品一区二区| 欧美色综合久久| 国产精品亚洲午夜一区二区三区| 一区二区三区国产豹纹内裤在线| 久久先锋影音av| 欧美日韩色综合| 成人高清在线视频| 久久精品999| 亚洲午夜视频在线| 中文字幕在线观看一区二区| 日韩欧美不卡在线观看视频| 91高清视频免费看| 国产91精品露脸国语对白| 日日摸夜夜添夜夜添精品视频| 国产午夜精品一区二区三区四区 | 精品在线免费观看| 亚洲精品综合在线| 亚洲国产电影在线观看| 日韩一区二区三区电影在线观看 | 欧美日韩dvd在线观看| 成人国产亚洲欧美成人综合网| 午夜激情一区二区三区| 亚洲精品日日夜夜| 一区二区三区 在线观看视频| 久久免费电影网| 欧美一区二区三区思思人| 一本大道久久a久久精二百| 丁香五精品蜜臀久久久久99网站| 久久丁香综合五月国产三级网站 | 欧美一区二区三区影视| 欧洲精品中文字幕| 91毛片在线观看| 成人精品一区二区三区中文字幕 | 18欧美乱大交hd1984| 国产日产亚洲精品系列| 国产午夜精品在线观看| 久久亚洲私人国产精品va媚药| 日韩手机在线导航| 日韩午夜小视频| 精品欧美乱码久久久久久1区2区| 日韩一区二区三区四区| 91精品午夜视频| 日韩免费观看高清完整版在线观看| 欧美精品久久久久久久久老牛影院| 欧美色图天堂网| 91精品欧美一区二区三区综合在| 欧美久久久久久久久久| 制服丝袜激情欧洲亚洲| 337p亚洲精品色噜噜狠狠| 91精品国产综合久久久久久漫画| 欧美精品日韩一本| 91精品国产色综合久久ai换脸| 日韩三级av在线播放| 精品国产乱码久久久久久图片| 久久人人97超碰com| 中文字幕精品在线不卡| 亚洲欧洲av在线| 亚洲综合激情网| 日韩精品亚洲一区| av中文字幕在线不卡| 色成人在线视频| 欧美福利视频一区| 精品久久久影院| 国产精品国产a级| 亚洲精品大片www| 日韩电影在线免费观看| 精品制服美女丁香| 成人av集中营| 欧美日韩日本视频| 精品人在线二区三区| 亚洲欧洲另类国产综合| 丝袜美腿亚洲色图| 国产美女视频91| 色拍拍在线精品视频8848| 欧美精品在线观看播放| 久久久久久久久久久久电影| 中文字幕色av一区二区三区| 亚洲国产视频一区| 国产福利精品导航| 欧美网站大全在线观看| 久久亚洲精品国产精品紫薇| 亚洲欧美区自拍先锋| 免费高清成人在线| 97成人超碰视| 精品99一区二区三区| 一个色妞综合视频在线观看| 久久精品国产亚洲高清剧情介绍 | 中文字幕亚洲一区二区av在线| 午夜精品一区二区三区免费视频| 国产综合色在线| 91麻豆精品在线观看| 日韩小视频在线观看专区| 国产精品久久久99| 捆绑调教一区二区三区| 色婷婷综合在线| 国产视频一区在线播放| 无码av中文一区二区三区桃花岛| 粉嫩aⅴ一区二区三区四区五区| 欧美乱妇一区二区三区不卡视频| 亚洲男人电影天堂| 国产一区欧美二区| 欧美高清一级片在线| 亚洲人成伊人成综合网小说| 国产一区 二区 三区一级| 欧美日韩三级在线| 亚洲欧洲制服丝袜| 国产黑丝在线一区二区三区| 欧美精品久久一区二区三区| 亚洲激情自拍偷拍| 成人综合在线观看| www激情久久| 日本怡春院一区二区| 色综合久久中文字幕综合网| 欧美韩国日本一区| 国产一区二区三区| 欧美va天堂va视频va在线| 污片在线观看一区二区| 色婷婷国产精品综合在线观看| 国产精品私人影院| 国产传媒久久文化传媒| 精品国产成人在线影院| 另类成人小视频在线| 日韩欧美在线影院| 日韩国产精品久久久久久亚洲| 欧美在线观看你懂的| 亚洲天堂精品在线观看| 99久久久国产精品免费蜜臀| 国产精品久久久一区麻豆最新章节| 国产精品综合二区| 久久久一区二区三区| 国产中文一区二区三区| 久久免费偷拍视频| 国产成人精品午夜视频免费| 久久蜜臀中文字幕| 成人综合婷婷国产精品久久 | 老色鬼精品视频在线观看播放| 91精品在线观看入口| 日本少妇一区二区| 日韩欧美的一区二区| 国产一区二区影院| 日本一区二区视频在线观看| 欧美性色aⅴ视频一区日韩精品| 一区二区三区四区不卡在线| 91福利精品第一导航| 亚洲电影在线免费观看| 欧美另类变人与禽xxxxx| 蜜臀av一级做a爰片久久| 精品对白一区国产伦| 国产精一品亚洲二区在线视频| 国产精品素人视频| 一本久久a久久精品亚洲| 亚洲成a人片在线不卡一二三区 | 国产一区二区三区四区五区美女 | 国产精品福利一区二区三区| 色av一区二区| 午夜精品视频在线观看| 欧美一级在线视频| 国产成人免费视频网站| 亚洲欧洲无码一区二区三区| 欧美艳星brazzers| 极品少妇一区二区| 中文字幕在线观看一区| 欧美美女网站色|