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

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

?? isopnp.c

?? USB技術大全-54.8M.zip
?? C
?? 第 1 頁 / 共 3 頁
字號:

    DeviceObject - pointer to the FDO (Functional Device Object)

Return Value:

    NT status code

--*/
{
    PDEVICE_EXTENSION deviceExtension;
    NTSTATUS ntStatus;
    PUSB_DEVICE_DESCRIPTOR deviceDescriptor = NULL;
    PURB urb;
    ULONG siz;

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("enter IsoUsb_StartDevice\n"));

    deviceExtension = DeviceObject->DeviceExtension;

    urb = ExAllocatePool(NonPagedPool,
                         sizeof(struct _URB_CONTROL_DESCRIPTOR_REQUEST));

    ISOUSB_KdPrintCond( DBGLVL_DEFAULT,!urb, ("IsoUsb_StartDevice() FAILED ExAllocatePool() for URB\n"));

    if (urb) {

        siz = sizeof(USB_DEVICE_DESCRIPTOR);

        deviceDescriptor = ExAllocatePool(NonPagedPool,
                                          siz);

        ISOUSB_KdPrintCond( DBGLVL_DEFAULT, !deviceDescriptor, ("IsoUsb_StartDevice() FAILED ExAllocatePool() for deviceDescriptor\n"));

        if (deviceDescriptor) {

            UsbBuildGetDescriptorRequest(urb,
                                         (USHORT) sizeof (struct _URB_CONTROL_DESCRIPTOR_REQUEST),
                                         USB_DEVICE_DESCRIPTOR_TYPE,
                                         0,
                                         0,
                                         deviceDescriptor,
                                         NULL,
                                         siz,
                                         NULL);


            ntStatus = IsoUsb_CallUSBD(DeviceObject, urb);

            ISOUSB_KdPrintCond( DBGLVL_DEFAULT, !NT_SUCCESS(ntStatus), ("IsoUsb_StartDevice() FAILED IsoUsb_CallUSBD(DeviceObject, urb)\n"));

            if (NT_SUCCESS(ntStatus)) {
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("Device Descriptor = %x, len %x\n",
                                deviceDescriptor,
                                urb->UrbControlDescriptorRequest.TransferBufferLength));

                ISOUSB_KdPrint( DBGLVL_MEDIUM,("I82930 Device Descriptor:\n"));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("-------------------------\n"));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bLength %d\n", deviceDescriptor->bLength));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bDescriptorType 0x%x\n", deviceDescriptor->bDescriptorType));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bcdUSB 0x%x\n", deviceDescriptor->bcdUSB));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bDeviceClass 0x%x\n", deviceDescriptor->bDeviceClass));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bDeviceSubClass 0x%x\n", deviceDescriptor->bDeviceSubClass));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bDeviceProtocol 0x%x\n", deviceDescriptor->bDeviceProtocol));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bMaxPacketSize0 0x%x\n", deviceDescriptor->bMaxPacketSize0));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("idVendor 0x%x\n", deviceDescriptor->idVendor));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("idProduct 0x%x\n", deviceDescriptor->idProduct));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bcdDevice 0x%x\n", deviceDescriptor->bcdDevice));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("iManufacturer 0x%x\n", deviceDescriptor->iManufacturer));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("iProduct 0x%x\n", deviceDescriptor->iProduct));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("iSerialNumber 0x%x\n", deviceDescriptor->iSerialNumber));
                ISOUSB_KdPrint( DBGLVL_MEDIUM,("bNumConfigurations 0x%x\n", deviceDescriptor->bNumConfigurations));
            }
        } else {
			// if we got here we failed to allocate deviceDescriptor
            ntStatus = STATUS_INSUFFICIENT_RESOURCES;
        }

        if (NT_SUCCESS(ntStatus)) {
            deviceExtension->UsbDeviceDescriptor = deviceDescriptor;
        } else if (deviceDescriptor) {
            ExFreePool(deviceDescriptor);
        }

        ExFreePool(urb);

    } else {
		// if we got here we failed to allocate the urb
        ntStatus = STATUS_INSUFFICIENT_RESOURCES;
    }

    if (NT_SUCCESS(ntStatus)) {
        ntStatus = IsoUsb_ConfigureDevice(DeviceObject);

        ISOUSB_KdPrintCond( DBGLVL_MEDIUM,!NT_SUCCESS(ntStatus),("IsoUsb_StartDevice IsoUsb_ConfigureDevice() FAILURE (%x)\n", ntStatus));
    }


    if (NT_SUCCESS(ntStatus)) {
        deviceExtension->DeviceStarted = TRUE;
    }
    ISOUSB_KdPrint( DBGLVL_DEFAULT, ("exit IsoUsb_StartDevice (%x)\n", ntStatus));

    return ntStatus;
}


