185 lines
6.4 KiB
C
185 lines
6.4 KiB
C
|
/*++
|
||
|
|
||
|
Copyright (c) 1993 Microsoft Corporation
|
||
|
|
||
|
Module Name:
|
||
|
|
||
|
vwdebug.h
|
||
|
|
||
|
Abstract:
|
||
|
|
||
|
Prototypes, structures, manifests, macros for VWIPXSPX debug routines
|
||
|
|
||
|
Author:
|
||
|
|
||
|
Richard L Firth (rfirth) 5-Oct-1993
|
||
|
|
||
|
Revision History:
|
||
|
|
||
|
5-Oct-1993 rfirth
|
||
|
Created
|
||
|
|
||
|
--*/
|
||
|
|
||
|
#ifndef _VWDEBUG_H_
|
||
|
#define _VWDEBUG_H_
|
||
|
|
||
|
//
|
||
|
// debug flags
|
||
|
//
|
||
|
|
||
|
#define DEBUG_ANY 0xFFFFFFFF // any debug flags set
|
||
|
#define DEBUG_NOTHING 0x00000001 // no debug output
|
||
|
#define DEBUG_CHECK_INT 0x00080000 // check interrupts (DOS)
|
||
|
#define DEBUG_STATS 0x00100000 // dump connection stats
|
||
|
#define DEBUG_DATA 0x00200000 // dump data (send)
|
||
|
#define DEBUG_FRAGMENTS 0x00400000 // dump fragments
|
||
|
#define DEBUG_HEADERS 0x00800000 // dump IPX/SPX headers
|
||
|
#define DEBUG_ECB 0x01000000 // dump 16-bit ECBs
|
||
|
#define DEBUG_XECB 0x02000000 // dump 32-bit XECBs
|
||
|
#define DEBUG_SOCKINFO 0x04000000 // dump SOCKET_INFO structs
|
||
|
#define DEBUG_CONNINFO 0x08000000 // dump CONNECTION_INFO structs
|
||
|
#define DEBUG_DLL 0x10000000 // include DLL attach/detach info
|
||
|
#define DEBUG_FLUSH 0x20000000 // flush every write
|
||
|
#define DEBUG_TO_FILE 0x40000000 // write debug stuff to file
|
||
|
#define DEBUG_TO_DBG 0x80000000 // debug stuff to debugger
|
||
|
|
||
|
#define VWDEBUG_FILE "VWDEBUG.LOG"
|
||
|
|
||
|
//
|
||
|
// function designators
|
||
|
//
|
||
|
|
||
|
#define FUNCTION_ANY 0xFFFFFFFF
|
||
|
#define FUNCTION_IPXOpenSocket 0x00000001 // 0x00
|
||
|
#define FUNCTION_IPXCloseSocket 0x00000002 // 0x01
|
||
|
#define FUNCTION_IPXGetLocalTarget 0x00000004 // 0x02
|
||
|
#define FUNCTION_IPXSendPacket 0x00000008 // 0x03
|
||
|
#define FUNCTION_IPXListenForPacket 0x00000010 // 0x04
|
||
|
#define FUNCTION_IPXScheduleIPXEvent 0x00000020 // 0x05
|
||
|
#define FUNCTION_IPXCancelEvent 0x00000040 // 0x06
|
||
|
#define FUNCTION_IPXScheduleAESEvent 0x00000080 // 0x07
|
||
|
#define FUNCTION_IPXGetIntervalMarker 0x00000100 // 0x08
|
||
|
#define FUNCTION_IPXGetInternetworkAddress 0x00000200 // 0x09
|
||
|
#define FUNCTION_IPXRelinquishControl 0x00000400 // 0x0A
|
||
|
#define FUNCTION_IPXDisconnectFromTarget 0x00000800 // 0x0B
|
||
|
#define FUNCTION_InvalidFunction_0C 0x00001000 // 0x0C
|
||
|
#define FUNCTION_InvalidFunction_0D 0x00002000 // 0x0D
|
||
|
#define FUNCTION_InvalidFunction_0E 0x00004000 // 0x0E
|
||
|
#define FUNCTION_InvalidFunction_0F 0x00008000 // 0x0F
|
||
|
#define FUNCTION_SPXInitialize 0x00010000 // 0x10
|
||
|
#define FUNCTION_SPXEstablishConnection 0x00020000 // 0x11
|
||
|
#define FUNCTION_SPXListenForConnection 0x00040000 // 0x12
|
||
|
#define FUNCTION_SPXTerminateConnection 0x00080000 // 0x13
|
||
|
#define FUNCTION_SPXAbortConnection 0x00100000 // 0x14
|
||
|
#define FUNCTION_SPXGetConnectionStatus 0x00200000 // 0x15
|
||
|
#define FUNCTION_SPXSendSequencedPacket 0x00400000 // 0x16
|
||
|
#define FUNCTION_SPXListenForSequencedPacket 0x00800000 // 0x17
|
||
|
#define FUNCTION_InvalidFunction_18 0x01000000 // 0x18
|
||
|
#define FUNCTION_InvalidFunction_19 0x02000000 // 0x19
|
||
|
#define FUNCTION_IPXGetMaxPacketSize 0x04000000 // 0x1A
|
||
|
#define FUNCTION_InvalidFunction_1B 0x08000000 // 0x1B
|
||
|
#define FUNCTION_InvalidFunction_1C 0x10000000 // 0x1C
|
||
|
#define FUNCTION_InvalidFunction_1D 0x20000000 // 0x1D
|
||
|
#define FUNCTION_InvalidFunction_1E 0x40000000 // 0x1E
|
||
|
#define FUNCTION_IPXGetInformation 0x80000000 // 0x1F
|
||
|
#define FUNCTION_IPXSendWithChecksum 0xFFFFFFFF // 0x20
|
||
|
#define FUNCTION_IPXGenerateChecksum 0xFFFFFFFF // 0x21
|
||
|
#define FUNCTION_IPXVerifyChecksum 0xFFFFFFFF // 0x22
|
||
|
|
||
|
//
|
||
|
// debug levels
|
||
|
//
|
||
|
|
||
|
#define IPXDBG_LEVEL_ALL 0
|
||
|
#define IPXDBG_LEVEL_INFO 1
|
||
|
#define IPXDBG_LEVEL_WARNING 2
|
||
|
#define IPXDBG_LEVEL_ERROR 3
|
||
|
#define IPXDBG_LEVEL_FATAL 4
|
||
|
|
||
|
#define IPXDBG_MIN_LEVEL IPXDBG_LEVEL_ALL
|
||
|
#define IPXDBG_MAX_LEVEL IPXDBG_LEVEL_FATAL
|
||
|
|
||
|
//
|
||
|
// info dump flags (VWDUMP)
|
||
|
//
|
||
|
|
||
|
#define DUMP_ECB_IN 0x00000001
|
||
|
#define DUMP_ECB_OUT 0x00000002
|
||
|
#define DUMP_SEND_DATA 0x00000004
|
||
|
#define DUMP_RECEIVE_DATA 0x00000008
|
||
|
|
||
|
//
|
||
|
// show flags
|
||
|
//
|
||
|
|
||
|
#define SHOW_ECBS 0x00000001 // show ECBs vs. raw data
|
||
|
#define SHOW_HEADERS 0x00000002 // show IPX/SPX headers vs. raw data
|
||
|
|
||
|
#if DBG
|
||
|
|
||
|
extern DWORD VwDebugFlags;
|
||
|
extern DWORD VwDebugFunctions;
|
||
|
extern DWORD VwShow;
|
||
|
extern DWORD DebugFlagsEx;
|
||
|
|
||
|
|
||
|
#define IF_DEBUG(f) if (VwDebugFlags & DEBUG_ ## f)
|
||
|
#define IF_NOT_DEBUG(f) if (!(VwDebugFlags & DEBUG_ ## f))
|
||
|
#define IF_SHOW(f) if (VwShow & SHOW_ ## f)
|
||
|
#define IF_NOT_SHOW(f) if (!(VwShow & SHOW_ ## f))
|
||
|
#define PRIVATE
|
||
|
#define IPXDBGPRINT(x) VwDebugPrint x
|
||
|
#define IPXDBGSTART() VwDebugStart()
|
||
|
#define IPXDBGEND() VwDebugEnd()
|
||
|
#define VWASSERT(a, b) ASSERT((a) == (b))
|
||
|
#define IPXDUMPDATA(x) VwDumpData x
|
||
|
#define IPXDUMPECB(x) VwDumpEcb x
|
||
|
#define DUMPXECB(x) VwDumpXecb(x)
|
||
|
#define DUMPCONN(x) VwDumpConnectionInfo(x)
|
||
|
#define DUMPSTATS(x) VwDumpConnectionStats(x)
|
||
|
#define CHECK_INTERRUPTS(s) CheckInterrupts(s)
|
||
|
#define DUMPALL() VwDumpAll()
|
||
|
|
||
|
#else
|
||
|
|
||
|
#define IF_DEBUG(f) if (0)
|
||
|
#define IF_NOT_DEBUG(f) if (0)
|
||
|
#define IF_SHOW(f) if (0)
|
||
|
#define IF_NOT_SHOW(f) if (0)
|
||
|
#define PRIVATE static
|
||
|
#define IPXDBGPRINT(x)
|
||
|
#define IPXDBGSTART()
|
||
|
#define IPXDBGEND()
|
||
|
#define VWASSERT(a, b) a
|
||
|
#define IPXDUMPDATA(x)
|
||
|
#define IPXDUMPECB(x)
|
||
|
#define DUMPXECB(x)
|
||
|
#define DUMPCONN(x)
|
||
|
#define DUMPSTATS(x)
|
||
|
#define CHECK_INTERRUPTS(s)
|
||
|
#define DUMPALL()
|
||
|
|
||
|
#endif
|
||
|
|
||
|
//
|
||
|
// debug function prototypes
|
||
|
//
|
||
|
|
||
|
extern VOID VwDebugStart(VOID);
|
||
|
extern VOID VwDebugEnd(VOID);
|
||
|
extern VOID VwDebugPrint(LPSTR, DWORD, DWORD, DWORD, LPSTR, ...);
|
||
|
extern VOID VwDumpData(ULPBYTE, WORD, WORD, BOOL, WORD);
|
||
|
extern VOID VwDumpEcb(LPECB, WORD, WORD, BYTE, BOOL, BOOL, BOOL);
|
||
|
extern VOID VwDumpFragment(WORD, LPFRAGMENT, BYTE, BOOL, BOOL);
|
||
|
extern VOID VwDumpPacketHeader(ULPBYTE, BYTE);
|
||
|
extern VOID VwDumpXecb(LPXECB);
|
||
|
extern VOID VwDumpSocketInfo(LPSOCKET_INFO);
|
||
|
extern VOID VwDumpConnectionInfo(LPCONNECTION_INFO);
|
||
|
extern VOID VwDumpConnectionStats(LPSPX_CONNECTION_STATS);
|
||
|
extern VOID VwLog(LPSTR);
|
||
|
extern VOID CheckInterrupts(LPSTR);
|
||
|
extern VOID VwDumpAll(VOID);
|
||
|
|
||
|
#endif // _VWDEBUG_H_
|