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

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

?? pnp.c

?? 微軟的point of sale的源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*++

Copyright (c) 1999  Microsoft Corporation

Module Name:

    pnp.c

Abstract: ESC/POS (serial) interface for USB Point-of-Sale devices

Author:

    ervinp

Environment:

    Kernel mode

Revision History:


--*/

#include <WDM.H>

#include <usbdi.h>
#include "usbdlib.h"
#include <usbioctl.h>

#include "escpos.h"
#include "debug.h"


#ifdef ALLOC_PRAGMA
        #pragma alloc_text(PAGE, FDO_PnP)
        #pragma alloc_text(PAGE, GetDeviceCapabilities)
#endif

            
NTSTATUS FDO_PnP(PARENTFDOEXT *parentFdoExt, PIRP irp)
/*++

Routine Description:

    Dispatch routine for PnP IRPs (MajorFunction == IRP_MJ_PNP)

Arguments:

    parentFdoExt - device extension for the targetted device object
    irp - IO Request Packet

Return Value:

    NT status code

--*/
{
    PIO_STACK_LOCATION irpSp;
    NTSTATUS status = STATUS_SUCCESS;
    BOOLEAN completeIrpHere = FALSE;
    BOOLEAN justReturnStatus = FALSE;
	ULONG minorFunction;
    enum deviceState prevState;

    PAGED_CODE();

    irpSp = IoGetCurrentIrpStackLocation(irp);

	/*
	 *  Get this field into a stack var so we can touch it after the IRP's completed.
	 */
	minorFunction = (ULONG)(irpSp->MinorFunction);

	DBG_LOG_PNP_IRP(irp, minorFunction, FALSE, FALSE, -1);

    switch (minorFunction){

        case IRP_MN_START_DEVICE:

            prevState = parentFdoExt->state;
            parentFdoExt->state = STATE_STARTING;

            /*
             *  First, send the START_DEVICE irp down the stack
             *  synchronously to start the lower stack.
             *  We cannot do anything with our device object
             *  before propagating the START_DEVICE this way.
             */
            IoCopyCurrentIrpStackLocationToNext(irp);
            status = CallNextDriverSync(parentFdoExt, irp);

            if (NT_SUCCESS(status) && (prevState != STATE_STOPPED)){
                /*
                 *  Now that the lower stack is started,
                 *  do any initialization required by this device object.
                 */
                status = GetDeviceCapabilities(parentFdoExt);
                if (NT_SUCCESS(status)){

                    status = InitUSB(parentFdoExt);
                    if (NT_SUCCESS(status)){
                        /*
                         *  Check whether any special feature needs to be implemented.
                         */
                        DBGVERBOSE(("FDO_PnP: Poking registry for posFlag..."));
                        status = QuerySpecialFeature(parentFdoExt);
                        
                        if (NT_SUCCESS(status)){
                            status = CreatePdoForEachEndpointPair(parentFdoExt);
                            if (NT_SUCCESS(status)){
	                            IoInvalidateDeviceRelations(parentFdoExt->physicalDevObj, BusRelations);
                            }
                        }
                    }
                }
            }

            if (NT_SUCCESS(status)){
                parentFdoExt->state = STATE_STARTED;
            }
            else {
                parentFdoExt->state = STATE_START_FAILED;
            }
            completeIrpHere = TRUE;
            break;

        case IRP_MN_QUERY_STOP_DEVICE:
            break;

        case IRP_MN_STOP_DEVICE:
            if (parentFdoExt->state == STATE_SUSPENDED){
                status = STATUS_DEVICE_POWER_FAILURE;
                completeIrpHere = TRUE;
            }
            else {
                /*
                 *  Only set state to STOPPED if the device was
                 *  previously started successfully.
                 */
                if (parentFdoExt->state == STATE_STARTED){
                    parentFdoExt->state = STATE_STOPPED;
                }
            }
            break;
      
        case IRP_MN_QUERY_REMOVE_DEVICE:
            /*
             *  We will pass this IRP down the driver stack.
             *  However, we need to change the default status
             *  from STATUS_NOT_SUPPORTED to STATUS_SUCCESS.
             */
            irp->IoStatus.Status = STATUS_SUCCESS;
            break;

        case IRP_MN_SURPRISE_REMOVAL:

            /*
             *  We will pass this IRP down the driver stack.
             *  However, we need to change the default status
             *  from STATUS_NOT_SUPPORTED to STATUS_SUCCESS.
             */
            irp->IoStatus.Status = STATUS_SUCCESS;

            /*
             *  For now just set the STATE_REMOVING state so that
             *  we don't do any more IO.  We are guaranteed to get
             *  IRP_MN_REMOVE_DEVICE soon; we'll do the rest of
             *  the remove processing there.
             */
            parentFdoExt->state = STATE_REMOVING;

            break;

        case IRP_MN_REMOVE_DEVICE:
            /*
             *  Check the current state to guard against multiple
             *  REMOVE_DEVICE IRPs.
             */
            parentFdoExt->state = STATE_REMOVED;


            /*
             *  Send the REMOVE IRP down the stack asynchronously.
             *  Do not synchronize sending down the REMOVE_DEVICE
             *  IRP, because the REMOVE_DEVICE IRP must be sent
             *  down and completed all the way back up to the sender
             *  before we continue.
             */
            IoCopyCurrentIrpStackLocationToNext(irp);
            status = IoCallDriver(parentFdoExt->physicalDevObj, irp);
            justReturnStatus = TRUE;

            DBGVERBOSE(("REMOVE_DEVICE - waiting for %d irps to complete...", parentFdoExt->pendingActionCount));  

            /*
             *  We must for all outstanding IO to complete before
             *  completing the REMOVE_DEVICE IRP.
             *
             *  First do an extra decrement on the pendingActionCount.
             *  This will cause pendingActionCount to eventually
             *  go to -1 once all asynchronous actions on this
             *  device object are complete.
             *  Then wait on the event that gets set when the
             *  pendingActionCount actually reaches -1.
             */
            DecrementPendingActionCount(parentFdoExt);
            KeWaitForSingleObject(  &parentFdoExt->removeEvent,
                                    Executive,      // wait reason
                                    KernelMode,
                                    FALSE,          // not alertable
                                    NULL );         // no timeout

            DBGVERBOSE(("REMOVE_DEVICE - ... DONE waiting. ")); 

            /*
             *  Detach our device object from the lower device object stack.
             */
            IoDetachDevice(parentFdoExt->topDevObj);

            /*
             *  Delete all child PDOs.
             */
			if (ISPTR(parentFdoExt->deviceRelations)){
                ULONG i;
				
                DBGVERBOSE(("Parent deleting %xh child PDOs on REMOVE_DEVICE", parentFdoExt->deviceRelations->Count));
                for (i = 0; i < parentFdoExt->deviceRelations->Count; i++){
                    PDEVICE_OBJECT childPdo = parentFdoExt->deviceRelations->Objects[i];
                    DEVEXT *devExt = childPdo->DeviceExtension;
                    POSPDOEXT *pdoExt;

                    ASSERT(devExt->signature == DEVICE_EXTENSION_SIGNATURE);
                    ASSERT(devExt->isPdo);
                    pdoExt = &devExt->pdoExt;
                    DeleteChildPdo(pdoExt);
                }
				FREEPOOL(parentFdoExt->deviceRelations);
                parentFdoExt->deviceRelations = BAD_POINTER;
			}

            if (ISPTR(parentFdoExt->interfaceInfo)){
                FREEPOOL(parentFdoExt->interfaceInfo);
            }

            if (ISPTR(parentFdoExt->configDesc)){
                FREEPOOL(parentFdoExt->configDesc);
            }

            /*
             *  Delete our device object.
             *  This will also delete the associated device extension.
             */
            IoDeleteDevice(parentFdoExt->functionDevObj);

            break;

        case IRP_MN_QUERY_DEVICE_RELATIONS:
		    if (irpSp->Parameters.QueryDeviceRelations.Type == BusRelations){
				status = QueryDeviceRelations(parentFdoExt, irp);
				if (NT_SUCCESS(status)){
					/*
					 *  Although we may have satisfied this IRP, 
					 *  we still pass it down the stack.
					 *  But change the default status to success.
					 */
					irp->IoStatus.Status = status;
				}
				else {
					completeIrpHere = TRUE;
				}
			}
			break;

        case IRP_MN_QUERY_CAPABILITIES:
            /*
             *  Return the USB PDO's capabilities, but add the SurpriseRemovalOK bit.
             */
            ASSERT(irpSp->Parameters.DeviceCapabilities.Capabilities);
            IoCopyCurrentIrpStackLocationToNext(irp);
            status = CallNextDriverSync(parentFdoExt, irp);
            if (NT_SUCCESS(status)){
	            irpSp->Parameters.DeviceCapabilities.Capabilities->SurpriseRemovalOK = TRUE;
            }
            completeIrpHere = TRUE;
            break;

        case IRP_MN_QUERY_PNP_DEVICE_STATE:
			break;

        default:
            break;

    }

    if (justReturnStatus){
        /*
         *  We've already sent this IRP down the stack asynchronously.
         */
    }
    else if (completeIrpHere){
		ASSERT(status != NO_STATUS);
        irp->IoStatus.Status = status;
        IoCompleteRequest(irp, IO_NO_INCREMENT);
    }
    else {
        IoCopyCurrentIrpStackLocationToNext(irp);
        status = IoCallDriver(parentFdoExt->physicalDevObj, irp);
    }

	DBG_LOG_PNP_IRP(irp, minorFunction, FALSE, TRUE, status);

    return status;
}





