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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? debug.h

?? HomePNA的Usb網(wǎng)卡驅(qū)動
?? H
字號:
/*++

Copyright (c) 1999  Microsoft Corporation

Module Name:

   debug.h

Abstract:
        Header for debug output logic

Environment:

    kernel mode only

Notes:

  THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
  KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
  PURPOSE.

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


Revision History:


--*/

#ifndef _DEBUG_H_
#define _DEBUG_H_

#if DBG
    #define DEBUG
    #define DEBUG_USB

//Begin, Debug code from BulkUsb


#ifndef DBGSTR_PREFIX
#define DBGSTR_PREFIX "Usb: " 
#endif


#define DPRINT DbgPrint

#define TRAP() DbgBreakPoint();


#define USB_DBGOUTSIZE        512


typedef struct _USB_DBGDATA {

    // mirrors device extension pending io count
    ULONG PendingIoCount;

    // count of pipe errors detected during the life of this device instance
    ULONG PipeErrorCount;

    // count of pipe resets performed during the life of this device instance
    ULONG ResetPipeCount;


} USB_DBGDATA, *PUSB_DBGDATA;

//these declared in debug 'c' file


extern PUSB_DBGDATA gpDbg; 


static const PCHAR szIrpMajFuncDesc[] =
{  // note this depends on corresponding values to the indexes in wdm.h
   "IRP_MJ_CREATE",
   "IRP_MJ_CREATE_NAMED_PIPE",
   "IRP_MJ_CLOSE",
   "IRP_MJ_READ",
   "IRP_MJ_WRITE",
   "IRP_MJ_QUERY_INFORMATION",
   "IRP_MJ_SET_INFORMATION",
   "IRP_MJ_QUERY_EA",
   "IRP_MJ_SET_EA",
   "IRP_MJ_FLUSH_BUFFERS",
   "IRP_MJ_QUERY_VOLUME_INFORMATION",
   "IRP_MJ_SET_VOLUME_INFORMATION",
   "IRP_MJ_DIRECTORY_CONTROL",
   "IRP_MJ_FILE_SYSTEM_CONTROL",
   "IRP_MJ_DEVICE_CONTROL",
   "IRP_MJ_INTERNAL_DEVICE_CONTROL",
   "IRP_MJ_SHUTDOWN",
   "IRP_MJ_LOCK_CONTROL",
   "IRP_MJ_CLEANUP",
   "IRP_MJ_CREATE_MAILSLOT",
   "IRP_MJ_QUERY_SECURITY",
   "IRP_MJ_SET_SECURITY",
   "IRP_MJ_POWER",          
   "IRP_MJ_SYSTEM_CONTROL", 
   "IRP_MJ_DEVICE_CHANGE",  
   "IRP_MJ_QUERY_QUOTA",    
   "IRP_MJ_SET_QUOTA",      
   "IRP_MJ_PNP"            
};
//IRP_MJ_MAXIMUM_FUNCTION defined in wdm.h


static const PCHAR szPnpMnFuncDesc[] =
{    // note this depends on corresponding values to the indexes in wdm.h 

    "IRP_MN_START_DEVICE",
    "IRP_MN_QUERY_REMOVE_DEVICE",
    "IRP_MN_REMOVE_DEVICE",
    "IRP_MN_CANCEL_REMOVE_DEVICE",
    "IRP_MN_STOP_DEVICE",
    "IRP_MN_QUERY_STOP_DEVICE",
    "IRP_MN_CANCEL_STOP_DEVICE",
    "IRP_MN_QUERY_DEVICE_RELATIONS",
    "IRP_MN_QUERY_INTERFACE",
    "IRP_MN_QUERY_CAPABILITIES",
    "IRP_MN_QUERY_RESOURCES",
    "IRP_MN_QUERY_RESOURCE_REQUIREMENTS",
    "IRP_MN_QUERY_DEVICE_TEXT",
    "IRP_MN_FILTER_RESOURCE_REQUIREMENTS",
    "IRP_MN_READ_CONFIG",
    "IRP_MN_WRITE_CONFIG",
    "IRP_MN_EJECT",
    "IRP_MN_SET_LOCK",
    "IRP_MN_QUERY_ID",
    "IRP_MN_QUERY_PNP_DEVICE_STATE",
    "IRP_MN_QUERY_BUS_INFORMATION",
    "IRP_MN_DEVICE_USAGE_NOTIFICATION",
    "IRP_MN_SURPRISE_REMOVAL"
};

#define IRP_PNP_MN_FUNCMAX    IRP_MN_SURPRISE_REMOVAL



