00001
00010 #ifndef DBG_KERNELMODE
00011
00012 #define DBG_USERMODE
00013 #endif // #ifndef DBG_KERNELMODE
00014
00015 #include "debug.h"
00016
00017 #if DBG
00018
00019 #include <stdarg.h>
00020 #include <stdio.h>
00021
00022
00023
00027 unsigned char DbgBuffer[DBG_MAX_BUFFER][DBG_MAX_BUFFERLEN];
00028
00030 int DbgBufferPos[DBG_MAX_BUFFER];
00031
00033 unsigned long DbgFlags = 0
00034
00035
00036
00037
00038
00039
00040 #ifdef DBG_KERNELMODE
00041
00042
00043 | DBGF_ASSERTIRQL
00044
00045 | DBGF_THREAD
00046
00047
00048
00049 | DBGF_DBGMEMBUF
00050 | DBGF_DBGPRINT
00051
00052 #endif // #ifdef DBG_KERNELMODE
00053
00054
00055
00056
00057 | DBGF_ASSERT
00058 ;
00059
00060 #ifdef DBG_KERNELMODE
00061
00065 LONG DebugBufferCounter;
00066
00070 LONG DebugBufferUsed[DBG_MAX_BUFFER];
00071
00072 #endif // #ifdef DBG_KERNELMODE
00073
00074
00091 void
00092 DbgOutputIntoBuffer(unsigned long BufferNumber, const char * const Format, ...)
00093 {
00094 va_list arg_ptr;
00095
00096
00097
00098 char *buffer = &DbgBuffer[BufferNumber][DbgBufferPos[BufferNumber]];
00099
00100 va_start(arg_ptr, Format);
00101
00102
00103
00104 if ((DBG_MAX_BUFFERLEN - DbgBufferPos[BufferNumber] - 1) > 0)
00105 {
00106 int n;
00107
00108
00109
00110 n = _vsnprintf(buffer, DBG_MAX_BUFFERLEN - DbgBufferPos[BufferNumber] - 1,
00111 Format, arg_ptr);
00112
00113
00114
00115
00116
00117 if (n<0)
00118 {
00119 n = DBG_MAX_BUFFERLEN - DbgBufferPos[BufferNumber] - 1;
00120 }
00121
00122
00123
00124 DbgBufferPos[BufferNumber] += n;
00125
00126
00127
00128 DbgBuffer[BufferNumber][DbgBufferPos[BufferNumber]] = 0;
00129 }
00130 va_end(arg_ptr);
00131 }
00132
00133 #endif // #if DBG