NTSTATUS GetDeviceCapabilities(PARENTFDOEXT *parentFdoExt)
/*++

Routine Description:

    Function retrieves the DEVICE_CAPABILITIES descriptor from the device

Arguments:

    parentFdoExt - device extension for targetted device object

Return Value:

    NT status code

--*/
{
    NTSTATUS status;
    PIRP irp;

    PAGED_CODE();

    irp = IoAllocateIrp(parentFdoExt->physicalDevObj->StackSize, FALSE);
    if (irp){
        PIO_STACK_LOCATION nextSp = IoGetNextIrpStackLocation(irp);

        nextSp->MajorFunction = IRP_MJ_PNP;
        nextSp->MinorFunction = IRP_MN_QUERY_CAPABILITIES;
        RtlZeroMemory(  &parentFdoExt->deviceCapabilities, 
                        sizeof(DEVICE_CAPABILITIES));
        nextSp->Parameters.DeviceCapabilities.Capabilities = 
                        &parentFdoExt->deviceCapabilities;

        /*
         *  For any IRP you create, you must set the default status
         *  to STATUS_NOT_SUPPORTED before sending it.
         */
        irp->IoStatus.Status = STATUS_NOT_SUPPORTED;

        status = CallNextDriverSync(parentFdoExt, irp);

        IoFreeIrp(irp);
    }
    else {
        status = STATUS_INSUFFICIENT_RESOURCES;
    }

    ASSERT(NT_SUCCESS(status));
    return status;
}


