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

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

?? isostrm.c

?? usb范例代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*++

Copyright (c) 2004  Microsoft Corporation

Module Name:

    isostrm.c

Abstract:

    This file has routines for stream transfers.
    Stream transfers are initiated and stopped using
    the IOCTLs exposed by this driver.
    The stream transfer information is contained in
    ISOUSB_STREAM_OBJECT structure which is securely
    placed in the FileObject. The ISOUSB_STREAM_OBJECT
    structure has links to ISOUSB_TRANSFER_OBJECT
    (each TRANSFER_OBJECT corresponds to the number of
    irp/urb pair circulating).
    So if the user-mode app simply crashes or aborts or
    does not terminate, we can cleanly abort the stream
    transfers.

Environment:

    Kernel mode

Notes:

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

--*/

#include "isousb.h"
#include "isopnp.h"
#include "isopwr.h"
#include "isodev.h"
#include "isousr.h"
#include "isowmi.h"
#include "isorwr.h"
#include "isostrm.h"

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

Routine Description:

    This routine create a single stream object and
    invokes StartTransfer for ISOUSB_MAX_IRP number of
    times.

Arguments:

    DeviceObject - pointer to device object
    Irp - I/O request packet

Return Value:

    NT status value

--*/
{
    ULONG                  i;
    ULONG                  info;
    ULONG                  inputBufferLength;
    ULONG                  outputBufferLength;
    NTSTATUS               ntStatus = STATUS_SUCCESS;
    PFILE_OBJECT           fileObject;
    PDEVICE_EXTENSION      deviceExtension;
    PIO_STACK_LOCATION     irpStack;
    PISOUSB_STREAM_OBJECT  streamObject;
    PUSBD_PIPE_INFORMATION pipeInformation;

    info = 0;
    irpStack = IoGetCurrentIrpStackLocation(Irp);
    fileObject = irpStack->FileObject;
    streamObject = NULL;
    pipeInformation = NULL;
    deviceExtension = DeviceObject->DeviceExtension;
    inputBufferLength = irpStack->Parameters.DeviceIoControl.InputBufferLength;
    outputBufferLength = irpStack->Parameters.DeviceIoControl.OutputBufferLength;

    IsoUsb_DbgPrint(3, ("IsoUsb_StartIsoStream - begins\n"));

    streamObject = ExAllocatePool(NonPagedPool,
                                  sizeof(struct _ISOUSB_STREAM_OBJECT));

    if(streamObject == NULL) {

        IsoUsb_DbgPrint(1, ("failed to alloc mem for streamObject\n"));

        ntStatus = STATUS_INSUFFICIENT_RESOURCES;
        goto IsoUsb_StartIsoStream_Exit;
    }

    RtlZeroMemory(streamObject, sizeof(ISOUSB_STREAM_OBJECT));

    // Find the first currently configured Isochronous IN Endpoint
    //
    for (i = 0; i < deviceExtension->NumberOfPipes; i++)
    {
        if ((deviceExtension->PipeInformation[i]->PipeType == UsbdPipeTypeIsochronous) &&
            USBD_PIPE_DIRECTION_IN(deviceExtension->PipeInformation[i]))
        {
            pipeInformation = deviceExtension->PipeInformation[i];
            break;
        }
    }

    if (pipeInformation == NULL)
    {
        ntStatus = STATUS_INVALID_PARAMETER;
        
        if (streamObject != NULL)
        {
            ExFreePool(streamObject);
            streamObject = NULL;
        }
        
        goto IsoUsb_StartIsoStream_Exit;
    }

    // reset the pipe
    //
    IsoUsb_AbortResetPipe(DeviceObject,
                          pipeInformation->PipeHandle,
                          TRUE);

    streamObject->DeviceObject = DeviceObject;
    streamObject->PipeInformation = pipeInformation;

    KeInitializeEvent(&streamObject->NoPendingIrpEvent,
                      NotificationEvent,
                      FALSE);

    for(i = 0; i < ISOUSB_MAX_IRP; i++) {

        ntStatus = IsoUsb_StartTransfer(DeviceObject,
                                        streamObject,
                                        i);

        if(!NT_SUCCESS(ntStatus)) {

            //
            // we continue sending transfer object irps..
            //

            IsoUsb_DbgPrint(1, ("IsoUsb_StartTransfer [%d] - failed\n", i));

            if(ntStatus == STATUS_INSUFFICIENT_RESOURCES) {

                ASSERT(streamObject->TransferObjectList[i] == NULL);
            }
        }
    }

    if(fileObject && fileObject->FsContext) {

        if(streamObject->PendingIrps) {

            ((PFILE_OBJECT_CONTENT)fileObject->FsContext)->StreamInformation
                                                                = streamObject;
        }
        else {

            IsoUsb_DbgPrint(1, ("no transfer object irp sent..abort..\n"));
            ExFreePool(streamObject);
            streamObject = NULL;
            ((PFILE_OBJECT_CONTENT)fileObject->FsContext)->StreamInformation = NULL;
        }
    }
    else {
        if (streamObject != NULL) {
            ExFreePool(streamObject);
            streamObject = NULL;
        }
    }

IsoUsb_StartIsoStream_Exit:

    Irp->IoStatus.Information = info;
    Irp->IoStatus.Status = ntStatus;

    IoCompleteRequest(Irp, IO_NO_INCREMENT);

    IsoUsb_DbgPrint(3, ("IsoUsb_StartIsoStream::"));
    IsoUsb_IoDecrement(deviceExtension);

    IsoUsb_DbgPrint(3, ("IsoUsb_StartIsoStream - ends\n"));

    return ntStatus;
}

