|  | /* | 
|  | * | 
|  | *   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); | 
|  | void cifs_dump_detail(void *buf, struct TCP_Server_Info *ptcp_info); | 
|  | void cifs_dump_mids(struct TCP_Server_Info *); | 
|  | extern bool traceSMB;		/* flag which enables the function below */ | 
|  | void dump_smb(void *, int); | 
|  | #define CIFS_INFO	0x01 | 
|  | #define CIFS_RC		0x02 | 
|  | #define CIFS_TIMER	0x04 | 
|  |  | 
|  | #define VFS 1 | 
|  | #define FYI 2 | 
|  | extern int cifsFYI; | 
|  | #ifdef CONFIG_CIFS_DEBUG2 | 
|  | #define NOISY 4 | 
|  | #else | 
|  | #define NOISY 0 | 
|  | #endif | 
|  | #define ONCE 8 | 
|  |  | 
|  | /* | 
|  | *	debug ON | 
|  | *	-------- | 
|  | */ | 
|  | #ifdef CONFIG_CIFS_DEBUG | 
|  |  | 
|  | /* information message: e.g., configuration, major event */ | 
|  | #define cifs_dbg_func(ratefunc, type, fmt, ...)			\ | 
|  | do {								\ | 
|  | if ((type) & FYI && cifsFYI & CIFS_INFO) {		\ | 
|  | pr_debug_ ## ratefunc("%s: "			\ | 
|  | fmt, __FILE__, ##__VA_ARGS__);	\ | 
|  | } else if ((type) & VFS) {				\ | 
|  | pr_err_ ## ratefunc("CIFS VFS: "		\ | 
|  | fmt, ##__VA_ARGS__);		\ | 
|  | } else if ((type) & NOISY && (NOISY != 0)) {		\ | 
|  | pr_debug_ ## ratefunc(fmt, ##__VA_ARGS__);	\ | 
|  | }							\ | 
|  | } while (0) | 
|  |  | 
|  | #define cifs_dbg(type, fmt, ...) \ | 
|  | do {							\ | 
|  | if ((type) & ONCE)				\ | 
|  | cifs_dbg_func(once,			\ | 
|  | type, fmt, ##__VA_ARGS__);	\ | 
|  | else						\ | 
|  | cifs_dbg_func(ratelimited,		\ | 
|  | type, fmt, ##__VA_ARGS__);	\ | 
|  | } while (0) | 
|  |  | 
|  | /* | 
|  | *	debug OFF | 
|  | *	--------- | 
|  | */ | 
|  | #else		/* _CIFS_DEBUG */ | 
|  | #define cifs_dbg(type, fmt, ...)					\ | 
|  | do {									\ | 
|  | if (0)								\ | 
|  | pr_debug(fmt, ##__VA_ARGS__);				\ | 
|  | } while (0) | 
|  | #endif | 
|  |  | 
|  | #endif				/* _H_CIFS_DEBUG */ |