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

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

?? sspnp.c

?? WINDDK開發代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
/*++

Copyright (c) 2000  Microsoft Corporation

Module Name:

    sSPnP.c

Abstract:

    This file contains code to handle the pnp irps.
    This is not USB specific but is essential for 
    every WDM driver.

Environment:

    Kernel mode

Notes:

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

--*/

#include "selSusp.h"
#include "sSPnP.h"
#include "sSPwr.h"
#include "sSDevCtr.h"
#include "sSWmi.h"
#include "sSUsr.h"

NTSTATUS
SS_DispatchPnP(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    )
/*++
 
Routine Description:

    The plug and play dispatch routines.
    Most of these requests the driver will completely ignore.
    In all cases it must pass on the IRP to the lower driver.

Arguments:

    DeviceObject - pointer to a device object.

    Irp - pointer to an I/O Request Packet.

Return Value:

    NT status code

--*/
{
    PIO_STACK_LOCATION irpStack;
    PDEVICE_EXTENSION  deviceExtension;
    KEVENT             startDeviceEvent;
    NTSTATUS           ntStatus;

    //
    // initialize variables
    //

    irpStack = IoGetCurrentIrpStackLocation(Irp);
    deviceExtension = DeviceObject->DeviceExtension;

    //
    // since the device is removed, fail the Irp.
    //

    if(Removed == deviceExtension->DeviceState) {

        ntStatus = STATUS_DELETE_PENDING;

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

        IoCompleteRequest(Irp, IO_NO_INCREMENT);

        return ntStatus;
    }

    SSDbgPrint(3, ("///////////////////////////////////////////\n"));
    SSDbgPrint(3, ("SS_DispatchPnP::"));
    SSIoIncrement(deviceExtension);

    if(irpStack->MinorFunction == IRP_MN_START_DEVICE) {

        ASSERT(deviceExtension->IdleReqPend == 0);
    }
    else {

        if(deviceExtension->SSEnable) {
        
            CancelSelectSuspend(deviceExtension);
        }
    }

    SSDbgPrint(2, (PnPMinorFunctionString(irpStack->MinorFunction)));

    switch(irpStack->MinorFunction) {

    case IRP_MN_START_DEVICE:

        ntStatus = HandleStartDevice(DeviceObject, Irp);

        break;

    case IRP_MN_QUERY_STOP_DEVICE:

        //
        // if we cannot stop the device, we fail the query stop irp
        //
        ntStatus = CanStopDevice(DeviceObject, Irp);

        if(NT_SUCCESS(ntStatus)) {

            ntStatus = HandleQueryStopDevice(DeviceObject, Irp);

            return ntStatus;
        }
        break;

    case IRP_MN_CANCEL_STOP_DEVICE:

        ntStatus = HandleCancelStopDevice(DeviceObject, Irp);

        break;
     
    case IRP_MN_STOP_DEVICE:

        ntStatus = HandleStopDevice(DeviceObject, Irp);

        SSDbgPrint(3, ("SS_DispatchPnP::IRP_MN_STOP_DEVICE::"));
        SSIoDecrement(deviceExtension);

        return ntStatus;

    case IRP_MN_QUERY_REMOVE_DEVICE:

        //
        // if we cannot remove the device, we fail the query remove irp
        //
        ntStatus = CanRemoveDevice(DeviceObject, Irp);

        if(NT_SUCCESS(ntStatus)) {
            
            ntStatus = HandleQueryRemoveDevice(DeviceObject, Irp);

            return ntStatus;
        }
        break;

    case IRP_MN_CANCEL_REMOVE_DEVICE:

        ntStatus = HandleCancelRemoveDevice(DeviceObject, Irp);

        break;

    case IRP_MN_SURPRISE_REMOVAL:

        ntStatus = HandleSurpriseRemoval(DeviceObject, Irp);

        SSDbgPrint(3, ("SS_DispatchPnP::IRP_MN_SURPRISE_REMOVAL::"));
        SSIoDecrement(deviceExtension);

        return ntStatus;

    case IRP_MN_REMOVE_DEVICE:

        ntStatus = HandleRemoveDevice(DeviceObject, Irp);

        return ntStatus;

    case IRP_MN_QUERY_CAPABILITIES:

        ntStatus = HandleQueryCapabilities(DeviceObject, Irp);

        break;

    default:

        IoSkipCurrentIrpStackLocation(Irp);

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

        SSDbgPrint(3, ("SS_DispatchPnP::default::"));
        SSIoDecrement(deviceExtension);

        return ntStatus;

    } // switch

    //
    // complete request 
    //
    Irp->IoStatus.Status = ntStatus;
    Irp->IoStatus.Information = 0;

    IoCompleteRequest(Irp, IO_NO_INCREMENT);

    //
    // decrement count
    //
    SSDbgPrint(3, ("SS_DispatchPnP::"));
    SSIoDecrement(deviceExtension);

    return ntStatus;
}