NTSTATUS
IsoUsb_StartTransfer(
    IN PDEVICE_OBJECT        DeviceObject,
    IN PISOUSB_STREAM_OBJECT StreamObject,
    IN ULONG                 Index
    )
/*++

Routine Description:

    This routine creates a transfer object for each irp/urb pair.
    After initializing the pair, it sends the irp down the stack.

Arguments:

    DeviceObject - pointer to device object.
    StreamObject - pointer to stream object
    Index - index into the transfer object table in stream object

Return Value:

    NT status value

--*/
{
    PIRP                    irp;
    CCHAR                   stackSize;
    ULONG                   packetSize;
    ULONG                   maxXferSize;
    ULONG                   numPackets;
    NTSTATUS                ntStatus;
    PDEVICE_EXTENSION       deviceExtension;
    PIO_STACK_LOCATION      nextStack;
    PISOUSB_TRANSFER_OBJECT transferObject;

    deviceExtension = (PDEVICE_EXTENSION) DeviceObject->DeviceExtension;
    maxXferSize = StreamObject->PipeInformation->MaximumTransferSize;
    packetSize = StreamObject->PipeInformation->MaximumPacketSize;
    numPackets = maxXferSize / packetSize;

    IsoUsb_DbgPrint(3, ("IsoUsb_StartTransfer - begins\n"));

    transferObject = ExAllocatePool(NonPagedPool,
                                    sizeof(struct _ISOUSB_TRANSFER_OBJECT));

    if(transferObject == NULL) {

        IsoUsb_DbgPrint(1, ("failed to alloc mem for transferObject\n"));

        return STATUS_INSUFFICIENT_RESOURCES;
    }

    RtlZeroMemory(transferObject,
                  sizeof(struct _ISOUSB_TRANSFER_OBJECT));


    transferObject->StreamObject = StreamObject;

    stackSize = (CCHAR) (deviceExtension->TopOfStackDeviceObject->StackSize + 1);

    irp = IoAllocateIrp(stackSize, FALSE);

    if(irp == NULL) {

        IsoUsb_DbgPrint(1, ("failed to alloc mem for irp\n"));

        ExFreePool(transferObject);
        return STATUS_INSUFFICIENT_RESOURCES;
    }

    transferObject->Irp = irp;

    transferObject->DataBuffer = ExAllocatePool(NonPagedPool,
                                                maxXferSize);

    if(transferObject->DataBuffer == NULL) {

        IsoUsb_DbgPrint(1, ("failed to alloc mem for DataBuffer\n"));

        ExFreePool(transferObject);
        IoFreeIrp(irp);
        return STATUS_INSUFFICIENT_RESOURCES;
    }

    transferObject->Urb = ExAllocatePool(NonPagedPool,
                                         GET_ISO_URB_SIZE(numPackets));

    if(transferObject->Urb == NULL) {

        IsoUsb_DbgPrint(1, ("failed to alloc mem for Urb\n"));

        ExFreePool(transferObject->DataBuffer);
        IoFreeIrp(irp);
        ExFreePool(transferObject);
        return STATUS_INSUFFICIENT_RESOURCES;
    }

    IsoUsb_InitializeStreamUrb(DeviceObject, transferObject);

    StreamObject->TransferObjectList[Index] = transferObject;
    InterlockedIncrement((PLONG)&StreamObject->PendingIrps);

    nextStack = IoGetNextIrpStackLocation(irp);

    nextStack->Parameters.Others.Argument1 = transferObject->Urb;
    nextStack->Parameters.DeviceIoControl.IoControlCode =
                                   IOCTL_INTERNAL_USB_SUBMIT_URB;
    nextStack->MajorFunction = IRP_MJ_INTERNAL_DEVICE_CONTROL;

    IoSetCompletionRoutine(irp,
                           IsoUsb_IsoIrp_Complete,
                           transferObject,
                           TRUE,
                           TRUE,
                           TRUE);

    IsoUsb_DbgPrint(3, ("IsoUsb_StartTransfer::"));
    IsoUsb_IoIncrement(deviceExtension);

    ntStatus = IoCallDriver(deviceExtension->TopOfStackDeviceObject,
                            irp);

    if(NT_SUCCESS(ntStatus)) {

        ntStatus = STATUS_SUCCESS;
    }

    IsoUsb_DbgPrint(3, ("IsoUsb_StartTransfer - ends\n"));

    return ntStatus;
}