NTSTATUS
IsoUsb_RemoveDevice(
    IN  PDEVICE_OBJECT DeviceObject
    )
/*++

Routine Description:

	Called from IsoUsb_ProcessPnPIrp() to
    clean up our device instance's allocated buffers; free symbolic links

Arguments:

    DeviceObject - pointer to the FDO

Return Value:

    NT status code from free symbolic link operation

--*/
{
    PDEVICE_EXTENSION deviceExtension;
    NTSTATUS ntStatus = STATUS_SUCCESS;
    UNICODE_STRING deviceLinkUnicodeString;

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("enter IsoUsb_RemoveDevice\n"));

    deviceExtension = DeviceObject->DeviceExtension;

    RtlInitUnicodeString (&deviceLinkUnicodeString,
                          deviceExtension->DeviceLinkNameBuffer);

    // remove the GUID-based symbolic link
    ntStatus = IoSetDeviceInterfaceState(&deviceLinkUnicodeString, FALSE);
    ISOUSB_ASSERT( NT_SUCCESS( ntStatus ) );

    //
    // Free device descriptor structure
    //

    if (deviceExtension->UsbDeviceDescriptor) {
        ExFreePool(deviceExtension->UsbDeviceDescriptor);
    }


    //
    // Free pipe info structs
    //
    if( deviceExtension->PipeInfo ) { 

        ExFreePool( deviceExtension->PipeInfo );
    }

    //
    // Free up the UsbInterface structure
    //
    if (deviceExtension->UsbInterface) {
        ExFreePool(deviceExtension->UsbInterface);
    }

	// free up the USB config discriptor
    if (deviceExtension->UsbConfigurationDescriptor) {
        ExFreePool(deviceExtension->UsbConfigurationDescriptor);
    }


    ISOUSB_KdPrint( DBGLVL_DEFAULT,("exit IsoUsb_RemoveDevice() status = 0x%x\n", ntStatus ));

    return ntStatus;
}




NTSTATUS
IsoUsb_StopDevice(
    IN  PDEVICE_OBJECT DeviceObject
    )
/*++

Routine Description:

    Stops a given instance of a 82930 device on the USB.
    We basically just tell USB this device is now 'unconfigured'

Arguments:

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

Return Value:

    NT status code

--*/
{
    PDEVICE_EXTENSION deviceExtension;
    NTSTATUS ntStatus = STATUS_SUCCESS;
    PURB urb;
    ULONG siz;

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("enter IsoUsb_StopDevice\n"));

    deviceExtension = DeviceObject->DeviceExtension;

    //
    // Send the select configuration urb with a NULL pointer for the configuration
    // handle. This closes the configuration and puts the device in the 'unconfigured'
    // state.
    //

    siz = sizeof(struct _URB_SELECT_CONFIGURATION);

    urb = ExAllocatePool(NonPagedPool,
                         siz);

    if (urb) {
        UsbBuildSelectConfigurationRequest(urb,
                                          (USHORT) siz,
                                          NULL);

        ntStatus = IsoUsb_CallUSBD(DeviceObject, urb);

        ISOUSB_KdPrintCond( DBGLVL_DEFAULT,!NT_SUCCESS(ntStatus),("IsoUsb_StopDevice() FAILURE Configuration Closed status = %x usb status = %x.\n", ntStatus, urb->UrbHeader.Status));

        ExFreePool(urb);
    } else {
        ntStatus = STATUS_INSUFFICIENT_RESOURCES;
    }


    if (NT_SUCCESS(ntStatus)) {
        deviceExtension->DeviceStarted = FALSE;
    }

    deviceExtension->StopDeviceRequested = FALSE;

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("exit IsoUsb_StopDevice() (%x)\n", ntStatus));

    return ntStatus;
}



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