static const PCHAR szSystemPowerState[] = 
{
    "PowerSystemUnspecified",
    "PowerSystemWorking",
    "PowerSystemSleeping1",
    "PowerSystemSleeping2",
    "PowerSystemSleeping3",
    "PowerSystemHibernate",
    "PowerSystemShutdown",
    "PowerSystemMaximum"
};

static const PCHAR szDevicePowerState[] = 
{
    "PowerDeviceUnspecified",
    "PowerDeviceD0",
    "PowerDeviceD1",
    "PowerDeviceD2",
    "PowerDeviceD3",
    "PowerDeviceMaximum"
};




BOOLEAN
IrUsb_GetRegistryDword(
    IN      PWCHAR    RegPath,
    IN      PWCHAR    ValueName,
    IN OUT  PULONG    Value
    );

void DBG_PrintBuf(PUCHAR bufptr, int buflen);


#define USB_ASSERT( cond ) ASSERT( cond )

#define USB_StringForDevState( devState )  szDevicePowerState[ devState ] 

#define USB_StringForSysState( sysState )  szSystemPowerState[ sysState ] 

#define USB_StringForPnpMnFunc( mnfunc ) szPnpMnFuncDesc[ mnfunc ]

#define USB_StringForIrpMjFunc(  mjfunc ) szIrpMajFuncDesc[ mjfunc ]



#else // if not DBG

// dummy definitions that go away in the retail build


#define USB_ASSERT( cond )
#define USB_StringForDevState( devState )
#define USB_StringForSysState( sysState ) 
#define USB_StringForPnpMnFunc( mnfunc )
#define USB_StringForIrpMjFunc(  mjfunc ) 


#endif
// End, debug code from Bul kUsb

#ifdef DEBUG

#define DEBUGCOND( ilev, cond, _x_) \
    if( (ilev & DbgSettings) && ( cond )) { \
            DbgPrint( DBGSTR_PREFIX ); \
            DbgPrint _x_ ; \
    }

#define DEBUGONCE( ilev, _x_ ) \
{ \
    static BOOLEAN didOnce = FALSE; \
    if ( !didOnce ) { \
        didOnce = TRUE; \
        DEBUGMSG( ilev, _x_ ); \
    } \
}

#define DUMP_STATS_SEC( pThisDev, NumSec ) DumpStatsEverySec(  pThisDev, NumSec ) 

#define DEBUGONCECOND( ilev, cond, _x_ ) \
{ \
    static BOOLEAN didOnce = FALSE; \
    if (( !didOnce ) && (cond)) { \
        didOnce = TRUE; \
        DEBUGMSG( ilev, _x_ ); \
    } \
}


extern int DbgSettings;

#define DEBUGMSG(dbgs,format) (((dbgs) & DbgSettings)? DbgPrint format:0)


#define USB_DUMP( flag,parms ) ((( flag) & DbgSettings )? DBG_PrintBuf parms: 0 )


    #define DBG_STAT     (1 << 23)
    #define DBG_PNP      (1 << 24)
    #define DBG_TIME     (1 << 25)
    #define DBG_DBG      (1 << 26)
    #define DBG_OUT      (1 << 27)
    #define DBG_BUF      (1 << 28)
    #define DBG_BUFS     (1 << 28)
    #define DBG_FUNCTION (1 << 29)
    #define DBG_FUNC     (1 << 29)
    #define DBG_WARN     (1 << 30)
    #define DBG_WARNING  (1 << 30)
    #define DBG_ERROR    (1 << 31)
    #define DBG_ERR      (1 << 31)



    #define DBGDBG(_dbgPrint)                       \
            DbgPrint(_dbgPrint)

    #ifdef DEBUG_USB

        #define DBG_D(dbgs, i) (((dbgs) & DbgSettings)? DbgPrint("usb:"#i"==%d\n", (i)):0)
        #define DBG_X(dbgs, x) (((dbgs) & DbgSettings)? DbgPrint("usb:"#x"==0x%0*X\n", sizeof(x)*2, ((ULONG_PTR)(x))&((1<<(sizeof(x)*8))-1) ):0)
        #define DBG_UNISTR(dbgs, s) (((dbgs) & DbgSettings)? DbgPrint("usb:"#s"==%wZ\n", (s) ):0))

        #define DBGTIME(_str)                               \
            {                                               \
                LARGE_INTEGER Time;                         \
                                                            \
                NdisGetCurrentSystemTime(&Time);                   \
                DEBUGMSG(DBG_TIME, (_str " %d:%d\n",        \
                                    Time.HighPart,          \
                                    Time.LowPart/10000));   \
            }
    #else // DEBUG_USB

        #define DBGTIME(_str)
        #define DBGFUNC(_dbgPrint)
        #define DBGOUT(_dbgPrint)
        #define DBGERR(_dbgPrint)
        #define DBGWARN(_dbgPrint)
        #define DBGSTAT(_dbgPrint)
        #define DBGTIME(_dbgPrint)
        #define DEBUGMSG(dbgs,format)
        #define DEBUGONCE( ilev, _x_ )
        #define DEBUGCOND( a, b, c )
        #define DEBUGONCECOND( a, b, c )
        #define USB_DUMP(dbgs,format)
        #define DUMP_STATS_SEC( pThisDev, NumSec ) 

    #endif // DEBUG_USB

