Merge branch 'fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/evalenti/linux...
[linux/fpc-iii.git] / fs / cifs / cifs_debug.h
blobc611ca2339d71e982da848bf1a5c1432d691e53c
1 /*
3 * Copyright (c) International Business Machines Corp., 2000,2002
4 * Modified by Steve French (sfrench@us.ibm.com)
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
14 * the GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 #ifndef _H_CIFS_DEBUG
23 #define _H_CIFS_DEBUG
25 void cifs_dump_mem(char *label, void *data, int length);
26 void cifs_dump_detail(void *);
27 void cifs_dump_mids(struct TCP_Server_Info *);
28 extern bool traceSMB; /* flag which enables the function below */
29 void dump_smb(void *, int);
30 #define CIFS_INFO 0x01
31 #define CIFS_RC 0x02
32 #define CIFS_TIMER 0x04
34 #define VFS 1
35 #define FYI 2
36 extern int cifsFYI;
37 #ifdef CONFIG_CIFS_DEBUG2
38 #define NOISY 4
39 #else
40 #define NOISY 0
41 #endif
44 * debug ON
45 * --------
47 #ifdef CONFIG_CIFS_DEBUG
49 __printf(1, 2) void cifs_vfs_err(const char *fmt, ...);
51 /* information message: e.g., configuration, major event */
52 #define cifs_dbg(type, fmt, ...) \
53 do { \
54 if (type == FYI && cifsFYI & CIFS_INFO) { \
55 pr_debug_ratelimited("%s: " \
56 fmt, __FILE__, ##__VA_ARGS__); \
57 } else if (type == VFS) { \
58 cifs_vfs_err(fmt, ##__VA_ARGS__); \
59 } else if (type == NOISY && type != 0) { \
60 pr_debug_ratelimited(fmt, ##__VA_ARGS__); \
61 } \
62 } while (0)
65 * debug OFF
66 * ---------
68 #else /* _CIFS_DEBUG */
69 #define cifs_dbg(type, fmt, ...) \
70 do { \
71 if (0) \
72 pr_debug(fmt, ##__VA_ARGS__); \
73 } while (0)
74 #endif
76 #endif /* _H_CIFS_DEBUG */