NTSTATUS
HandleStartDevice(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP              Irp
    )
/*++
 
Routine Description:

    This is the dispatch routine for IRP_MN_START_DEVICE

Arguments:

    DeviceObject - pointer to a device object.

    Irp - I/O request packet

Return Value:

    NT status value

--*/
{
    KIRQL             oldIrql;
    KEVENT            startDeviceEvent;
    NTSTATUS          ntStatus;
    PDEVICE_EXTENSION deviceExtension;
    LARGE_INTEGER     dueTime;

    SSDbgPrint(3, ("HandleStartDevice - begins\n"));

    //
    // initialize variables
    //
    deviceExtension = (PDEVICE_EXTENSION) DeviceObject->DeviceExtension;

    //
    // We cannot touch the device (send it any non pnp irps) until a
    // start device has been passed down to the lower drivers.
    // first pass the Irp down
    //

    KeInitializeEvent(&startDeviceEvent, NotificationEvent, FALSE);

    IoCopyCurrentIrpStackLocationToNext(Irp);

    IoSetCompletionRoutine(Irp, 
                           (PIO_COMPLETION_ROUTINE)IrpCompletionRoutine, 
                           (PVOID)&startDeviceEvent, 
                           TRUE, 
                           TRUE, 
                           TRUE);

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

    if(ntStatus == STATUS_PENDING) {

        KeWaitForSingleObject(&startDeviceEvent, 
                              Executive, 
                              KernelMode, 
                              FALSE, 
                              NULL);

        ntStatus = Irp->IoStatus.Status;
    }

    if(!NT_SUCCESS(ntStatus)) {

        SSDbgPrint(1, ("Lower drivers failed this Irp\n"));
        return ntStatus;
    }

    //
    // Read the device descriptor, configuration descriptor 
    // and select the interface descriptors
    //

    ntStatus = ReadandSelectDescriptors(DeviceObject);

    if(!NT_SUCCESS(ntStatus)) {

        SSDbgPrint(1, ("ReadandSelectDescriptors failed\n"));
        return ntStatus;
    }

    //
    // enable the symbolic links for system components to open
    // handles to the device
    //

    ntStatus = IoSetDeviceInterfaceState(&deviceExtension->InterfaceName, 
                                         TRUE);

    if(!NT_SUCCESS(ntStatus)) {

        SSDbgPrint(1, ("IoSetDeviceInterfaceState:enable:failed\n"));
        return ntStatus;
    }

    KeAcquireSpinLock(&deviceExtension->DevStateLock, &oldIrql);

    SET_NEW_PNP_STATE(deviceExtension, Working);
    deviceExtension->QueueState = AllowRequests;

    KeReleaseSpinLock(&deviceExtension->DevStateLock, oldIrql);

    //
    // initialize wait wake variables
    // and issue a wait wake.
    
    deviceExtension->WaitWakeIrp = NULL;
    deviceExtension->FlagWWCancel = 0;
    deviceExtension->FlagWWOutstanding = 0;

    if(deviceExtension->WaitWakeEnable) {

        IssueWaitWake(deviceExtension);
    }

    ProcessQueuedRequests(deviceExtension);

    if(WinXpOrBetter == deviceExtension->WdmVersion) {

        deviceExtension->SSEnable = deviceExtension->SSRegistryEnable;

        //
        // set timer for selective suspend requests.
        //

        if(deviceExtension->SSEnable) {

            dueTime.QuadPart = -10000 * IDLE_INTERVAL;               // 5000 ms

            SSDbgPrint(3, ("Setting the timer...\n"));
            KeSetTimerEx(&deviceExtension->Timer, 
                         dueTime,
                         IDLE_INTERVAL,                              // 5000 ms
                         &deviceExtension->DeferredProcCall);

            deviceExtension->FreeIdleIrpCount = 0;
        }
    }

    SSDbgPrint(3, ("HandleStartDevice - ends\n"));

    return ntStatus;
}


NTSTATUS
ReadandSelectDescriptors(
    IN PDEVICE_OBJECT DeviceObject
    )
