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

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

?? power.c

?? usb to rs232 虛擬RS232串口驅動程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
    USB2COM_ASSERT( !deviceExtension->SelfPowerIrp );

    if (  deviceExtension->CurrentDevicePowerState ==  PowerState.DeviceState )
        return STATUS_SUCCESS;  // nothing to do

    USB2COM_KdPrint( DBGLVL_HIGH,("Enter USB2COM_SelfRequestPowerIrp() will request power irp to state %s\n",
        USB2COM_StringForDevState( PowerState.DeviceState )));

    USB2COM_IncrementIoCount(DeviceObject);

        // flag we're handling a self-generated power irp
    deviceExtension->SelfPowerIrp = TRUE;

        // actually request the Irp
    ntStatus = PoRequestPowerIrp(deviceExtension->PhysicalDeviceObject,
                         IRP_MN_SET_POWER,
                         PowerState,
                         USB2COM_PoSelfRequestCompletion,
                         DeviceObject,
                         NULL);


    if  ( ntStatus == STATUS_PENDING ) {
        // status pending is the return code we wanted

        // We only need to wait for completion if we're powering up
        if ( (ULONG) PowerState.DeviceState < deviceExtension->PowerDownLevel ) {

            NTSTATUS waitStatus;

            waitStatus = KeWaitForSingleObject(
                           &deviceExtension->SelfRequestedPowerIrpEvent,
                           Suspended,
                           KernelMode,
                           FALSE,
                           NULL);

        }

        ntStatus = STATUS_SUCCESS;

        deviceExtension->SelfPowerIrp = FALSE;

        USB2COM_KdPrint( DBGLVL_HIGH, ("USB2COM_SelfRequestPowerIrp() SUCCESS\n    IRP 0x%x to state %s\n",
            pIrp, USB2COM_StringForDevState(PowerState.DeviceState) ));


    }
    else {
        // The return status was not STATUS_PENDING; any other codes must be considered in error here;
        //  i.e., it is not possible to get a STATUS_SUCCESS  or any other non-error return from this call;
        USB2COM_KdPrint( DBGLVL_HIGH, ("USB2COM_SelfRequestPowerIrp() to state %s FAILED, status = 0x%x\n",
            USB2COM_StringForDevState( PowerState.DeviceState ),ntStatus));
    }

    return ntStatus;
}



NTSTATUS
USB2COM_PoSelfRequestCompletion(
    IN PDEVICE_OBJECT       DeviceObject,
    IN UCHAR                MinorFunction,
    IN POWER_STATE          PowerState,
    IN PVOID                Context,
    IN PIO_STATUS_BLOCK     IoStatus
    )
/*++

Routine Description:

    This routine is called when the driver completes a self-originated power IRP
        that was generated by a call to USB2COM_SelfSuspendOrActivate().
    We power down whenever the last pipe is closed and power up when the first pipe is opened.

    For power-up , we set an event in our FDO extension to signal this IRP done
    so the power request can be treated as a synchronous call.
    We need to know the device is powered up before opening the first pipe, for example.
    For power-down, we do not set the event, as no caller waits for powerdown complete.

Arguments:

    DeviceObject - Pointer to the device object for the class device. ( Physical Device Object )

    Context - Driver defined context, in this case our FDO ( functional device object )

Return Value:

    The function value is the final status from the operation.

--*/
{
    PDEVICE_OBJECT deviceObject = Context;
    PDEVICE_EXTENSION deviceExtension = deviceObject->DeviceExtension;
    NTSTATUS ntStatus = IoStatus->Status;

    // we should not be in the midst of handling a system-generated power irp
    USB2COM_ASSERT( NULL == deviceExtension->PowerIrp );

    // We only need to set the event if we're powering up;
    // No caller waits on power down complete
    if ( (ULONG) PowerState.DeviceState < deviceExtension->PowerDownLevel ) {

        // Trigger Self-requested power irp completed event;
        //  The caller is waiting for completion
        KeSetEvent(&deviceExtension->SelfRequestedPowerIrpEvent, 1, FALSE);
    }

    USB2COM_DecrementIoCount(deviceObject);

    USB2COM_KdPrintCond( DBGLVL_HIGH, !NT_SUCCESS(ntStatus),("Exit USB2COM_PoSelfRequestCompletion() FAILED, ntStatus = 0x%x\n", ntStatus ));

    return ntStatus;
}


