| 1 | #ifndef FIO_DEBUG_H |
| 2 | #define FIO_DEBUG_H |
| 3 | |
| 4 | #include <assert.h> |
| 5 | #include "log.h" |
| 6 | |
| 7 | enum { |
| 8 | FD_PROCESS = 0, |
| 9 | FD_FILE, |
| 10 | FD_IO, |
| 11 | FD_MEM, |
| 12 | FD_BLKTRACE, |
| 13 | FD_VERIFY, |
| 14 | FD_RANDOM, |
| 15 | FD_PARSE, |
| 16 | FD_DISKUTIL, |
| 17 | FD_JOB, |
| 18 | FD_MUTEX, |
| 19 | FD_PROFILE, |
| 20 | FD_TIME, |
| 21 | FD_NET, |
| 22 | FD_DEBUG_MAX, |
| 23 | }; |
| 24 | |
| 25 | extern unsigned int fio_debug_jobno, *fio_debug_jobp; |
| 26 | |
| 27 | #ifdef FIO_INC_DEBUG |
| 28 | struct debug_level { |
| 29 | const char *name; |
| 30 | unsigned long shift; |
| 31 | unsigned int jobno; |
| 32 | }; |
| 33 | extern struct debug_level debug_levels[]; |
| 34 | |
| 35 | extern unsigned long fio_debug; |
| 36 | |
| 37 | void __dprint(int type, const char *str, ...); |
| 38 | |
| 39 | #define dprint(type, str, args...) \ |
| 40 | do { \ |
| 41 | if ((((1 << type)) & fio_debug) == 0) \ |
| 42 | break; \ |
| 43 | __dprint((type), (str), ##args); \ |
| 44 | } while (0) \ |
| 45 | |
| 46 | #else |
| 47 | |
| 48 | static inline void dprint(int type, const char *str, ...) |
| 49 | { |
| 50 | } |
| 51 | #endif |
| 52 | |
| 53 | #endif |