Routine Description:

    Used as a  general purpose completion routine so it can signal an event,
    passed as the Context, when the next lower driver is done with the input Irp.
	This routine is used by both PnP and Power Management logic.

    Even though this routine does nothing but set an event, it must be defined and
    prototyped as a completetion routine for use as such


Arguments:

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

    Irp - Irp completed.

    Context - Driver defined context, in this case a pointer to an event.

Return Value:

    The function value is the final status from the operation.

--*/
{
    PKEVENT event = Context;

    // Set the input event
    KeSetEvent(event,
               1,       // Priority increment  for waiting thread.
               FALSE);  // Flag this call is not immediately followed by wait.

    // This routine must return STATUS_MORE_PROCESSING_REQUIRED because we have not yet called
    // IoFreeIrp() on this IRP.
    return STATUS_MORE_PROCESSING_REQUIRED;

}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩亚洲欧美在线| 偷拍日韩校园综合在线| 日韩一级高清毛片| 欧美日韩成人综合天天影院| 色综合色狠狠天天综合色| a级高清视频欧美日韩| www.亚洲色图| 99国产精品久久久久久久久久久| 国产激情91久久精品导航| 国产精品乡下勾搭老头1| 国产乱码精品一区二区三区忘忧草| 极品美女销魂一区二区三区免费| 激情文学综合插| 国产精品69毛片高清亚洲| 国产成人av电影| 成人激情视频网站| 99re成人精品视频| 在线亚洲免费视频| 欧美性猛交一区二区三区精品| 欧美性受xxxx| 日韩欧美国产成人一区二区| 久久亚洲综合色| 国产精品丝袜91| 一区二区激情小说| 天堂影院一区二区| 国产精品中文欧美| 91在线云播放| 欧美片网站yy| 久久久综合精品| 亚洲欧美日韩久久精品| 视频一区视频二区中文字幕| 精品一区二区三区久久久| 国产69精品久久99不卡| 一本久道中文字幕精品亚洲嫩| 欧美理论片在线| 久久久久久毛片| 一区二区三区中文在线| 秋霞影院一区二区| 国产成人精品网址| 欧日韩精品视频| 亚洲精品一区二区三区香蕉| 国产目拍亚洲精品99久久精品| 亚洲女人小视频在线观看| 蜜臀精品一区二区三区在线观看| 国产精品一区免费视频| 在线欧美小视频| 日韩三级在线观看| 亚洲精品精品亚洲| 日本va欧美va瓶| 99久久综合国产精品| 制服丝袜在线91| 国产精品色在线观看| 午夜av一区二区三区| 国产精品一区二区三区网站| 在线观看国产一区二区| 欧美第一区第二区| 亚洲精品国产精品乱码不99| 另类欧美日韩国产在线| 日本韩国精品一区二区在线观看| 久久亚洲欧美国产精品乐播| 亚洲一区二区欧美| 国产麻豆日韩欧美久久| 欧美日韩另类一区| 中文字幕制服丝袜一区二区三区 | 91片黄在线观看| 日韩欧美区一区二| 一区二区三区免费观看| 成人午夜免费视频| 91精品国产欧美一区二区| 中文字幕一区在线观看| 韩国一区二区视频| 欧美日本不卡视频| 亚洲欧美电影一区二区| 国产精品白丝jk白祙喷水网站| 欧美日本在线看| 自拍偷自拍亚洲精品播放| 国产在线精品一区二区| 欧美精选在线播放| 依依成人精品视频| 成人一区在线看| 337p日本欧洲亚洲大胆精品| 日本伊人精品一区二区三区观看方式| 97aⅴ精品视频一二三区| 国产亚洲一区二区在线观看| 麻豆免费精品视频| 777奇米成人网| 亚洲一卡二卡三卡四卡五卡| 91福利在线导航| 亚洲狼人国产精品| 91老师片黄在线观看| 17c精品麻豆一区二区免费| 国产a级毛片一区| 久久久久久久网| 精品中文av资源站在线观看| 日韩欧美国产午夜精品| 日韩国产欧美在线播放| 欧美日韩另类一区| 午夜久久电影网| 欧美日韩一级二级三级| 亚洲第一福利一区| 欧美吞精做爰啪啪高潮| 亚洲在线观看免费视频| 欧美视频一二三区| 午夜激情一区二区三区| 欧美日韩电影一区| 欧美bbbbb| 精品日韩欧美一区二区| 精品亚洲成a人在线观看| 精品国产伦一区二区三区观看方式 | 亚洲免费观看视频| 色综合视频在线观看| 伊人性伊人情综合网| 91九色最新地址| 亚洲国产精品尤物yw在线观看| 欧美另类变人与禽xxxxx| 日韩精品1区2区3区| 精品免费国产一区二区三区四区| 久久99国产精品麻豆| 久久毛片高清国产| www.欧美日韩| 亚洲一区二区三区在线| 欧美一区二区三区影视| 极品少妇xxxx精品少妇偷拍| 国产欧美在线观看一区| 一本色道久久综合亚洲aⅴ蜜桃| 亚洲国产精品综合小说图片区| 69堂亚洲精品首页| 国产乱子轮精品视频| 国产精品久久毛片a| 欧美综合欧美视频| 另类小说综合欧美亚洲| 国产免费观看久久| 在线看一区二区| 美国毛片一区二区| 中文乱码免费一区二区| 欧美专区亚洲专区| 久久99日本精品| 一区在线观看视频| 555夜色666亚洲国产免| 国产精品一区二区在线看| 亚洲另类色综合网站| 69堂亚洲精品首页| 福利电影一区二区| 欧美激情一区二区三区全黄| 久久色在线视频| 日韩欧美在线123| 精品影视av免费| 天天综合日日夜夜精品| 免费精品99久久国产综合精品| 亚洲香肠在线观看| 亚洲aaa精品| 国内精品久久久久影院一蜜桃| 男女男精品视频| 国产精品一区专区| 欧美日韩国产精品成人| 欧美日韩一区二区欧美激情| 波多野结衣91| 秋霞影院一区二区| 自拍偷拍亚洲激情| xnxx国产精品| 欧美日韩精品一区视频| 国产精一品亚洲二区在线视频| 亚洲综合区在线| 欧美激情综合五月色丁香小说| 欧美日韩一二区| 成人国产亚洲欧美成人综合网| 日韩中文字幕亚洲一区二区va在线 | 久久精品99国产精品日本| 亚洲免费观看高清在线观看| 久久伊99综合婷婷久久伊| 欧美性受极品xxxx喷水| 不卡一区中文字幕| 国产麻豆91精品| 五月婷婷激情综合| 亚洲男人电影天堂| 国产视频视频一区| 日韩精品一区二区三区在线| 欧美日韩一级二级| 一本久道中文字幕精品亚洲嫩| 国产精品夜夜爽| 免费成人结看片| 婷婷综合另类小说色区| 亚洲欧美日韩一区| 国产精品福利电影一区二区三区四区| 精品入口麻豆88视频| 欧美高清hd18日本| 欧美日韩亚洲综合一区二区三区| 不卡的电影网站| 国产不卡在线视频| 国产精品一区二区久久精品爱涩| 热久久一区二区| 三级一区在线视频先锋| 亚洲3atv精品一区二区三区| 亚洲精品欧美在线| 亚洲视频小说图片| 亚洲欧美另类在线| 亚洲丝袜精品丝袜在线| 成人欧美一区二区三区在线播放| 国产日韩成人精品| 久久久99精品免费观看不卡|