#else // DEBUG

    #define DBGTIME(_str)
    #define DBGFUNC(_dbgPrint)
    #define DBGDBG(_dbgPrint)
    #define DBGOUT(_dbgPrint)
    #define DBGERR(_dbgPrint)
    #define DBGWARN(_dbgPrint)
    #define DBGSTAT(_dbgPrint)
    #define DEBUGMSG(dbgs,format)
    #define DBG_D(dbgs, ivar)
    #define DBG_X(dbgs, xvar)
    #define DBG_UNISTR(dbgs, svar)
    #define DEBUGONCE( ilev, _x_ )
    #define DEBUGONCECOND( a, b, c )
    #define DEBUGCOND( a, b, c )
    #define USB_DUMP(dbgs,format)
    #define DUMP_STATS_SEC( pThisDev, NumSec ) 

#endif // DEBUG


#ifndef LOGGING
#define LOGGING 0
#endif

#if LOGGING
typedef struct {
    UHALF_PTR Tag;
    UHALF_PTR Line;
    ULONG_PTR  Data[3];
} LOG;

#define NUM_LOG 1024

extern ULONG LogIndex;
extern LOG   Log[NUM_LOG];

#define NextLog()  ((NdisInterlockedIncrement(&LogIndex)-1)&(NUM_LOG-1))
#define LOG_ENTRY(tag, d1, d2, d3)              \
{                                               \
    ULONG ThisLog = NextLog();                  \
    Log[ThisLog].Tag = (tag);                   \
    Log[ThisLog].Line = __LINE__;               \
    Log[ThisLog].Data[0] = (ULONG_PTR)(d1);      \
    Log[ThisLog].Data[1] = (ULONG_PTR)(d2);      \
    Log[ThisLog].Data[2] = (ULONG_PTR)(d3);      \
}
#else
#define LOG_ENTRY(tag, d1, d2, d3)
#endif
// Override DDK definition of ASSERT so that debugger halts in the
// affected code and halts even in the unchecked OS

#if DBG && defined(_X86_)
	#undef ASSERT
	#define ASSERT(e) if(!(e)){DbgPrint("Assertion failure in "\
	__FILE__ ", line %d: " #e "\n", __LINE__);\
	_asm int 1\
  }
#endif


