2005-04-17 02:20:36 +04:00
/*
*
* Copyright ( c ) International Business Machines Corp . , 2000 , 2002
* Modified by Steve French ( sfrench @ us . ibm . com )
*
* 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
* the Free Software Foundation ; either version 2 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
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*
*/
# ifndef _H_CIFS_DEBUG
# define _H_CIFS_DEBUG
void cifs_dump_mem ( char * label , void * data , int length ) ;
2012-03-23 22:28:02 +04:00
void cifs_dump_detail ( void * ) ;
2006-06-01 02:40:51 +04:00
void cifs_dump_mids ( struct TCP_Server_Info * ) ;
2016-03-18 00:22:54 +03:00
extern bool traceSMB ; /* flag which enables the function below */
2012-03-23 22:28:02 +04:00
void dump_smb ( void * , int ) ;
2005-10-12 06:58:06 +04:00
# define CIFS_INFO 0x01
2010-10-07 22:46:32 +04:00
# define CIFS_RC 0x02
2005-10-12 06:58:06 +04:00
# define CIFS_TIMER 0x04
2005-04-17 02:20:36 +04:00
2013-05-05 07:12:25 +04:00
# define VFS 1
# define FYI 2
2012-12-06 00:42:47 +04:00
extern int cifsFYI ;
2013-05-05 07:12:25 +04:00
# ifdef CONFIG_CIFS_DEBUG2
# define NOISY 4
# else
# define NOISY 0
# endif
2012-12-06 00:42:47 +04:00
2005-04-17 02:20:36 +04:00
/*
* debug ON
* - - - - - - - -
*/
2012-12-06 00:42:58 +04:00
# ifdef CONFIG_CIFS_DEBUG
2005-04-17 02:20:36 +04:00
2013-05-05 07:12:25 +04:00
__printf ( 1 , 2 ) void cifs_vfs_err ( const char * fmt , . . . ) ;
2005-04-17 02:20:36 +04:00
2013-05-05 07:12:25 +04:00
/* information message: e.g., configuration, major event */
# define cifs_dbg(type, fmt, ...) \
2012-12-06 00:42:47 +04:00
do { \
2015-11-07 15:13:49 +03:00
if ( type = = FYI & & cifsFYI & CIFS_INFO ) { \
pr_debug_ratelimited ( " %s: " \
fmt , __FILE__ , # # __VA_ARGS__ ) ; \
2013-05-05 07:12:25 +04:00
} else if ( type = = VFS ) { \
cifs_vfs_err ( fmt , # # __VA_ARGS__ ) ; \
} else if ( type = = NOISY & & type ! = 0 ) { \
2015-11-07 15:13:49 +03:00
pr_debug_ratelimited ( fmt , # # __VA_ARGS__ ) ; \
2013-05-05 07:12:25 +04:00
} \
2010-04-21 07:50:45 +04:00
} while ( 0 )
2005-04-17 02:20:36 +04:00
/*
* debug OFF
* - - - - - - - - -
*/
# else /* _CIFS_DEBUG */
2013-05-05 07:12:25 +04:00
# define cifs_dbg(type, fmt, ...) \
2012-12-06 00:42:47 +04:00
do { \
if ( 0 ) \
2014-08-27 17:49:44 +04:00
pr_debug ( fmt , # # __VA_ARGS__ ) ; \
2012-12-06 00:42:47 +04:00
} while ( 0 )
2013-05-05 07:12:25 +04:00
# endif
2005-04-17 02:20:36 +04:00
# endif /* _H_CIFS_DEBUG */