BOOLEAN
USB2COM_SetDevicePowerState(
    IN PDEVICE_OBJECT DeviceObject,
    IN DEVICE_POWER_STATE DeviceState
    )
/*++

Routine Description:

    This routine is called when An IRP_MN_SET_POWER of type 'DevicePowerState'
    has been received by USB2COM_ProcessPowerIrp().


Arguments:

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

    DeviceState - Device specific power state to set the device in to.


Return Value:

    For requests to DeviceState D0 ( fully on ), returns TRUE to signal caller
    that we must set a completion routine and finish there.

--*/
{
    NTSTATUS ntStatus = STATUS_SUCCESS;
    PDEVICE_EXTENSION deviceExtension;
    BOOLEAN fRes = FALSE;

    deviceExtension = (PDEVICE_EXTENSION) DeviceObject->DeviceExtension;

    switch (DeviceState) {
    case PowerDeviceD3:

        //
        // Device will be going OFF,
                // TODO: add any needed device-dependent code to save state here.
                //  ( We have nothing to do in this sample )
        //

        USB2COM_KdPrint( DBGLVL_MEDIUM,("USB2COM_SetDevicePowerState() PowerDeviceD3 (OFF)\n"));

        deviceExtension->CurrentDevicePowerState = DeviceState;
        break;

    case PowerDeviceD1:
    case PowerDeviceD2:
        //
        // power states D1,D2 translate to USB suspend

        USB2COM_KdPrint( DBGLVL_MEDIUM,("USB2COM_SetDevicePowerState()  %s\n",
            USB2COM_StringForDevState(DeviceState) ));

        deviceExtension->CurrentDevicePowerState = DeviceState;
        break;

    case PowerDeviceD0:


        USB2COM_KdPrint( DBGLVL_MEDIUM,("USB2COM_SetDevicePowerState() PowerDeviceD0 (ON)\n"));

        // We'll need to finish the rest in the completion routine;
        //   signal caller we're going to D0 and will need to set a completion routine
        fRes = TRUE;

        // Caller will pass on to PDO ( Physical Device object )
        break;

    default:

        USB2COM_KdPrint( DBGLVL_MEDIUM,(" Bogus DeviceState = %x\n", DeviceState));
    }

    return fRes;
}



NTSTATUS
USB2COM_QueryCapabilities(
    IN PDEVICE_OBJECT       LowerDeviceObject,
    IN PDEVICE_CAPABILITIES DeviceCapabilities
    )

/*++

Routine Description:

    This routine generates an internal IRP from this driver to the lower portion
    of the driver stack to obtain information on the Device Object's
    capabilities. We are most interested in learning which system power states
    are to be mapped to which device power states for honoring
    IRP_MJ_SET_POWER Irps.

    This is a blocking call which waits for the IRP completion routine
    to set an event on finishing.

Arguments:

    LowerDeviceObject        - DeviceObject beneath this driver in the stack.

Return Value:

    NTSTATUS value from the IoCallDriver() call.

--*/

