You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
466 lines
13 KiB
466 lines
13 KiB
/*++
|
|
|
|
Copyright (c) 1992 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
atkerror.h
|
|
|
|
Abstract:
|
|
|
|
This module contains some error definitions for appletalk.
|
|
|
|
Author:
|
|
|
|
Jameel Hyder ([email protected])
|
|
Nikhil Kamkolkar ([email protected])
|
|
|
|
Revision History:
|
|
19 Jun 1992 Initial Version
|
|
|
|
Notes: Tab stop: 4
|
|
--*/
|
|
|
|
#ifndef _ATKERROR_
|
|
#define _ATKERROR_
|
|
|
|
// Define the modules names for Appletalk - use the high bits.
|
|
#define ATKINIT 0x00010000
|
|
#define ATKDRVR 0x00020000
|
|
#define ATKNDIS 0x00030000
|
|
#define ATKTDI 0x00040000
|
|
#define ATKACT 0x00050000
|
|
#define ATKUTILS 0x00060000
|
|
#define ATKTIMER 0x00070000
|
|
#define ATKMEM 0x00080000
|
|
#define ATKERROR 0x00090000
|
|
|
|
#define ROUTER 0x000A0000
|
|
#define SOCKET 0x000B0000
|
|
#define PORTS 0x000C0000
|
|
#define NODE 0x000D0000
|
|
#define AARP 0x000E0000
|
|
#define AEP 0x000F0000
|
|
#define DDP 0x00100000
|
|
#define RTMP 0x00200000
|
|
#define NBP 0x00300000
|
|
#define ZIP 0x00400000
|
|
#define ATP 0x00500000
|
|
#define ASP 0x00600000
|
|
#define PAP 0x00700000
|
|
#define ADSP 0x00800000
|
|
#define ATKIND 0x00900000
|
|
#define ASPC 0x00A00000
|
|
#define DATAX 0x00B00000
|
|
#define RAS 0x00C00000
|
|
#define ARAP 0x00D00000
|
|
#define ARAPNDIS 0x00E00000
|
|
#define ARAPUTIL 0x00F00000
|
|
#define ARAPATK 0x01000000
|
|
#define ARAPDBG 0x02000000
|
|
#define ATKPNP 0x03000000
|
|
#define PPP 0x04000000
|
|
|
|
|
|
// DEBUGGING SUPPORT:
|
|
// Debugging messages are provided per-subsystem defined here, and within
|
|
// the subsystems, there are 4 levels of messages.
|
|
//
|
|
// The four levels of debug messages are:
|
|
//
|
|
// INFO: Informational messages, eg., entry exit in routines
|
|
// WARN: Something went wrong, but its not an error, eg., packet was not ours
|
|
// ERR: Error situations, but we can still run if a retry happens
|
|
// FATAL: In this situation, the driver is not operational
|
|
|
|
// These give the ref/deref dbgprints if DBG is defined. LOTS of output.
|
|
// Defined as a hierarchy of the stack objects.
|
|
#define DBG_LEVEL_REFDDP 0x2000
|
|
#define DBG_LEVEL_REFNODE 0x3000
|
|
#define DBG_LEVEL_REFPORT 0x4000
|
|
#define DBG_LEVEL_REFATP 0x4100
|
|
#define DBG_LEVEL_REFPAPADDR 0x4200
|
|
#define DBG_LEVEL_REFPAPCONN 0x4300
|
|
#define DBG_LEVEL_REFASPADDR 0x4400
|
|
#define DBG_LEVEL_REFASPCONN 0x4500
|
|
|
|
#define DBG_LEVEL_INFO 0x5000
|
|
#define DBG_LEVEL_WARN 0x6000
|
|
#define DBG_LEVEL_ERR 0x7000
|
|
#define DBG_LEVEL_FATAL 0x8000
|
|
|
|
// SUBSYSTEMS
|
|
#define DBG_COMP_INIT 0x00000001
|
|
#define DBG_COMP_DISPATCH 0x00000002
|
|
#define DBG_COMP_CREATE 0x00000004
|
|
#define DBG_COMP_CLOSE 0x00000008
|
|
#define DBG_COMP_ACTION 0x00000010
|
|
#define DBG_COMP_ADDROBJ 0x00000020
|
|
#define DBG_COMP_CONNOBJ 0x00000040
|
|
#define DBG_COMP_CHANOBJ 0x00000080
|
|
#define DBG_COMP_RESOURCES 0x00000100
|
|
#define DBG_COMP_UNLOAD 0x00000200
|
|
|
|
#define DBG_COMP_NODE 0x00000400
|
|
#define DBG_COMP_AARP 0x00000800
|
|
|
|
#define DBG_COMP_AEP 0x00001000
|
|
#define DBG_COMP_DDP 0x00002000
|
|
#define DBG_COMP_ATP 0x00004000
|
|
#define DBG_COMP_ADSP 0x00008000
|
|
#define DBG_COMP_ZIP 0x00010000
|
|
#define DBG_COMP_NBP 0x00020000
|
|
#define DBG_COMP_PAP 0x00040000
|
|
#define DBG_COMP_ASP 0x00080000
|
|
#define DBG_COMP_RTMP 0x00100000
|
|
#define DBG_COMP_ROUTER 0x00200000
|
|
|
|
#define DBG_COMP_DUMP 0x00400000
|
|
#define DBG_COMP_REFCOUNTS 0x00800000
|
|
#define DBG_COMP_SYSTEM 0x01000000
|
|
#define DBG_COMP_CRITSEC 0x02000000
|
|
#define DBG_COMP_UTILS 0x04000000
|
|
|
|
#define DBG_COMP_NDISSEND 0x08000000
|
|
#define DBG_COMP_NDISRECV 0x10000000
|
|
#define DBG_COMP_NDISREQ 0x20000000
|
|
#define DBG_COMP_TDI 0x40000000
|
|
#define DBG_COMP_RAS 0x80000000
|
|
|
|
#define DBG_MOST (DBG_COMP_INIT | \
|
|
DBG_COMP_DISPATCH | \
|
|
DBG_COMP_CREATE | \
|
|
DBG_COMP_CLOSE | \
|
|
DBG_COMP_ACTION | \
|
|
DBG_COMP_ADDROBJ | \
|
|
DBG_COMP_CONNOBJ | \
|
|
DBG_COMP_CHANOBJ | \
|
|
DBG_COMP_RESOURCES | \
|
|
DBG_COMP_UNLOAD | \
|
|
DBG_COMP_NODE | \
|
|
DBG_COMP_AARP | \
|
|
DBG_COMP_AEP | \
|
|
DBG_COMP_DDP | \
|
|
DBG_COMP_ATP | \
|
|
DBG_COMP_ADSP | \
|
|
DBG_COMP_ZIP | \
|
|
DBG_COMP_NBP | \
|
|
DBG_COMP_PAP | \
|
|
DBG_COMP_ASP | \
|
|
DBG_COMP_RTMP | \
|
|
DBG_COMP_ROUTER | \
|
|
DBG_COMP_DUMP | \
|
|
DBG_COMP_UTILS | \
|
|
DBG_COMP_REFCOUNTS | \
|
|
DBG_COMP_SYSTEM | \
|
|
DBG_COMP_TDI | \
|
|
DBG_COMP_RAS)
|
|
|
|
// past here are debug things that are really frequent; don't use them
|
|
// unless you want LOTS of output
|
|
|
|
|
|
#define DBG_ALL (DBG_MOST | DBG_COMP_CRITSEC)
|
|
|
|
|
|
// More debugging support. These values define the dumping components.
|
|
// There are a max of 32 such components that can be defined. Each of
|
|
// these are associated with a dump routine. It one is specified and
|
|
// enabled, periodically it is called. It is upto that component to
|
|
// decide what it wants to do
|
|
|
|
#define DBG_DUMP_DEF_INTERVAL 300 // In 100ms units
|
|
|
|
#define DBG_DUMP_PORTINFO 0x00000001
|
|
#define DBG_DUMP_AMT 0x00000002
|
|
#define DBG_DUMP_ZONETABLE 0x00000004
|
|
#define DBG_DUMP_RTES 0x00000008
|
|
#define DBG_DUMP_TIMERS 0x00000010
|
|
#define DBG_DUMP_ATPINFO 0x00000020
|
|
#define DBG_DUMP_ASPSESSIONS 0x00000040
|
|
#define DBG_DUMP_PAPJOBS 0x00000080
|
|
|
|
typedef LONG ATALK_ERROR, *PATALK_ERROR;
|
|
|
|
#define ATALK_SUCCESS(error) ((ATALK_ERROR)(error) >= 0)
|
|
|
|
#define ATALK_NO_ERROR 0x00000000
|
|
#define ATALK_PENDING 0x00000001
|
|
|
|
#define ATALK_RESR_MEM -1000
|
|
|
|
#define ATALK_INVALID_PARAMETER -1050
|
|
#define ATALK_BUFFER_TOO_SMALL -1051
|
|
#define ATALK_BUFFER_TOO_BIG -1052
|
|
#define ATALK_ALREADY_ASSOCIATED -1053
|
|
#define ATALK_CANNOT_DISSOCIATE -1054
|
|
#define ATALK_CANNOT_CANCEL -1055
|
|
#define ATALK_INVALID_REQUEST -1056
|
|
#define ATALK_REQUEST_NOT_ACCEPTED -1057
|
|
#define ATALK_DEVICE_NOT_READY -1058
|
|
#define ATALK_INVALID_CONNECTION -1059
|
|
#define ATALK_INVALID_ADDRESS -1060
|
|
#define ATALK_TOO_MANY_COMMANDS -1061
|
|
#define ATALK_CONNECTION_TIMEOUT -1062
|
|
#define ATALK_REMOTE_CLOSE -1063
|
|
#define ATALK_LOCAL_CLOSE -1064
|
|
#define ATALK_BUFFER_INVALID_SIZE -1065
|
|
#define ATALK_REQUEST_CANCELLED -1066
|
|
#define ATALK_NEW_SOCKET -1067
|
|
#define ATALK_TIMEOUT -1068
|
|
#define ATALK_SHARING_VIOLATION -1069
|
|
#define ATALK_INVALID_PKT -1070
|
|
#define ATALK_DUP_PKT -1071
|
|
|
|
#define ATALK_INIT_BINDFAIL -1100
|
|
#define ATALK_INIT_REGPROTO_FAIL -1101
|
|
#define ATALK_INIT_MEDIA_INVALID -1102
|
|
|
|
#define ATALK_PORT_INVALID -1200
|
|
#define ATALK_PORT_CLOSING -1201
|
|
|
|
#define ATALK_NODE_FINDING -1300
|
|
#define ATALK_NODE_NONEXISTENT -1301
|
|
#define ATALK_NODE_CLOSING -1302
|
|
#define ATALK_NODE_NOMORE -1303
|
|
|
|
#define ATALK_SOCKET_INVALID -1400
|
|
#define ATALK_SOCKET_NODEFULL -1401
|
|
#define ATALK_SOCKET_EXISTS -1402
|
|
#define ATALK_SOCKET_CLOSED -1403
|
|
|
|
#define ATALK_DDP_CLOSING -1500
|
|
#define ATALK_DDP_NOTFOUND -1501
|
|
#define ATALK_DDP_INVALID_LEN -1502
|
|
#define ATALK_DDP_SHORT_HDR -1503
|
|
#define ATALK_DDP_INVALID_SRC -1504
|
|
#define ATALK_DDP_INVALID_DEST -1505
|
|
#define ATALK_DDP_INVALID_ADDR -1506
|
|
#define ATALK_DDP_INVALID_PROTO -1507
|
|
#define ATALK_DDP_INVALID_PARAM -1508
|
|
#define ATALK_DDP_NO_ROUTER -1509
|
|
#define ATALK_DDP_NO_AMT_ENTRY -1510
|
|
#define ATALK_DDP_NO_BRC_ENTRY -1511
|
|
#define ATALK_DDP_PKT_DROPPED -1512
|
|
|
|
#define ATALK_ATP_NOT_FOUND -1600
|
|
#define ATALK_ATP_INVALID_PKT -1601
|
|
#define ATALK_ATP_INVALID_REQ -1602
|
|
#define ATALK_ATP_REQ_CLOSING -1603
|
|
#define ATALK_ATP_RESP_CLOSING -1604
|
|
#define ATALK_ATP_INVALID_RETRYCNT -1605
|
|
#define ATALK_ATP_INVALID_TIMERVAL -1606
|
|
#define ATALK_ATP_INVALID_RELINT -1607
|
|
#define ATALK_ATP_CLOSING -1608
|
|
#define ATALK_ATP_RESP_TOOMANY -1609
|
|
#define ATALK_ATP_NO_MATCH_REQ -1610
|
|
#define ATALK_ATP_NO_GET_REQ -1611
|
|
#define ATALK_ATP_RESP_TIMEOUT -1612
|
|
#define ATALK_ATP_RESP_CANCELLED -1613
|
|
#define ATALK_ATP_REQ_CANCELLED -1614
|
|
#define ATALK_ATP_GET_REQ_CANCELLED -1615
|
|
#define ATALK_ATP_NO_VALID_RESP -1616
|
|
#define ATALK_ATP_REQ_TIMEOUT -1617
|
|
|
|
#define ATALK_ASP_INVALID_REQUEST -1700
|
|
|
|
#define ATALK_PAP_LOCAL_CLOSE -1800
|
|
#define ATALK_PAP_REMOTE_CLOSE -1801
|
|
#define ATALK_PAP_INVALID_REQUEST -1802
|
|
#define ATALK_PAP_TOO_MANY_READS -1803
|
|
#define ATALK_PAP_TOO_MANY_WRITES -1804
|
|
#define ATALK_PAP_CONN_NOT_ACTIVE -1805
|
|
#define ATALK_PAP_ADDR_CLOSING -1806
|
|
#define ATALK_PAP_CONN_CLOSING -1807
|
|
#define ATALK_PAP_CONN_NOT_FOUND -1808
|
|
#define ATALK_PAP_INVALID_USERBYTES -1809
|
|
#define ATALK_PAP_SERVER_BUSY -1810
|
|
#define ATALK_PAP_INVALID_STATUS -1811
|
|
#define ATALK_PAP_PARTIAL_RECEIVE -1812
|
|
#define ATALK_PAP_CONN_RESET -1813
|
|
|
|
#define ATALK_ADSP_INVALID_REQUEST -1900
|
|
#define ATALK_ADSP_CONN_NOT_ACTIVE -1903
|
|
#define ATALK_ADSP_ADDR_CLOSING -1904
|
|
#define ATALK_ADSP_CONN_CLOSING -1905
|
|
#define ATALK_ADSP_CONN_NOT_FOUND -1906
|
|
#define ATALK_ADSP_CONN_RESET -1907
|
|
#define ATALK_ADSP_SERVER_BUSY -1908
|
|
|
|
#define ATALK_ADSP_PARTIAL_RECEIVE -1912
|
|
#define ATALK_ADSP_EXPED_RECEIVE -1913
|
|
#define ATALK_ADSP_PAREXPED_RECEIVE -1914
|
|
#define ATALK_ADSP_REMOTE_RESR -1915
|
|
|
|
#define ATALK_TIMER_CANCEL_FAIL -2000
|
|
#define ATALK_TIMER_SCHEDULE_FAIL -2001
|
|
|
|
#define ATALK_ASPC_LOCAL_CLOSE -2100
|
|
#define ATALK_ASPC_REMOTE_CLOSE -2101
|
|
#define ATALK_ASPC_INVALID_REQUEST -2102
|
|
#define ATALK_ASPC_TOO_MANY_READS -2103
|
|
#define ATALK_ASPC_TOO_MANY_WRITES -2104
|
|
#define ATALK_ASPC_CONN_NOT_ACTIVE -2105
|
|
#define ATALK_ASPC_ADDR_CLOSING -2106
|
|
#define ATALK_ASPC_CONN_CLOSING -2107
|
|
#define ATALK_ASPC_CONN_NOT_FOUND -2108
|
|
#define ATALK_ASPC_INVALID_USERBYTES -2109
|
|
#define ATALK_ASPC_SERVER_BUSY -2110
|
|
#define ATALK_ASPC_INVALID_STATUS -2111
|
|
#define ATALK_ASPC_PARTIAL_RECEIVE -2112
|
|
#define ATALK_ASPC_CONN_RESET -2113
|
|
|
|
#define ATALK_FAILURE -5000
|
|
|
|
// This defines the number of times an error has to happen consecutively before
|
|
// it gets logged again.
|
|
#define ERROR_CONSEQ_FREQ 200
|
|
#define ERROR_CONSEQ_TIME 18000 // 30 minutes in 100ns intervals
|
|
|
|
|
|
#if DBG
|
|
extern ULONG AtalkDebugDump;
|
|
extern LONG AtalkDumpInterval;
|
|
extern ULONG AtalkDebugLevel;
|
|
extern ULONG AtalkDebugSystems;
|
|
extern TIMERLIST AtalkDumpTimerList;
|
|
typedef VOID (*DUMP_ROUTINE)(VOID);
|
|
|
|
extern
|
|
LONG FASTCALL
|
|
AtalkDumpComponents(
|
|
IN PTIMERLIST Context,
|
|
IN BOOLEAN TimerShuttingDown
|
|
);
|
|
|
|
extern
|
|
VOID
|
|
AtalkAmtDumpTable(
|
|
VOID
|
|
);
|
|
|
|
extern
|
|
VOID
|
|
AtalkPortDumpInfo(
|
|
VOID
|
|
);
|
|
|
|
extern
|
|
VOID
|
|
AtalkRtmpDumpTable(
|
|
VOID
|
|
);
|
|
|
|
extern
|
|
VOID
|
|
AtalkTimerDumpList(
|
|
VOID
|
|
);
|
|
|
|
extern
|
|
VOID
|
|
AtalkZoneDumpTable(
|
|
VOID
|
|
);
|
|
|
|
extern
|
|
VOID
|
|
AtalkAspDumpSessions(
|
|
VOID
|
|
);
|
|
|
|
#endif
|
|
|
|
|
|
#define LOG_ERROR(AtalkError, NtStatus, RawData, RawDataLen) \
|
|
LOG_ERRORONPORT(NULL, AtalkError, NtStatus, RawData, RawDataLen)
|
|
|
|
#define RES_LOG_ERROR() \
|
|
LOG_ERROR(EVENT_ATALK_RESOURCES, STATUS_INSUFFICIENT_RESOURCES, NULL, 0)
|
|
|
|
#define LOG_ERRORONPORT(Port, AtalkError, NtStatus, RawData, RawDataLen) \
|
|
{ \
|
|
if (!NT_SUCCESS(NtStatus)) \
|
|
{ \
|
|
DBGPRINT(DBG_ALL, DBG_LEVEL_ERR, \
|
|
("LOG_ERROR: File %s Line %ld Event %lx Error %lx\n", \
|
|
__FILE__, __LINE__, AtalkError, NtStatus)); \
|
|
} \
|
|
AtalkWriteErrorLogEntry(Port, \
|
|
AtalkError, \
|
|
(__LINE__ | FILENUM), \
|
|
NtStatus, \
|
|
RawData, \
|
|
RawDataLen); \
|
|
}
|
|
|
|
#if DBG
|
|
// ERROR and above ignore the Component part
|
|
#define DBGPRINT(Component, Level, Fmt) \
|
|
{ \
|
|
if ((Level >= AtalkDebugLevel) && \
|
|
((AtalkDebugSystems & Component) == Component)) \
|
|
{ \
|
|
DbgPrint("***ATALK*** "); \
|
|
DbgPrint Fmt; \
|
|
} \
|
|
}
|
|
|
|
#define DBGPRINTSKIPHDR(Component, Level, Fmt) \
|
|
{ \
|
|
if ((Level >= AtalkDebugLevel) && \
|
|
((AtalkDebugSystems & Component) == Component)) \
|
|
{ \
|
|
DbgPrint Fmt; \
|
|
} \
|
|
}
|
|
|
|
#define DBGBRK(Level) \
|
|
{ \
|
|
if (Level >= AtalkDebugLevel) \
|
|
DbgBreakPoint(); \
|
|
}
|
|
|
|
#define TMPLOGERR() DBGPRINT(DBG_MOST, DBG_LEVEL_ERR, \
|
|
("TempErrLog: %s, Line %ld\n", \
|
|
__FILE__, __LINE__));
|
|
|
|
#else
|
|
#define DBGPRINTSKIPHDR(Component, Level, Fmt)
|
|
#define DBGPRINT(Component, Level, Fmt)
|
|
#define DBGBRK(Level)
|
|
#define TMPLOGERR()
|
|
#endif
|
|
|
|
extern
|
|
VOID
|
|
AtalkWriteErrorLogEntry(
|
|
IN struct _PORT_DESCRIPTOR * pPortDesc,
|
|
IN NTSTATUS UniqueErrorCode,
|
|
IN ULONG UniqueErrorValue,
|
|
IN NTSTATUS NtStatusCode,
|
|
IN PVOID RawDataBuf OPTIONAL,
|
|
IN LONG RawDataLen);
|
|
|
|
extern
|
|
VOID
|
|
AtalkLogBadPacket(
|
|
IN struct _PORT_DESCRIPTOR * pPortDesc,
|
|
IN PATALK_ADDR pSrcAddr,
|
|
IN PATALK_ADDR pDstAddr OPTIONAL,
|
|
IN PBYTE pPkt,
|
|
IN USHORT PktLen);
|
|
|
|
extern
|
|
ATALK_ERROR FASTCALL
|
|
AtalkNdisToAtalkError(
|
|
IN NDIS_STATUS Error);
|
|
|
|
extern
|
|
NTSTATUS FASTCALL
|
|
AtalkErrorToNtStatus(
|
|
IN ATALK_ERROR AtalkError);
|
|
|
|
#endif // _ATKERROR_
|
|
|
|
|