blob: 56719806f11cbf8019892805a66e3af6227e9ab0 [file] [log] [blame]
Harald Welte52b1f982008-12-23 20:25:15 +00001#ifndef _DEBUG_H
2#define _DEBUG_H
3
Harald Welte3633a6d2008-12-26 00:06:02 +00004#define DEBUG
5
Harald Welte52b1f982008-12-23 20:25:15 +00006#define DRLL 0x0001
7#define DCC 0x0002
8#define DMM 0x0004
9#define DRR 0x0008
Harald Welte3633a6d2008-12-26 00:06:02 +000010#define DRSL 0x0010
11#define DNM 0x0020
Harald Weltebcae43f2008-12-27 21:45:37 +000012#define DSMS 0x0100
Harald Welted35b6a72008-12-29 04:06:41 +000013#define DPAG 0x0200
Harald Welte3633a6d2008-12-26 00:06:02 +000014#define DMI 0x1000
Harald Weltea3d04382008-12-27 17:02:56 +000015#define DMIB 0x2000
Harald Welte52b1f982008-12-23 20:25:15 +000016
17#ifdef DEBUG
Harald Weltead384642008-12-26 10:20:07 +000018#define DEBUGP(ss, fmt, args...) debugp(ss, __FILE__, __LINE__, fmt, ## args)
Harald Welte52b1f982008-12-23 20:25:15 +000019#else
Harald Weltead384642008-12-26 10:20:07 +000020#define DEBUGP(xss, fmt, args...)
Harald Welte52b1f982008-12-23 20:25:15 +000021#endif
22
Holger Freyther1ad732c2008-12-28 16:32:41 +000023#define static_assert(exp, name) typedef int dummy##name [(exp) ? 1 : -1];
24
Holger Freytherca362a62009-01-04 21:05:01 +000025void hexdump(unsigned char *buf, int len);
Harald Welte702d8702008-12-26 20:25:35 +000026void debugp(unsigned int subsys, char *file, int line, const char *format, ...);
Holger Freyther5ee72ee2008-12-27 12:46:49 +000027void debug_parse_category_mask(const char* mask);
Holger Freytherb332f612008-12-27 12:46:51 +000028void debug_use_color(int use_color);
Harald Welteb0f47932008-12-30 14:59:01 +000029unsigned int debug_mask;
Harald Weltead384642008-12-26 10:20:07 +000030
Harald Welte52b1f982008-12-23 20:25:15 +000031#endif /* _DEBUG_H */