{
    PIO_STACK_LOCATION nextStack;
    PIRP irp;
    NTSTATUS ntStatus;
    KEVENT event;


    // This is a DDK-defined DBG-only macro that ASSERTS we are not running pageable code
    // at higher than APC_LEVEL.
    PAGED_CODE();


    // Build an IRP for us to generate an internal query request to the PDO
    irp = IoAllocateIrp(LowerDeviceObject->StackSize, FALSE);

    if (!irp) {
        return STATUS_INSUFFICIENT_RESOURCES;
    }

    //
    // Preinit the device capability structures appropriately.
    //
    RtlZeroMemory( DeviceCapabilities, sizeof(DEVICE_CAPABILITIES) );
    DeviceCapabilities->Size = sizeof(DEVICE_CAPABILITIES);
    DeviceCapabilities->Version = 1;
    DeviceCapabilities->Address = -1;
    DeviceCapabilities->UINumber = -1;

    // IoGetNextIrpStackLocation gives a higher level driver access to the next-lower
    // driver's I/O stack location in an IRP so the caller can set it up for the lower driver.
    nextStack = IoGetNextIrpStackLocation(irp);
    nextStack->MajorFunction= IRP_MJ_PNP;
    nextStack->MinorFunction= IRP_MN_QUERY_CAPABILITIES;

    // init an event to tell us when the completion routine's been called
    KeInitializeEvent(&event, NotificationEvent, FALSE);

    // Set a completion routine so it can signal our event when
    //  the next lower driver is done with the Irp
    IoSetCompletionRoutine(irp,
                           USB2COM_IrpCompletionRoutine,
                           &event,  // pass the event as Context to completion routine
                           TRUE,    // invoke on success
                           TRUE,    // invoke on error
                           TRUE);   // invoke on cancellation of the Irp


    // set our pointer to the DEVICE_CAPABILITIES struct
    nextStack->Parameters.DeviceCapabilities.Capabilities = DeviceCapabilities;

    // preset the irp to report not supported
    irp->IoStatus.Status = STATUS_NOT_SUPPORTED;

    ntStatus = IoCallDriver(LowerDeviceObject,
                            irp);

    USB2COM_KdPrint( DBGLVL_MEDIUM,(" USB2COM_QueryCapabilities() ntStatus from IoCallDriver to PCI = 0x%x\n", ntStatus));

    if (ntStatus == STATUS_PENDING) {
       // wait for irp to complete

       KeWaitForSingleObject(
            &event,
            Suspended,
            KernelMode,
            FALSE,
            NULL);

       ntStatus = irp->IoStatus.Status;
    }

    // failed? this is probably a bug
    USB2COM_KdPrintCond( DBGLVL_DEFAULT,(!NT_SUCCESS(ntStatus)), ("USB2COM_QueryCapabilities() failed\n"));

    IoFreeIrp(irp);

    return ntStatus;
}