NTSTATUS QueryDeviceRelations(PARENTFDOEXT *parentFdoExt, PIRP irp)
{
    PIO_STACK_LOCATION irpSp;
    NTSTATUS status;

    PAGED_CODE();

    irpSp = IoGetCurrentIrpStackLocation(irp);

    if (irpSp->Parameters.QueryDeviceRelations.Type == BusRelations){
		DBGVERBOSE(("QueryDeviceRelations(BusRelations) for parent"));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人做爰69片免费看网站| 久久成人18免费观看| 亚洲成人一区二区在线观看| 国产精品久久久久久久久搜平片| 国产精品毛片大码女人| 亚洲美女一区二区三区| 麻豆精品一区二区三区| av成人动漫在线观看| 色婷婷精品大在线视频| 精品国产乱码久久久久久浪潮 | 欧美色精品天天在线观看视频| 欧美日韩精品三区| 国产欧美中文在线| 亚洲一区二区视频在线| 日韩国产欧美视频| 不卡视频在线观看| 欧美一区二区三级| 亚洲免费在线视频一区 二区| 日本aⅴ精品一区二区三区| 99久精品国产| 久久九九全国免费| 欧美aⅴ一区二区三区视频| 成人av综合一区| 精品福利在线导航| 日韩中文字幕1| 成人精品小蝌蚪| 欧美成人综合网站| 爽好久久久欧美精品| 91亚洲大成网污www| 91精品国产一区二区三区香蕉| 亚洲免费大片在线观看| 国产成人综合精品三级| 日韩欧美一卡二卡| 日韩国产高清在线| 欧美视频在线一区二区三区 | 成人国产亚洲欧美成人综合网| 宅男噜噜噜66一区二区66| 一区二区不卡在线播放| 不卡影院免费观看| 日本一区二区高清| 国产不卡在线播放| 久久精品视频网| 激情综合色综合久久综合| 欧美丰满少妇xxxxx高潮对白| 亚洲愉拍自拍另类高清精品| 91小视频在线免费看| 一区在线播放视频| 一本一道综合狠狠老| 最好看的中文字幕久久| 成人午夜看片网址| 久久久久久久综合日本| 国产毛片精品一区| 国产欧美一区二区在线观看| 国产成人激情av| 国产精品美女一区二区| jizz一区二区| 亚洲精选视频免费看| 91在线精品一区二区| 亚洲免费观看高清在线观看| 日本道色综合久久| 亚洲美女一区二区三区| 欧美性大战久久久久久久蜜臀 | 日本韩国欧美国产| 亚洲精品久久久蜜桃| 欧美日韩中文字幕精品| 日韩av在线免费观看不卡| 91精品国产福利| 国产美女av一区二区三区| 日本一区二区三区久久久久久久久不 | 成人午夜电影网站| 亚洲欧美精品午睡沙发| 欧美日韩一卡二卡| 亚洲福利视频一区| 在线观看91av| 国产精品资源站在线| 国产精品国产自产拍高清av| 91色.com| 久久精品国产99| 亚洲精品国产a| 久久久蜜臀国产一区二区| 欧美午夜精品一区二区三区| 国产一区二区三区久久久| 艳妇臀荡乳欲伦亚洲一区| 久久色成人在线| 欧美日韩一区高清| 91在线一区二区三区| 国内国产精品久久| 首页亚洲欧美制服丝腿| 日韩毛片高清在线播放| 精品国产乱码91久久久久久网站| 色呦呦一区二区三区| 国产·精品毛片| 国产自产视频一区二区三区| 丝袜a∨在线一区二区三区不卡| 国产精品电影院| 国产亚洲女人久久久久毛片| 91精品国产色综合久久| 欧美在线观看视频在线| 成人国产电影网| 国产精选一区二区三区| 日本aⅴ免费视频一区二区三区| 一区二区三区av电影 | 一区二区三区欧美| 国产精品第五页| 国产精品欧美久久久久无广告 | 精品一区二区三区欧美| 蜜臀久久99精品久久久久久9| 午夜精品aaa| 视频一区二区三区中文字幕| 亚洲成人黄色小说| 首页亚洲欧美制服丝腿| 亚洲成a人v欧美综合天堂| 亚洲一区二区三区四区的| 亚洲永久免费视频| 日韩激情视频在线观看| 日韩av一区二区在线影视| 香蕉久久一区二区不卡无毒影院| 亚洲一区二区av在线| 亚洲国产欧美日韩另类综合| 亚洲电影在线播放| 亚洲一区二区三区四区在线免费观看| 成人欧美一区二区三区黑人麻豆| 国产精品久久久久久久久免费相片| 中文在线一区二区| 亚洲色图一区二区| 中文字幕日韩av资源站| 自拍视频在线观看一区二区| 国产精品国产三级国产普通话三级| 久久综合一区二区| 国产精品天干天干在观线| 日本一区二区成人| 亚洲欧美激情一区二区| 亚洲一二三区视频在线观看| 亚洲成av人片| 老司机精品视频在线| 国产成人精品亚洲午夜麻豆| 国产成人综合精品三级| 99精品欧美一区二区三区综合在线| 94-欧美-setu| 91精品国产综合久久婷婷香蕉| 91麻豆精品国产91久久久久| 久久亚洲二区三区| 综合久久久久久| 亚洲第一精品在线| 久久精品国产免费看久久精品| 精品夜夜嗨av一区二区三区| 成人激情动漫在线观看| 色天使久久综合网天天| 91精品国产一区二区三区| 国产丝袜在线精品| 亚洲国产欧美一区二区三区丁香婷| 麻豆视频观看网址久久| 99久久久精品| 精品国产自在久精品国产| 亚洲三级理论片| 韩国精品一区二区| 色婷婷国产精品| 精品成人a区在线观看| 中文无字幕一区二区三区 | 欧美探花视频资源| 国产亚洲精品aa| 午夜不卡av在线| 成人av一区二区三区| 欧美一区二区三区免费在线看| 国产精品伦一区二区三级视频| 图片区小说区区亚洲影院| 成人av资源网站| 欧美电影免费提供在线观看| 中文字幕日韩欧美一区二区三区| 日本人妖一区二区| 91丨九色丨蝌蚪丨老版| 国产性色一区二区| 久草精品在线观看| 欧美女孩性生活视频| 亚洲欧美日韩在线播放| 懂色av噜噜一区二区三区av| 欧美成va人片在线观看| 亚洲最新视频在线播放| 成年人国产精品| 欧美高清在线视频| 国内精品视频666| 欧美一区二区观看视频| 亚洲综合无码一区二区| av在线不卡免费看| 久久久蜜桃精品| 色999日韩国产欧美一区二区| 久久亚洲捆绑美女| 久久se精品一区精品二区| 91超碰这里只有精品国产| 亚洲男同性视频| 99精品久久只有精品| 欧美高清在线一区二区| 国产一区91精品张津瑜| 日韩精品一区二区三区蜜臀| 日韩成人午夜电影| 777午夜精品视频在线播放| 午夜视频在线观看一区二区| 欧美久久一区二区| 日韩在线播放一区二区| 欧美一级电影网站|