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

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

?? isopwr.c

?? softusb for atmel avr
?? C
?? 第 1 頁 / 共 3 頁
字號:
    The function value is the final status from the operation.

--*/
{
    NTSTATUS ntStatus = STATUS_SUCCESS;
    PDEVICE_EXTENSION deviceExtension;
    PIRP pIrp = NULL;

    deviceExtension =  DeviceObject->DeviceExtension;

    // This should have been reset in completion routine
    ISOUSB_ASSERT( !deviceExtension->SelfPowerIrp );

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

    ISOUSB_KdPrint( DBGLVL_HIGH,("Enter IsoUsb_SelfRequestPowerIrp() will request power irp to state %s\n",
        ISOUSB_StringForDevState( PowerState.DeviceState )));

    IsoUsb_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,
                         IsoUsb_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;

        ISOUSB_KdPrint( DBGLVL_HIGH, ("IsoUsb_SelfRequestPowerIrp() SUCCESS\n    IRP 0x%x to state %s\n",
            pIrp, ISOUSB_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;
        ISOUSB_KdPrint( DBGLVL_HIGH, ("IsoUsb_SelfRequestPowerIrp() to state %s FAILED, status = 0x%x\n",
            ISOUSB_StringForDevState( PowerState.DeviceState ),ntStatus));
    }

    return ntStatus;
}



NTSTATUS
IsoUsb_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 IsoUsb_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
    ISOUSB_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);
    }

    IsoUsb_DecrementIoCount(deviceObject);

    ISOUSB_KdPrintCond( DBGLVL_HIGH, !NT_SUCCESS(ntStatus),("Exit IsoUsb_PoSelfRequestCompletion() FAILED, ntStatus = 0x%x\n", ntStatus ));
   
    return ntStatus;
}