/*++
 
Routine Description:

    This routine configures the USB device.
    In this routines we get the device descriptor, 
    the configuration descriptor and select the
    configuration descriptor.

Arguments:

    DeviceObject - pointer to a device object

Return Value:

    NTSTATUS - NT status value.

--*/
{
    PURB                   urb;
    ULONG                  siz;
    NTSTATUS               ntStatus;
    PUSB_DEVICE_DESCRIPTOR deviceDescriptor;
    
    //
    // initialize variables
    //

    urb = NULL;
    deviceDescriptor = NULL;

    //
    // 1. Read the device descriptor
    //

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

    if(urb) {

        siz = sizeof(USB_DEVICE_DESCRIPTOR);
        deviceDescriptor = ExAllocatePool(NonPagedPool, siz);

        if(deviceDescriptor) {

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

            ntStatus = CallUSBD(DeviceObject, urb);

            if(NT_SUCCESS(ntStatus)) {

                ASSERT(deviceDescriptor->bNumConfigurations);
                ntStatus = ConfigureDevice(DeviceObject);    
            }
            			    
            ExFreePool(urb);                
            ExFreePool(deviceDescriptor);
        }
        else {

            SSDbgPrint(1, ("Failed to allocate memory for deviceDescriptor"));

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

        SSDbgPrint(1, ("Failed to allocate memory for urb"));

        ntStatus = STATUS_INSUFFICIENT_RESOURCES;
    }

    return ntStatus;
}

NTSTATUS
ConfigureDevice(
	IN PDEVICE_OBJECT DeviceObject
    )
/*++
 
Routine Description:

    This helper routine reads the configuration descriptor
    for the device in couple of steps.

Arguments:

    DeviceObject - pointer to a device object

Return Value:

    NTSTATUS - NT status value

--*/
{
    PURB                          urb;
    ULONG                         siz;
    NTSTATUS                      ntStatus;
    PDEVICE_EXTENSION             deviceExtension;
    PUSB_CONFIGURATION_DESCRIPTOR configurationDescriptor;

    //
    // initialize the variables
    //

    urb = NULL;
    configurationDescriptor = NULL;
    deviceExtension = DeviceObject->DeviceExtension;

    //
    // Read the first configuration descriptor
    // This requires two steps:
    // 1. Read the fixed sized configuration desciptor (CD)
    // 2. Read the CD with all embedded interface and endpoint descriptors
    //

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

    if(urb) {

        siz = sizeof(USB_CONFIGURATION_DESCRIPTOR);
        configurationDescriptor = ExAllocatePool(NonPagedPool, siz);

        if(configurationDescriptor) {

            UsbBuildGetDescriptorRequest(
                    urb, 
                    (USHORT) sizeof(struct _URB_CONTROL_DESCRIPTOR_REQUEST),
                    USB_CONFIGURATION_DESCRIPTOR_TYPE, 
                    0, 
                    0, 
                    configurationDescriptor,
                    NULL, 
                    sizeof(USB_CONFIGURATION_DESCRIPTOR), 
                    NULL);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美色图小说| 欧美激情一区二区三区四区| 国产a精品视频| 亚洲在线观看免费| 久久久青草青青国产亚洲免观| 91在线播放网址| 国内外成人在线| 亚洲午夜久久久久中文字幕久| 久久免费视频一区| 欧美精品99久久久**| 暴力调教一区二区三区| 精油按摩中文字幕久久| 亚洲aaa精品| 亚洲美女区一区| 日本一区二区三区国色天香 | 一本一道久久a久久精品| 麻豆精品久久精品色综合| 亚洲精品日韩专区silk| 中文av字幕一区| 精品国产91洋老外米糕| 欧美日本不卡视频| 色一情一伦一子一伦一区| 国产成人精品一区二区三区四区| 日韩精品视频网| 亚洲超碰精品一区二区| 一区二区三区美女视频| 中文字幕一区二区三| 中文在线资源观看网站视频免费不卡| 日韩欧美国产午夜精品| 7777精品伊人久久久大香线蕉完整版| 91美女在线看| 91视频观看免费| 9久草视频在线视频精品| 成人午夜大片免费观看| 国产传媒欧美日韩成人| 国产米奇在线777精品观看| 喷白浆一区二区| 久久精品国产成人一区二区三区 | 国产一区二区不卡老阿姨| 蜜臀va亚洲va欧美va天堂| 日韩中文字幕不卡| 天天操天天色综合| 亚洲成人av电影在线| 亚洲国产一区在线观看| 亚洲一区欧美一区| 亚洲国产另类精品专区| 污片在线观看一区二区| 日韩电影网1区2区| 久色婷婷小香蕉久久| 国产一区二区h| 国产1区2区3区精品美女| 成人免费视频视频| kk眼镜猥琐国模调教系列一区二区 | 久久综合久久综合久久综合| 精品剧情v国产在线观看在线| 日韩欧美一区中文| 精品国产伦一区二区三区观看方式| 精品国产污污免费网站入口| 26uuu国产电影一区二区| 久久九九影视网| 中文字幕一区二区三区av| 亚洲一区二区欧美激情| 美国毛片一区二区| 国产精品一区二区不卡| 97久久精品人人做人人爽| 欧美日韩在线直播| 日韩精品中文字幕一区| 欧美激情一区二区三区四区| 综合激情网...| 午夜免费久久看| 国内精品久久久久影院一蜜桃| 国产精品一区二区男女羞羞无遮挡 | 狠狠色丁香久久婷婷综合_中 | 白白色亚洲国产精品| 欧美在线制服丝袜| 日韩女优制服丝袜电影| 国产成人在线免费| 欧洲生活片亚洲生活在线观看| 午夜视黄欧洲亚洲| 中文字幕一区二区三区不卡| 亚洲第一精品在线| 国产精品资源网站| 色94色欧美sute亚洲线路一ni | 精品毛片乱码1区2区3区| 亚洲国产精品成人综合色在线婷婷| 亚洲精品欧美在线| 韩国三级在线一区| 91网站黄www| 精品福利一二区| 一区二区三区免费在线观看| 久久精品国产亚洲一区二区三区| 不卡视频免费播放| 欧美一级日韩免费不卡| 亚洲欧洲日韩一区二区三区| 日韩高清不卡一区| 91麻豆成人久久精品二区三区| 日韩三级免费观看| 亚洲激情五月婷婷| 国产91精品一区二区麻豆亚洲| 欧美日本免费一区二区三区| 国产精品美日韩| 精品在线一区二区三区| 欧洲一区在线电影| 国产精品麻豆网站| 久久99国产精品麻豆| 欧美精品一卡二卡| 亚洲日本va午夜在线影院| 黑人巨大精品欧美黑白配亚洲| 欧美日韩你懂的| 国产精品久久久久久久久动漫| 日韩福利电影在线| 欧美日韩一区三区| 一区在线播放视频| 国产精品一区二区三区乱码| 日韩精品在线网站| 亚洲成人黄色影院| 一本大道av伊人久久综合| 欧美激情一区二区三区四区| 激情五月婷婷综合网| 欧美一区二区视频免费观看| 亚洲成人免费电影| 欧美色视频在线| 亚洲精品乱码久久久久久日本蜜臀| 国产一二精品视频| 久久婷婷国产综合国色天香| 日本亚洲欧美天堂免费| 欧美另类z0zxhd电影| 亚洲成人自拍一区| 欧美视频在线观看一区二区| 亚洲女爱视频在线| 91美女精品福利| 亚洲少妇屁股交4| 粉嫩aⅴ一区二区三区四区| 国产欧美日产一区| 成人看片黄a免费看在线| 国产日产精品1区| 国产成人av资源| 欧美极品少妇xxxxⅹ高跟鞋 | 欧美做爰猛烈大尺度电影无法无天| 国产精品不卡视频| 波波电影院一区二区三区| 国产精品免费久久| 日韩精品亚洲一区| 精品美女被调教视频大全网站| 精品一区二区三区免费观看| 久久综合九色综合97婷婷女人 | 韩国成人福利片在线播放| 欧美刺激脚交jootjob| 狠狠色丁香婷综合久久| 久久久欧美精品sm网站| 国产成人精品一区二区三区四区| 国产精品色噜噜| 日本精品免费观看高清观看| 亚洲一区二区三区四区不卡| 欧美理论在线播放| 激情综合色丁香一区二区| 久久免费国产精品| 99精品在线观看视频| 亚洲福中文字幕伊人影院| 欧美日本韩国一区二区三区视频| 美腿丝袜亚洲一区| 久久久精品人体av艺术| 96av麻豆蜜桃一区二区| 亚洲国产va精品久久久不卡综合 | 欧美一区二区在线观看| 久久99热国产| 国产精品沙发午睡系列990531| 色婷婷综合久久久中文一区二区| 亚洲妇熟xx妇色黄| 久久久久免费观看| 91视视频在线观看入口直接观看www | 欧美天天综合网| 九九国产精品视频| 中文字幕日韩欧美一区二区三区| 欧美日韩国产小视频| 激情另类小说区图片区视频区| 中文字幕一区二区视频| 欧美妇女性影城| 成人免费高清在线| 亚洲成人免费看| 亚洲国产精品ⅴa在线观看| 欧美日韩免费观看一区三区| 国产一区三区三区| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美国产国产综合| 欧美日韩一级黄| 国产成人精品免费在线| 亚洲一区二区在线免费看| 精品日韩99亚洲| 色婷婷综合久久久久中文一区二区 | 欧美久久一二区| 丁香婷婷深情五月亚洲| 日日骚欧美日韩| 一区在线观看免费| 久久色在线视频| 欧美情侣在线播放| jvid福利写真一区二区三区| 久久国产综合精品| 亚洲国产wwwccc36天堂| 亚洲视频免费在线观看|