?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美黄色影院| 亚洲成人激情综合网| 一区二区成人在线| 麻豆精品在线视频| 欧美亚洲国产bt| 国产日韩欧美精品一区| 日本成人在线一区| 色婷婷久久综合| 国产欧美一区二区精品性色 | 亚洲男人都懂的| 国产一区三区三区| 日韩一区二区三区四区| 亚洲成a人v欧美综合天堂下载| 99久久精品情趣| 日本一区二区综合亚洲| 黄一区二区三区| 日韩一区二区三免费高清| 亚洲一区二区美女| 91浏览器入口在线观看| 国产精品久久久久久久久免费丝袜 | 中文字幕+乱码+中文字幕一区| 日本欧美在线看| 欧美日本精品一区二区三区| 亚洲国产日韩在线一区模特| 色欧美乱欧美15图片| 亚洲精品五月天| 色婷婷国产精品综合在线观看| 国产精品久久久久婷婷| 国产成人精品免费在线| 久久久精品人体av艺术| 国模一区二区三区白浆| 久久久美女毛片| 国产福利一区在线| 中文字幕乱码久久午夜不卡| 福利一区在线观看| 国产精品美女视频| 91在线观看高清| 一级中文字幕一区二区| 欧美亚洲国产一区二区三区va | 国产成人精品亚洲午夜麻豆| 久久久另类综合| 成人久久久精品乱码一区二区三区 | 久久香蕉国产线看观看99| 国产精品456| 中文字幕在线不卡视频| 色www精品视频在线观看| 亚洲综合精品自拍| 欧美一级高清片| 国产电影一区二区三区| 日韩一区在线免费观看| 欧美网站大全在线观看| 热久久国产精品| 国产日产精品一区| 99久久久国产精品| 日本中文一区二区三区| 337p粉嫩大胆色噜噜噜噜亚洲| 国产在线精品不卡| 亚洲天堂中文字幕| 日韩视频免费观看高清完整版在线观看 | 国产一区二区在线看| 中文字幕在线不卡一区| 欧美疯狂做受xxxx富婆| 粉嫩一区二区三区性色av| 亚洲乱码精品一二三四区日韩在线 | 国产在线精品免费av| 亚洲婷婷在线视频| 日韩一区二区三区视频在线观看| 成人激情免费电影网址| 亚洲成av人**亚洲成av**| 久久久久久夜精品精品免费| 在线观看国产日韩| 国产毛片一区二区| 亚洲成人av一区二区| 欧美国产精品中文字幕| 69p69国产精品| 99精品国产99久久久久久白柏| 日韩在线一二三区| 一区在线观看免费| 精品国产亚洲在线| 在线一区二区观看| 国产精品一区二区男女羞羞无遮挡| 亚洲欧美另类图片小说| 亚洲精品一线二线三线无人区| 欧美专区亚洲专区| 成人av电影在线观看| 老司机免费视频一区二区| 亚洲另类春色校园小说| 国产清纯白嫩初高生在线观看91| 在线成人免费视频| 欧美亚洲动漫精品| 一本大道综合伊人精品热热 | 国产精品久久久久久久久动漫| 日韩欧美综合在线| 欧美日韩日日夜夜| 91网站最新地址| 高清不卡一区二区| 国产精品99久| 国产精品一区一区| 九色porny丨国产精品| 午夜精品一区二区三区电影天堂| 综合婷婷亚洲小说| 中文字幕 久热精品 视频在线| 久久影院午夜论| 欧美电影免费提供在线观看| 欧美一区二区三区视频| 在线播放中文一区| 欧美日韩mp4| 欧美精品123区| 91精品久久久久久蜜臀| 欧美嫩在线观看| 欧美日韩精品一区二区天天拍小说 | 日韩欧美一区中文| 欧美一区二区国产| 91精品国产高清一区二区三区蜜臀| 日本精品裸体写真集在线观看| 91蜜桃在线观看| 色哟哟国产精品| 欧美色涩在线第一页| 欧美性生活久久| 欧美色综合网站| 欧美丰满嫩嫩电影| 日韩一区二区视频| 欧美精品一区二区三区四区| 精品少妇一区二区三区视频免付费 | 一个色在线综合| 综合亚洲深深色噜噜狠狠网站| 亚洲乱码精品一二三四区日韩在线| 国产精品国产精品国产专区不蜜| 亚洲免费在线播放| 亚洲一区在线播放| 美女性感视频久久| 国产白丝网站精品污在线入口| 成人aaaa免费全部观看| 99久久伊人精品| 欧美午夜宅男影院| 欧美一二三四在线| 国产精品久久久久影院老司| 一个色妞综合视频在线观看| 美女视频黄免费的久久| 国产盗摄一区二区三区| 在线观看视频一区二区欧美日韩| 精品视频免费看| 亚洲精品一区二区三区影院 | 国产精品午夜免费| 亚洲综合999| 久久99国产精品久久99果冻传媒| 成人免费看片app下载| 欧美日韩一区三区| 久久久久9999亚洲精品| 亚洲欧美一区二区三区久本道91 | 99热国产精品| 国产在线精品免费| 91搞黄在线观看| 久久久久久久久久电影| 一二三四社区欧美黄| 国产一区二区电影| 欧美日韩精品综合在线| 国产三级久久久| 婷婷久久综合九色综合绿巨人| 成人性生交大合| 日韩精品一区二区三区三区免费| 自拍偷拍欧美激情| 乱一区二区av| 日本韩国精品在线| 国产亚洲精品免费| 日本在线观看不卡视频| 91亚洲永久精品| 久久日韩粉嫩一区二区三区| 五月婷婷综合网| 91在线精品一区二区三区| 精品国内片67194| 性感美女极品91精品| eeuss鲁片一区二区三区在线看| 欧美大片日本大片免费观看| 亚洲成人免费在线| 91色综合久久久久婷婷| 亚洲国产精品国自产拍av| 久久国产麻豆精品| 欧美日韩www| 亚洲国产日韩一区二区| 色综合中文字幕| 国产精品美日韩| 国产91精品久久久久久久网曝门 | 日韩欧美区一区二| 亚洲午夜精品一区二区三区他趣| 成人激情图片网| 国产亚洲一本大道中文在线| 久久99精品久久久久久| 日韩欧美亚洲国产精品字幕久久久| 亚洲午夜视频在线观看| 欧美午夜电影一区| 亚洲一区二区在线免费观看视频| 色欧美片视频在线观看| 亚洲欧美另类图片小说| caoporm超碰国产精品| 国产精品乱人伦| 99这里都是精品| 亚洲欧美色一区| 欧美偷拍一区二区| 午夜在线成人av|