#endif // _DEBUG_H_

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品乱码一区二三区小蝌蚪| 欧美视频三区在线播放| 精品久久久久久久人人人人传媒| 日本不卡不码高清免费观看| 欧美一区二区三区四区高清| 精品一区二区三区在线播放| 久久久久久久久久电影| 成人av动漫在线| 亚洲精品久久嫩草网站秘色| 精品视频免费看| 日韩不卡手机在线v区| 久久综合九色欧美综合狠狠| 成人午夜视频网站| 亚洲国产视频在线| 精品国一区二区三区| eeuss鲁片一区二区三区在线观看| 中文字幕一区二区三区乱码在线| 91成人看片片| 蓝色福利精品导航| 国产精品免费av| 欧美三级欧美一级| 韩国成人精品a∨在线观看| 国产精品不卡视频| 欧美精品123区| 国产suv一区二区三区88区| 亚洲欧美激情在线| 日韩视频123| 99v久久综合狠狠综合久久| 午夜国产不卡在线观看视频| 久久久久久日产精品| 日本高清成人免费播放| 久久精品国产亚洲a| 亚洲同性gay激情无套| 51精品国自产在线| 成人动漫精品一区二区| 美女在线视频一区| 亚洲精品成人在线| 久久免费看少妇高潮| 欧美日韩高清不卡| 成人激情小说乱人伦| 麻豆精品一二三| 亚洲最色的网站| 久久久久久久精| 欧美狂野另类xxxxoooo| 成人99免费视频| 国产一区二区免费看| 婷婷国产在线综合| 亚洲精品成人在线| 中文字幕精品一区二区精品绿巨人| 欧美麻豆精品久久久久久| a级精品国产片在线观看| 久久精品国产第一区二区三区| 亚洲在线视频一区| 中文字幕中文在线不卡住| www国产成人免费观看视频 深夜成人网| 91成人免费网站| 91视频在线看| 99久久精品免费看国产 | 色噜噜狠狠成人网p站| 国内成人自拍视频| 欧美aⅴ一区二区三区视频| 性欧美疯狂xxxxbbbb| 一区二区视频免费在线观看| 国产精品福利在线播放| 亚洲精品一区二区三区影院| 日韩欧美自拍偷拍| 欧美精品高清视频| 欧美日韩日日摸| 色国产精品一区在线观看| 99综合电影在线视频| 成人一区二区三区视频| 国产不卡视频一区二区三区| 国产在线国偷精品产拍免费yy| 蜜桃av一区二区在线观看| 免费在线成人网| 久久99精品一区二区三区三区| 午夜精品影院在线观看| 婷婷久久综合九色国产成人| 日本伊人精品一区二区三区观看方式| 亚洲1区2区3区4区| 日韩一区精品视频| 麻豆91免费观看| 国内精品国产三级国产a久久| 精品一区二区在线视频| 国产一二三精品| 99视频精品免费视频| 一本到高清视频免费精品| 色嗨嗨av一区二区三区| 欧美日韩久久一区二区| 69堂国产成人免费视频| 欧美r级在线观看| 国产欧美精品一区二区色综合| 国产精品美日韩| 亚洲精选视频免费看| 亚洲18色成人| 精品影视av免费| 成人精品免费网站| 91成人在线免费观看| 欧美高清性hdvideosex| 精品久久久久99| 亚洲国产成人一区二区三区| 亚洲美女在线一区| 日韩高清在线一区| 国产成人亚洲精品狼色在线 | 美女视频网站黄色亚洲| 国产精品一区二区三区四区| 99久久伊人网影院| 欧美色图免费看| 久久综合九色综合欧美98| 亚洲欧洲无码一区二区三区| 午夜激情久久久| 国产成人免费视频一区| 在线观看国产精品网站| 精品日韩在线一区| 亚洲精品自拍动漫在线| 麻豆视频一区二区| 91免费观看在线| 欧美v国产在线一区二区三区| 自拍偷拍国产亚洲| 极品少妇xxxx精品少妇偷拍| jvid福利写真一区二区三区| 欧美一区二区三区视频在线 | 一区2区3区在线看| 久久成人免费电影| 日本韩国一区二区三区视频| 久久伊人蜜桃av一区二区| 亚洲高清一区二区三区| 丰满放荡岳乱妇91ww| 91精品国产欧美日韩| 中文字幕字幕中文在线中不卡视频| 日韩电影在线一区二区三区| 不卡的av电影在线观看| 日韩欧美一区二区不卡| 亚洲黄色小说网站| 丁香天五香天堂综合| 日韩亚洲电影在线| 亚洲国产精品天堂| 99精品国产99久久久久久白柏| 精品精品欲导航| 午夜影院久久久| 91视频观看免费| 欧美国产日本视频| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美日韩精品一区视频| 国产精品女人毛片| 国产成人综合亚洲网站| 日韩精品一区二区三区中文不卡| 亚洲小少妇裸体bbw| 99这里只有久久精品视频| 国产亚洲欧美日韩俺去了| 看片的网站亚洲| 91麻豆精品国产自产在线| 亚洲综合一区二区精品导航| 成a人片亚洲日本久久| 国产日韩亚洲欧美综合| 精品一区二区三区视频| 欧美一级片在线观看| 日韩成人精品在线观看| 91精品国产乱| 视频一区视频二区在线观看| 欧美乱熟臀69xxxxxx| 亚洲一区二区在线观看视频 | 欧美日韩中文另类| 一区二区三区在线视频免费观看| eeuss影院一区二区三区| 一区精品在线播放| 91在线观看地址| 一区二区三区丝袜| 在线视频你懂得一区二区三区| 一区二区三区四区在线免费观看| 色综合天天狠狠| 亚洲日本免费电影| 91国内精品野花午夜精品| 一区二区三区蜜桃| 欧美午夜精品免费| 视频在线观看91| 精品久久久久久久久久久久包黑料| 韩国三级中文字幕hd久久精品| 久久综合久久综合九色| 福利一区二区在线| 国产精品第一页第二页第三页| 99国产麻豆精品| 亚洲一区二区三区国产| 91精品婷婷国产综合久久性色 | 中文在线资源观看网站视频免费不卡| 国产成人在线看| 亚洲欧美日韩国产综合在线| 色吊一区二区三区| 日韩综合在线视频| 久久网站最新地址| 成人动漫在线一区| 亚洲成av人片| 久久久久久久久久电影| 色吊一区二区三区| 裸体歌舞表演一区二区| 国产欧美1区2区3区| 欧美在线观看视频一区二区三区| 午夜电影久久久| 国产欧美日韩在线看| 欧美性大战久久久久久久蜜臀|