/*
Unix SMB / CIFS implementation .
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
( 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/>.
*/
# 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
past .
The PRINTFLIKE comment does the equivalent for SGI MIPSPro .
*/
/* PRINTFLIKE1 */
int Debug1 ( const char * , . . . ) PRINTF_ATTRIBUTE ( 1 , 2 ) ;
/* PRINTFLIKE1 */
2007-10-18 17:40:25 -07:00
bool dbgtext ( const char * , . . . ) PRINTF_ATTRIBUTE ( 1 , 2 ) ;
bool dbghdr ( int level , int cls , const char * file , const char * func , int line ) ;
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
# pragma mips_frequency_hint NEVER dbghdr
# endif
extern XFILE * dbf ;
/* 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
/*
* 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
extern int DEBUGLEVEL ;
/*
* 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 .
*/
# 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
# define DBGC_SAM 9
# define DBGC_AUTH 10
# define DBGC_WINBIND 11
# define DBGC_VFS 12
# define DBGC_IDMAP 13
# 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
/* So you can define DBGC_CLASS before including debug.h */
# ifndef DBGC_CLASS
# define DBGC_CLASS 0 /* override as shown above */
# endif
extern int * DEBUGLEVEL_CLASS ;
2007-10-18 17:40:25 -07:00
extern bool * DEBUGLEVEL_CLASS_ISSET ;
/* 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 .
*
* Example : if ( DEBUGLVLC ( DBGC_TDB , 2 ) ) dbgtext ( " Some text. \n " ) ;
*
* 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 .
*
* Example : DEBUG ( 2 , ( " Some text and a value %d. \n " , value ) ) ;
*
* 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 .
*
* Example : DEBUGC ( DBGC_TDB , 2 , ( " Some text and a value %d. \n " , value ) ) ;
*
* DEBUGADD ( ) , DEBUGADDC ( )
* Same as DEBUG ( ) and DEBUGC ( ) except the text is appended to the previous
* DEBUG ( ) , DEBUGC ( ) , DEBUGADD ( ) , DEBUGADDC ( ) with out another interviening
* header .
*
* Example : DEBUGADD ( 2 , ( " Some text and a value %d. \n " , value ) ) ;
* DEBUGADDC ( DBGC_TDB , 2 , ( " Some text and a value %d. \n " , value ) ) ;
*
* Note : If the debug class has not be redeined ( see above ) then the optimizer
* will remove the extra conditional test .
*/
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 */
# define likely(x) __builtin_expect(!!(x), 1)
# define unlikely(x) __builtin_expect(!!(x), 0)
# else
2007-12-28 00:12:14 +01:00
# define likely(x) (x)
# define unlikely(x) (x)
2007-12-27 17:41:19 +01:00
# endif
2008-01-23 00:30:28 +01:00
# define CHECK_DEBUGLVL( level ) \
( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ DBGC_CLASS ] > = ( level ) ) | | \
( ! DEBUGLEVEL_CLASS_ISSET [ DBGC_CLASS ] & & \
2008-01-23 00:30:28 +01:00
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) )
# define DEBUGLVL( level ) \
( CHECK_DEBUGLVL ( level ) \
2007-09-30 08:07:06 +00:00
& & dbghdr ( level , DBGC_CLASS , __FILE__ , FUNCTION_MACRO , ( __LINE__ ) ) )
# define DEBUGLVLC( dbgc_class, level ) \
( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ dbgc_class ] > = ( level ) ) | | \
( ! DEBUGLEVEL_CLASS_ISSET [ dbgc_class ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
2007-09-30 08:07:06 +00:00
& & dbghdr ( level , DBGC_CLASS , __FILE__ , FUNCTION_MACRO , ( __LINE__ ) ) )
# define DEBUG( level, body ) \
( void ) ( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ DBGC_CLASS ] > = ( level ) ) | | \
( ! DEBUGLEVEL_CLASS_ISSET [ DBGC_CLASS ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
2007-09-30 08:07:06 +00:00
& & ( dbghdr ( level , DBGC_CLASS , __FILE__ , FUNCTION_MACRO , ( __LINE__ ) ) ) \
& & ( dbgtext body ) )
# define DEBUGC( dbgc_class, level, body ) \
( void ) ( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ dbgc_class ] > = ( level ) ) | | \
( ! DEBUGLEVEL_CLASS_ISSET [ dbgc_class ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
2007-09-30 08:07:06 +00:00
& & ( dbghdr ( level , DBGC_CLASS , __FILE__ , FUNCTION_MACRO , ( __LINE__ ) ) ) \
& & ( dbgtext body ) )
# define DEBUGADD( level, body ) \
( void ) ( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ DBGC_CLASS ] > = ( level ) ) | | \
( ! DEBUGLEVEL_CLASS_ISSET [ DBGC_CLASS ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
& & ( dbgtext body ) )
# define DEBUGADDC( dbgc_class, level, body ) \
( void ) ( ( ( level ) < = MAX_DEBUG_LEVEL ) & & \
2007-12-27 17:41:19 +01:00
unlikely ( ( DEBUGLEVEL_CLASS [ dbgc_class ] > = ( level ) ) | | \
( ! DEBUGLEVEL_CLASS_ISSET [ dbgc_class ] & & \
DEBUGLEVEL_CLASS [ DBGC_ALL ] > = ( level ) ) ) \
& & ( dbgtext body ) )
2006-04-04 00:27:50 +00:00
/* Print a separator to the debug log. */
# define DEBUGSEP(level)\
DEBUG ( ( level ) , ( " =============================================================== \n " ) )
# endif