| /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
| /* | 
|  *   Copyright (C) International Business Machines Corp., 2000-2002 | 
|  *   Portions Copyright (C) Christoph Hellwig, 2001-2002 | 
|  */ | 
| #ifndef _H_JFS_DEBUG | 
| #define _H_JFS_DEBUG | 
|   | 
| /* | 
|  *    jfs_debug.h | 
|  * | 
|  * global debug message, data structure/macro definitions | 
|  * under control of CONFIG_JFS_DEBUG, CONFIG_JFS_STATISTICS; | 
|  */ | 
|   | 
| /* | 
|  * Create /proc/fs/jfs if procfs is enabled andeither | 
|  * CONFIG_JFS_DEBUG or CONFIG_JFS_STATISTICS is defined | 
|  */ | 
| #if defined(CONFIG_PROC_FS) && (defined(CONFIG_JFS_DEBUG) || defined(CONFIG_JFS_STATISTICS)) | 
| #define PROC_FS_JFS | 
| extern void jfs_proc_init(void); | 
| extern void jfs_proc_clean(void); | 
| #endif | 
|   | 
| /* | 
|  *    assert with traditional printf/panic | 
|  */ | 
| #define assert(p) do {    \ | 
|     if (!(p)) {    \ | 
|         printk(KERN_CRIT "BUG at %s:%d assert(%s)\n",    \ | 
|                __FILE__, __LINE__, #p);            \ | 
|         BUG();    \ | 
|     }        \ | 
| } while (0) | 
|   | 
| /* | 
|  *    debug ON | 
|  *    -------- | 
|  */ | 
| #ifdef CONFIG_JFS_DEBUG | 
| #define ASSERT(p) assert(p) | 
|   | 
| /* printk verbosity */ | 
| #define JFS_LOGLEVEL_ERR 1 | 
| #define JFS_LOGLEVEL_WARN 2 | 
| #define JFS_LOGLEVEL_DEBUG 3 | 
| #define JFS_LOGLEVEL_INFO 4 | 
|   | 
| extern int jfsloglevel; | 
|   | 
| int jfs_txanchor_proc_show(struct seq_file *m, void *v); | 
|   | 
| /* information message: e.g., configuration, major event */ | 
| #define jfs_info(fmt, arg...) do {            \ | 
|     if (jfsloglevel >= JFS_LOGLEVEL_INFO)        \ | 
|         printk(KERN_INFO fmt "\n", ## arg);    \ | 
| } while (0) | 
|   | 
| /* debug message: ad hoc */ | 
| #define jfs_debug(fmt, arg...) do {            \ | 
|     if (jfsloglevel >= JFS_LOGLEVEL_DEBUG)        \ | 
|         printk(KERN_DEBUG fmt "\n", ## arg);    \ | 
| } while (0) | 
|   | 
| /* warn message: */ | 
| #define jfs_warn(fmt, arg...) do {            \ | 
|     if (jfsloglevel >= JFS_LOGLEVEL_WARN)        \ | 
|         printk(KERN_WARNING fmt "\n", ## arg);    \ | 
| } while (0) | 
|   | 
| /* error event message: e.g., i/o error */ | 
| #define jfs_err(fmt, arg...) do {            \ | 
|     if (jfsloglevel >= JFS_LOGLEVEL_ERR)        \ | 
|         printk(KERN_ERR fmt "\n", ## arg);    \ | 
| } while (0) | 
|   | 
| /* | 
|  *    debug OFF | 
|  *    --------- | 
|  */ | 
| #else                /* CONFIG_JFS_DEBUG */ | 
| #define ASSERT(p) do {} while (0) | 
| #define jfs_info(fmt, arg...) do {} while (0) | 
| #define jfs_debug(fmt, arg...) do {} while (0) | 
| #define jfs_warn(fmt, arg...) do {} while (0) | 
| #define jfs_err(fmt, arg...) do {} while (0) | 
| #endif                /* CONFIG_JFS_DEBUG */ | 
|   | 
| /* | 
|  *    statistics | 
|  *    ---------- | 
|  */ | 
| #ifdef    CONFIG_JFS_STATISTICS | 
| int jfs_lmstats_proc_show(struct seq_file *m, void *v); | 
| int jfs_txstats_proc_show(struct seq_file *m, void *v); | 
| int jfs_mpstat_proc_show(struct seq_file *m, void *v); | 
| int jfs_xtstat_proc_show(struct seq_file *m, void *v); | 
|   | 
| #define    INCREMENT(x)        ((x)++) | 
| #define    DECREMENT(x)        ((x)--) | 
| #define    HIGHWATERMARK(x,y)    ((x) = max((x), (y))) | 
| #else | 
| #define    INCREMENT(x) | 
| #define    DECREMENT(x) | 
| #define    HIGHWATERMARK(x,y) | 
| #endif                /* CONFIG_JFS_STATISTICS */ | 
|   | 
| #endif                /* _H_JFS_DEBUG */ |