2000-02-03 04:47:50 +00:00
/*
2002-01-30 06:08:46 +00:00
Unix SMB / CIFS implementation .
2000-02-03 04:47:50 +00:00
SMB debug stuff
Copyright ( C ) Andrew Tridgell 1992 - 1998
Copyright ( C ) John H Terpstra 1996 - 1998
Copyright ( C ) Luke Kenneth Casson Leighton 1996 - 1998
Copyright ( C ) Paul Ashton 1998
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-09 19:25:36 +00:00
the Free Software Foundation ; either version 3 of the License , or
2000-02-03 04:47:50 +00:00
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2000-02-03 04:47:50 +00:00
*/
# ifndef _DEBUG_H
# define _DEBUG_H
/* -------------------------------------------------------------------------- **
* Debugging code . See also debug . c
*/
/* mkproto.awk has trouble with ifdef'd function definitions (it ignores
* the # ifdef directive and will read both definitions , thus creating two
* diffferent prototype declarations ) , so we must do these by hand .
*/
/* I know the __attribute__ stuff is ugly, but it does ensure we get the
2004-07-03 22:48:26 +00:00
arguments to DEBUG ( ) right . We have got them wrong too often in the
2000-02-03 04:47:50 +00:00
past .
2004-02-09 00:59:22 +00:00
The PRINTFLIKE comment does the equivalent for SGI MIPSPro .
2000-02-03 04:47:50 +00:00
*/
2004-02-09 00:59:22 +00:00
/* PRINTFLIKE1 */
2002-11-15 14:06:35 +00:00
int Debug1 ( const char * , . . . ) PRINTF_ATTRIBUTE ( 1 , 2 ) ;
2004-02-09 00:59:22 +00:00
/* PRINTFLIKE1 */
2007-10-18 17:40:25 -07:00
bool dbgtext ( const char * , . . . ) PRINTF_ATTRIBUTE ( 1 , 2 ) ;
2008-10-11 20:44:19 +02:00
bool dbghdrclass ( int level , int cls , const char * location , const char * func ) ;
bool dbghdr ( int level , const char * location , const char * func ) ;
2000-02-03 04:47:50 +00:00
2006-01-15 23:09:17 +00:00
# if defined(sgi) && (_COMPILER_VERSION >= 730)
# pragma mips_frequency_hint NEVER Debug1
# pragma mips_frequency_hint NEVER dbgtext
2008-10-11 20:44:19 +02:00
# pragma mips_frequency_hint NEVER dbghdrclass
2006-01-15 23:09:17 +00:00
# pragma mips_frequency_hint NEVER dbghdr
# endif
2001-09-10 12:14:18 +00:00
extern XFILE * dbf ;
2000-02-03 04:47:50 +00:00
/* If we have these macros, we can add additional info to the header. */
# ifdef HAVE_FUNCTION_MACRO
# define FUNCTION_MACRO (__FUNCTION__)
# else
# define FUNCTION_MACRO ("")
# endif
2001-02-12 16:18:02 +00:00
/*
* Redefine DEBUGLEVEL because so we don ' t have to change every source file
* that * unnecessarily * references it . Source files neeed not extern reference
* DEBUGLEVEL , as it ' s extern in includes . h ( which all source files include ) .
* Eventually , all these references should be removed , and all references to
* DEBUGLEVEL should be references to DEBUGLEVEL_CLASS [ DBGC_ALL ] . This could
* still be through a macro still called DEBUGLEVEL . This cannot be done now
* because some references would expand incorrectly .
*/
# define DEBUGLEVEL *debug_level
2002-07-15 10:35:28 +00:00
extern int DEBUGLEVEL ;
2001-02-12 16:18:02 +00:00
/*
* Define all new debug classes here . A class is represented by an entry in
* the DEBUGLEVEL_CLASS array . Index zero of this arrray is equivalent to the
* old DEBUGLEVEL . Any source file that does NOT add the following lines :
*
* # undef DBGC_CLASS
* # define DBGC_CLASS DBGC_ < your class name here >
*
* at the start of the file ( after # include " includes.h " ) will default to
* using index zero , so it will behaive just like it always has .
*/
2002-07-15 10:35:28 +00:00
# define DBGC_ALL 0 /* index equivalent to DEBUGLEVEL */
# define DBGC_TDB 1
# define DBGC_PRINTDRIVERS 2
# define DBGC_LANMAN 3
# define DBGC_SMB 4
# define DBGC_RPC_PARSE 5
# define DBGC_RPC_SRV 6
# define DBGC_RPC_CLI 7
# define DBGC_PASSDB 8
2002-09-25 15:19:00 +00:00
# define DBGC_SAM 9
# define DBGC_AUTH 10
# define DBGC_WINBIND 11
# define DBGC_VFS 12
2003-05-12 18:12:31 +00:00
# define DBGC_IDMAP 13
2004-01-15 08:49:30 +00:00
# define DBGC_QUOTA 14
2004-04-30 14:28:38 +00:00
# define DBGC_ACLS 15
2005-07-13 14:44:12 +00:00
# define DBGC_LOCKING 16
# define DBGC_MSDFS 17
2006-03-22 23:49:09 +00:00
# define DBGC_DMAPI 18
2007-09-28 23:03:08 +00:00
# define DBGC_REGISTRY 19
2002-07-15 10:35:28 +00:00
/* So you can define DBGC_CLASS before including debug.h */
# ifndef DBGC_CLASS
2001-02-12 16:18:02 +00:00
# define DBGC_CLASS 0 /* override as shown above */
2002-07-15 10:35:28 +00:00
# endif
2001-02-12 16:18:02 +00:00
2002-07-15 10:35:28 +00:00
extern int * DEBUGLEVEL_CLASS ;
2007-10-18 17:40:25 -07:00
extern bool * DEBUGLEVEL_CLASS_ISSET ;
2001-02-12 16:18:02 +00:00
/* Debugging macros
*
* DEBUGLVL ( )
* If the ' file specific ' debug class level > = level OR the system - wide
* DEBUGLEVEL ( synomym for DEBUGLEVEL_CLASS [ DBGC_ALL ] ) > = level then
* generate a header using the default macros for file , line , and
* function name . Returns True if the debug level was < = DEBUGLEVEL .
*
* Example : if ( DEBUGLVL ( 2 ) ) dbgtext ( " Some text. \n " ) ;
*
* DEBUGLVLC ( )
* If the ' macro specified ' debug class level > = level OR the system - wide
* DEBUGLEVEL ( synomym for DEBUGLEVEL_CLASS [ DBGC_ALL ] ) > = level then
* generate a header using the default macros for file , line , and
* function name . Returns True if the debug level was < = DEBUGLEVEL .
*
2001-06-01 12:04:44 +00:00
* Example : if ( DEBUGLVLC ( DBGC_TDB , 2 ) ) dbgtext ( " Some text. \n " ) ;
2001-02-12 16:18:02 +00:00
*
* DEBUG ( )
* If the ' file specific ' debug class level > = level OR the system - wide
* DEBUGLEVEL ( synomym for DEBUGLEVEL_CLASS [ DBGC_ALL ] ) > = level then
* generate a header using the default macros for file , line , and
* function name . Each call to DEBUG ( ) generates a new header * unless * the
* previous debug output was unterminated ( i . e . no ' \n ' ) .
* See debug . c : dbghdr ( ) for more info .
*
2001-06-01 12:04:44 +00:00
* Example : DEBUG ( 2 , ( " Some text and a value %d. \n " , value ) ) ;
2001-02-12 16:18:02 +00:00
*
* DEBUGC ( )
* If the ' macro specified ' debug class level > = level OR the system - wide
* DEBUGLEVEL ( synomym for DEBUGLEVEL_CLASS [ DBGC_ALL ] ) > = level then
* generate a header using the default macros for file , line , and
* function name . Each call to DEBUG ( ) generates a new header * unless * the
* previous debug output was unterminated ( i . e . no ' \n ' ) .
* See debug . c : dbghdr ( ) for more info .
*
2001-06-01 12:04:44 +00:00
* Example : DEBUGC ( DBGC_TDB , 2 , ( " Some text and a value %d. \n " , value ) ) ;
2001-02-12 16:18:02 +00:00
*
* DEBUGADD ( ) , DEBUGADDC ( )
* Same as DEBUG ( ) and DEBUGC ( ) except the text is appended to the previous
* DEBUG ( ) , DEBUGC ( ) , DEBUGADD ( ) , DEBUGADDC ( ) with out another interviening
* header .
*
2001-06-01 12:04:44 +00:00
* Example : DEBUGADD ( 2 , ( " Some text and a value %d. \n " , value ) ) ;
* DEBUGADDC ( DBGC_TDB , 2 , ( " Some text and a value %d. \n " , value ) ) ;
2001-02-12 16:18:02 +00:00
*
* Note : If the debug class has not be redeined ( see above ) then the optimizer
* will remove the extra conditional test .
2000-02-03 04:47:50 +00:00
*/
2001-02-12 16:18:02 +00:00
2007-12-27 17:41:19 +01:00
/*
* From talloc . c :
*/
/* these macros gain us a few percent of speed on gcc */
# if (__GNUC__ >= 3)
/* the strange !! is to ensure that __builtin_expect() takes either 0 or 1
as its first argument */
2008-06-27 15:51:35 +02:00
# ifndef likely
2007-12-27 17:41:19 +01:00
# define likely(x) __builtin_expect(!!(x), 1)
2008-06-27 15:51:35 +02:00
# endif
# ifndef unlikely
2007-12-27 17:41:19 +01:00
# define unlikely(x) __builtin_expect(!!(x), 0)
2008-06-27 15:51:35 +02:00
# endif
2007-12-27 17:41:19 +01:00
# else
2008-06-27 15:51:35 +02:00
# ifndef likely
2007-12-28 00:12:14 +01:00
# define likely(x) (x)
2008-06-27 15:51:35 +02:00
# endif
# ifndef unlikely
2007-12-28 00:12:14 +01:00
# define unlikely(x) (x)
2007-12-27 17:41:19 +01:00
# endif
2008-06-27 15:51:35 +02:00
# endif
2007-12-27 17:41:19 +01:00
2008-01-23 00:30:28 +01:00
# define CHECK_DEBUGLVL( level ) \
2001-12-06 07:17:25 +00:00
( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ DBGC_CLASS ] > = ( level ) ) | | \
2002-07-15 10:35:28 +00:00
( ! DEBUGLEVEL_CLASS_ISSET [ DBGC_CLASS ] & & \
2008-01-23 00:30:28 +01:00
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) )
# define DEBUGLVL( level ) \
( CHECK_DEBUGLVL ( level ) \
2008-10-11 20:44:19 +02:00
& & dbghdrclass ( level , DBGC_CLASS , __location__ , FUNCTION_MACRO ) )
2001-02-12 16:18:02 +00:00
# define DEBUGLVLC( dbgc_class, level ) \
2001-12-06 07:17:25 +00:00
( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ dbgc_class ] > = ( level ) ) | | \
2001-06-01 12:04:44 +00:00
( ! DEBUGLEVEL_CLASS_ISSET [ dbgc_class ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
2008-10-11 20:44:19 +02:00
& & dbghdrclass ( level , DBGC_CLASS , __location__ , FUNCTION_MACRO ) )
2000-02-03 04:47:50 +00:00
2001-02-12 16:18:02 +00:00
2000-02-03 04:47:50 +00:00
# define DEBUG( level, body ) \
2001-12-06 07:17:25 +00:00
( void ) ( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ DBGC_CLASS ] > = ( level ) ) | | \
2001-06-01 12:04:44 +00:00
( ! DEBUGLEVEL_CLASS_ISSET [ DBGC_CLASS ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
2008-10-11 20:44:19 +02:00
& & ( dbghdrclass ( level , DBGC_CLASS , __location__ , FUNCTION_MACRO ) ) \
2001-02-12 16:18:02 +00:00
& & ( dbgtext body ) )
# define DEBUGC( dbgc_class, level, body ) \
2001-12-06 07:17:25 +00:00
( void ) ( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ dbgc_class ] > = ( level ) ) | | \
2001-06-01 12:04:44 +00:00
( ! DEBUGLEVEL_CLASS_ISSET [ dbgc_class ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
2008-10-11 20:44:19 +02:00
& & ( dbghdrclass ( level , DBGC_CLASS , __location__ , FUNCTION_MACRO ) ) \
2000-02-03 04:47:50 +00:00
& & ( dbgtext body ) )
# define DEBUGADD( level, body ) \
2001-12-06 07:17:25 +00:00
( void ) ( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ DBGC_CLASS ] > = ( level ) ) | | \
2001-06-01 12:04:44 +00:00
( ! DEBUGLEVEL_CLASS_ISSET [ DBGC_CLASS ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
2001-02-12 16:18:02 +00:00
& & ( dbgtext body ) )
2000-02-03 04:47:50 +00:00
2001-02-12 16:18:02 +00:00
# define DEBUGADDC( dbgc_class, level, body ) \
2001-12-06 07:17:25 +00:00
( void ) ( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ dbgc_class ] > = ( level ) ) | | \
2001-06-01 12:04:44 +00:00
( ! DEBUGLEVEL_CLASS_ISSET [ dbgc_class ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
2001-02-12 16:18:02 +00:00
& & ( dbgtext body ) )
2000-02-03 04:47:50 +00:00
2006-04-04 00:27:50 +00:00
/* Print a separator to the debug log. */
# define DEBUGSEP(level)\
DEBUG ( ( level ) , ( " =============================================================== \n " ) )
2000-02-03 04:47:50 +00:00
# endif