BOOLEAN
IsoUsb_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 IsoUsb_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 )
        //

        ISOUSB_KdPrint( DBGLVL_MEDIUM,("IsoUsb_SetDevicePowerState() PowerDeviceD3 (OFF)\n"));

        deviceExtension->CurrentDevicePowerState = DeviceState;
        break;

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

        ISOUSB_KdPrint( DBGLVL_MEDIUM,("IsoUsb_SetDevicePowerState()  %s\n",
            ISOUSB_StringForDevState(DeviceState) ));

        deviceExtension->CurrentDevicePowerState = DeviceState;
        break;

    case PowerDeviceD0:


        ISOUSB_KdPrint( DBGLVL_MEDIUM,("IsoUsb_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:

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

    return fRes;
}



NTSTATUS
IsoUsb_QueryCapabilities(
    IN PDEVICE_OBJECT PdoDeviceObject,
    IN PDEVICE_CAPABILITIES DeviceCapabilities
    )

/*++

Routine Description:

    This routine generates an internal IRP from this driver to the PDO
    to obtain information on the Physical 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:

    DeviceObject        - Physical DeviceObject for this USB controller.

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(PdoDeviceObject->StackSize, FALSE);

    if (!irp) {
        return STATUS_INSUFFICIENT_RESOURCES;
    }


    // 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);
    ISOUSB_ASSERT(nextStack != NULL);
    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,
                           IsoUsb_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;

    ntStatus = IoCallDriver(PdoDeviceObject,
                            irp);

    ISOUSB_KdPrint( DBGLVL_MEDIUM,(" IsoUsb_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);
    }

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

    IoFreeIrp(irp);

    return ntStatus;
}








?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲最新视频在线播放| 亚洲精品日韩综合观看成人91| 成人av在线播放网站| 国产iv一区二区三区| 国产精品电影一区二区| 欧美性欧美巨大黑白大战| 国产精品自拍网站| 日韩电影在线观看网站| 国产精品福利在线播放| 2023国产精品自拍| 欧美日韩成人一区| 色综合久久九月婷婷色综合| 国产在线精品国自产拍免费| 日韩福利电影在线| 亚洲最色的网站| 亚洲欧美日韩在线播放| 国产亚洲自拍一区| 精品国产乱码久久久久久免费| 欧美日韩一区久久| 色婷婷国产精品| 粉嫩嫩av羞羞动漫久久久| 久久66热re国产| 丝袜美腿一区二区三区| 亚洲国产另类av| 亚洲色图.com| 国产精品久久久久久久岛一牛影视| 精品成人一区二区三区| 日韩欧美一二三| 欧美麻豆精品久久久久久| 在线亚洲免费视频| 色偷偷一区二区三区| 91蜜桃网址入口| av在线播放不卡| 成人aaaa免费全部观看| 不卡高清视频专区| 99r国产精品| 岛国一区二区三区| 高清不卡一区二区| 丁香天五香天堂综合| 国产成人在线视频免费播放| 国产成人午夜片在线观看高清观看| 韩国视频一区二区| 国产又粗又猛又爽又黄91精品| 美女视频免费一区| 久久不见久久见免费视频1| 婷婷久久综合九色综合伊人色| 亚洲不卡一区二区三区| 日韩电影在线观看一区| 捆绑紧缚一区二区三区视频| 精一区二区三区| 国产最新精品精品你懂的| 国产河南妇女毛片精品久久久 | 精品日产卡一卡二卡麻豆| 91精品国产福利| 日韩写真欧美这视频| ww亚洲ww在线观看国产| 国产欧美一区二区三区沐欲 | 天堂va蜜桃一区二区三区漫画版| 日韩和欧美一区二区三区| 国产99久久久久| 成人性生交大片免费看中文| 91年精品国产| 欧美日本在线视频| 日韩免费观看高清完整版| 国产日韩欧美综合一区| 亚洲视频小说图片| 日韩精品视频网站| 国产一区二区伦理| 色综合色综合色综合| 欧美乱熟臀69xxxxxx| 久久久国产精品午夜一区ai换脸| 亚洲天堂成人网| 日韩精品免费视频人成| 国产中文字幕一区| 色伊人久久综合中文字幕| 欧美一区二区黄色| 亚洲国产成人午夜在线一区| 亚洲一区成人在线| 国产成人精品一区二| 欧洲色大大久久| 欧美精品一区二区三区高清aⅴ| 国产精品午夜在线观看| 亚洲bdsm女犯bdsm网站| 成人涩涩免费视频| 69久久99精品久久久久婷婷| 国产亚洲成年网址在线观看| 亚洲成av人**亚洲成av**| 国产成人午夜精品影院观看视频 | 欧美视频中文一区二区三区在线观看 | 久久精品国产秦先生| 成人黄色国产精品网站大全在线免费观看 | 国产精品人人做人人爽人人添 | 久久国产婷婷国产香蕉| 99热精品国产| 精品国产乱码久久久久久夜甘婷婷| 亚洲免费毛片网站| 国产在线不卡一区| 51午夜精品国产| 亚洲精品国产一区二区三区四区在线| 色综合天天综合给合国产| 日韩一区国产二区欧美三区| 国产精品高潮呻吟久久| 国产老妇另类xxxxx| 91麻豆精品国产91久久久久久 | 99久久久无码国产精品| 欧美大胆人体bbbb| 亚洲午夜视频在线观看| 成人精品视频网站| 久久伊99综合婷婷久久伊| 亚洲成av人片在线观看| 日本久久电影网| 欧美激情一区在线| 韩国精品一区二区| 91精品国产综合久久小美女| 一区二区在线观看视频在线观看| 国产福利精品导航| 久久免费视频一区| 久久福利视频一区二区| 在线不卡的av| 偷窥少妇高潮呻吟av久久免费| 色拍拍在线精品视频8848| 国产精品久久久久久亚洲毛片| 国内久久精品视频| 欧美不卡在线视频| 精品亚洲aⅴ乱码一区二区三区| 欧美精品一二三区| 亚洲成人自拍偷拍| 欧美偷拍一区二区| 亚洲一区二区三区爽爽爽爽爽| av在线不卡电影| 成人欧美一区二区三区黑人麻豆 | 国产精品成人免费在线| 国产中文字幕精品| 久久中文娱乐网| 精品一区二区三区免费观看| 精品国产三级电影在线观看| 美女精品自拍一二三四| 精品国产一区a| 精品一区二区三区免费观看| 日韩一级完整毛片| 国内不卡的二区三区中文字幕| 欧美不卡一区二区三区四区| 狠狠色综合播放一区二区| 国产午夜一区二区三区| 成人精品视频.| 一区二区三区在线播| 欧美日韩www| 精久久久久久久久久久| 日本一区二区三区在线不卡| 91在线视频免费91| 亚洲国产视频网站| 中文字幕中文字幕一区| 94-欧美-setu| 一区二区不卡在线视频 午夜欧美不卡在 | 秋霞成人午夜伦在线观看| 日韩亚洲欧美中文三级| 国产成人免费视频网站 | 婷婷久久综合九色国产成人| 精品三级在线看| 成人免费黄色大片| 亚洲自拍另类综合| 日韩精品影音先锋| 国产福利一区二区三区视频| 亚洲欧美色图小说| 欧美一区二区三区思思人| 国产一区二区三区香蕉| 亚洲欧美日韩国产手机在线 | 精品伊人久久久久7777人| 国产日韩欧美高清| 在线视频国产一区| 麻豆免费精品视频| 亚洲图片欧美激情| 欧美一区欧美二区| 不卡欧美aaaaa| 日韩电影在线观看电影| 国产精品福利一区二区三区| 欧美剧在线免费观看网站| 国产精品一线二线三线精华| 一区二区三区视频在线看| 久久亚洲精品小早川怜子| 91九色02白丝porn| 国产精品一区一区三区| 亚洲在线视频免费观看| 久久久91精品国产一区二区三区| 色综合久久久网| 国产乱妇无码大片在线观看| 亚洲mv在线观看| 中文字幕av一区二区三区高| 在线电影国产精品| 99久久免费精品高清特色大片| 理论片日本一区| 亚洲自拍偷拍麻豆| 国产精品久久久久一区二区三区共| 91精品国产黑色紧身裤美女| 色婷婷综合久久久| 国产精品一区专区| 日本女人一区二区三区| 亚洲色图视频网站| 国产日韩欧美高清在线| 欧美成人video|