NTSTATUS
IsoUsb_InitializeStreamUrb(
    IN PDEVICE_OBJECT          DeviceObject,
    IN PISOUSB_TRANSFER_OBJECT TransferObject
    )
/*++

Routine Description:

    This routine initializes the irp/urb pair in the transfer object.

Arguments:

    DeviceObject - pointer to device object
    TransferObject - pointer to transfer object

Return Value:

    NT status value

--*/
{
    PURB                  urb;
    ULONG                 i;
    ULONG                 siz;
    ULONG                 packetSize;
    ULONG                 numPackets;
    ULONG                 maxXferSize;
    PISOUSB_STREAM_OBJECT streamObject;

    UNREFERENCED_PARAMETER( DeviceObject );
    
    urb = TransferObject->Urb;
    streamObject = TransferObject->StreamObject;
    maxXferSize = streamObject->PipeInformation->MaximumTransferSize;
    packetSize = streamObject->PipeInformation->MaximumPacketSize;
    numPackets = maxXferSize / packetSize;

    IsoUsb_DbgPrint(3, ("IsoUsb_InitializeStreamUrb - begins\n"));

    if(numPackets > 255) {

        numPackets = 255;
        maxXferSize = packetSize * numPackets;
    }

    siz = GET_ISO_URB_SIZE(numPackets);

    RtlZeroMemory(urb, siz);

    urb->UrbIsochronousTransfer.Hdr.Length = (USHORT) siz;
    urb->UrbIsochronousTransfer.Hdr.Function = URB_FUNCTION_ISOCH_TRANSFER;
    urb->UrbIsochronousTransfer.PipeHandle =

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91高清视频在线| 国产精品99久久久久久久女警| 精品久久久久久综合日本欧美| 欧美日韩中文另类| 日本韩国精品在线| 欧美午夜精品免费| 欧美在线|欧美| 欧美另类一区二区三区| 欧美精选在线播放| 这里只有精品电影| 欧美xxxx老人做受| 国产三级欧美三级| 国产精品电影一区二区三区| 日韩福利视频导航| 亚洲国产一区二区视频| 日本欧美在线看| 九色综合国产一区二区三区| 国产成人在线视频网址| 91在线porny国产在线看| 一本色道久久综合精品竹菊| 欧美三级视频在线| 日韩亚洲欧美一区二区三区| 久久亚洲捆绑美女| 国产精品乱码人人做人人爱| 亚洲午夜日本在线观看| 免费在线欧美视频| 成人国产亚洲欧美成人综合网| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 欧美精品电影在线播放| 51午夜精品国产| 国产精品麻豆一区二区| 夜夜嗨av一区二区三区网页| 麻豆精品精品国产自在97香蕉| 国产福利一区二区| 欧美日韩中文一区| 欧美国产欧美综合| 三级一区在线视频先锋| 丁香六月综合激情| 91精品国产乱码| 中文字幕在线一区二区三区| 日韩不卡在线观看日韩不卡视频| 国产毛片精品视频| 欧美无砖专区一中文字| 久久久久久一二三区| 亚洲一区中文在线| 国产成人精品亚洲777人妖| 欧美理论电影在线| 国产精品国产三级国产aⅴ中文| 日本不卡高清视频| 欧洲亚洲精品在线| 日精品一区二区| 成人一区二区视频| 91精品国产综合久久久久久久 | 色网站国产精品| 久久这里只有精品视频网| 亚洲另类春色校园小说| 成人听书哪个软件好| 日韩三级高清在线| 日韩激情一区二区| 欧美在线free| 亚洲欧美激情小说另类| 成人久久久精品乱码一区二区三区| 欧美一区二区免费视频| 首页国产欧美久久| 欧美日韩一本到| 亚洲一区二区三区激情| caoporen国产精品视频| 国产女人aaa级久久久级| 久久超碰97人人做人人爱| 这里只有精品视频在线观看| 午夜亚洲国产au精品一区二区| 色婷婷精品久久二区二区蜜臀av | 日韩av中文在线观看| 欧美日韩在线播放一区| 亚洲第一电影网| 欧美日韩综合在线| 日欧美一区二区| 欧美精品1区2区| 男人的天堂亚洲一区| 欧美电影免费提供在线观看| 久久99精品视频| 久久久久久久综合日本| 国产一区999| 国产精品久99| 欧美在线综合视频| 日韩中文字幕91| 日韩亚洲欧美成人一区| 狂野欧美性猛交blacked| 久久噜噜亚洲综合| 成人精品高清在线| 夜夜嗨av一区二区三区中文字幕| 欧美午夜免费电影| 美国十次综合导航| 国产日产欧美一区| 91丨porny丨首页| 三级成人在线视频| 久久毛片高清国产| 色悠久久久久综合欧美99| 樱桃国产成人精品视频| 7777精品久久久大香线蕉| 美女国产一区二区| 国产精品久久精品日日| 91精品在线观看入口| 粉嫩一区二区三区在线看| 亚洲欧洲国产专区| 日韩午夜激情视频| youjizz国产精品| 日日欢夜夜爽一区| 欧美极品xxx| 欧美放荡的少妇| 成人黄色一级视频| 毛片基地黄久久久久久天堂| 国产精品美女久久久久久久网站| 欧美日韩视频在线第一区 | 91蜜桃免费观看视频| 男女性色大片免费观看一区二区| 国产欧美一区二区三区在线老狼| 91成人看片片| 成人午夜激情片| 美女视频黄久久| 亚洲高清不卡在线| 中文字幕一区二区三区不卡在线 | 亚洲成人av中文| 欧美激情中文字幕| 7777精品伊人久久久大香线蕉的| 成人av中文字幕| 老汉av免费一区二区三区| 亚洲老司机在线| 国产精品美女久久久久久久| 日韩一区二区三区视频在线| 色美美综合视频| jlzzjlzz国产精品久久| 国产一区二区三区黄视频 | 91麻豆免费看| 国产精品18久久久| 美女视频黄久久| 日本美女一区二区三区视频| 亚洲精品一二三四区| 国产精品久久久久桃色tv| 日韩免费观看高清完整版| 欧美日韩电影一区| 欧美在线小视频| 色婷婷综合在线| 91麻豆免费观看| 色综合久久久久久久久久久| 懂色av一区二区三区蜜臀| 精品系列免费在线观看| 免费观看在线综合| 天堂在线一区二区| 日本人妖一区二区| 蜜桃在线一区二区三区| 人人狠狠综合久久亚洲| 日韩精品一级中文字幕精品视频免费观看 | 欧美日韩一卡二卡三卡| 欧美在线观看禁18| 欧美三区在线观看| 91精品国产综合久久精品性色| 欧美日韩精品系列| 91精品国产综合久久福利软件| 91精品综合久久久久久| 日韩一区二区在线免费观看| 欧美videos中文字幕| 久久婷婷色综合| 国产精品毛片久久久久久久| 国产精品美女久久久久久久| 亚洲另类在线视频| 天天综合日日夜夜精品| 精品一区二区av| 国产91精品欧美| 精品国产污网站| 中文字幕免费不卡在线| 亚洲品质自拍视频| 婷婷综合另类小说色区| 精品亚洲成av人在线观看| gogo大胆日本视频一区| 在线观看成人小视频| 欧美精品丝袜中出| 久久亚洲影视婷婷| 成人免费小视频| 日日摸夜夜添夜夜添国产精品| 国产精品亚洲一区二区三区在线| 99久久99久久综合| 欧美乱妇15p| 国产精品系列在线| 五月综合激情婷婷六月色窝| 国产剧情av麻豆香蕉精品| 99久久精品免费看国产免费软件| 欧美日韩另类一区| 国产欧美日韩中文久久| 天天av天天翘天天综合网色鬼国产| 久久精品国产免费| 色999日韩国产欧美一区二区| 精品欧美一区二区久久| 亚洲人亚洲人成电影网站色| 久久电影网站中文字幕| 色综合久久精品| 久久久精品天堂| 日韩国产精品91| 91久久精品日日躁夜夜躁欧美| 久久免费视频色|