blob: 63f9e671cb9605fc6c9a785c12ea8123506bd32b [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 Welteb480f412009-02-18 03:27:39 +000012
Harald Weltec125a682009-05-23 06:42:38 +000013#define DMNCC 0x0080
Harald Weltebcae43f2008-12-27 21:45:37 +000014#define DSMS 0x0100
Harald Welted35b6a72008-12-29 04:06:41 +000015#define DPAG 0x0200
Harald Welteb480f412009-02-18 03:27:39 +000016
Harald Welte3633a6d2008-12-26 00:06:02 +000017#define DMI 0x1000
Harald Weltea3d04382008-12-27 17:02:56 +000018#define DMIB 0x2000
Harald Welteb480f412009-02-18 03:27:39 +000019#define DMUX 0x4000
Harald Welteedb37782009-05-01 14:59:07 +000020#define DINP 0x8000
Harald Welte52b1f982008-12-23 20:25:15 +000021
22#ifdef DEBUG
Harald Welte6ddd1682009-02-06 12:38:29 +000023#define DEBUGP(ss, fmt, args...) debugp(ss, __FILE__, __LINE__, 0, fmt, ## args)
24#define DEBUGPC(ss, fmt, args...) debugp(ss, __FILE__, __LINE__, 1, fmt, ## args)
Harald Welte52b1f982008-12-23 20:25:15 +000025#else
Harald Weltead384642008-12-26 10:20:07 +000026#define DEBUGP(xss, fmt, args...)
Harald Welte6ddd1682009-02-06 12:38:29 +000027#define DEBUGPC(ss, fmt, args...)
Harald Welte52b1f982008-12-23 20:25:15 +000028#endif
29
Holger Freyther1ad732c2008-12-28 16:32:41 +000030#define static_assert(exp, name) typedef int dummy##name [(exp) ? 1 : -1];
31
Harald Welte3cc4bf52009-02-28 13:08:01 +000032char *hexdump(unsigned char *buf, int len);
Harald Welte6ddd1682009-02-06 12:38:29 +000033void debugp(unsigned int subsys, char *file, int line, int cont, const char *format, ...);
Holger Freyther5ee72ee2008-12-27 12:46:49 +000034void debug_parse_category_mask(const char* mask);
Holger Freytherb332f612008-12-27 12:46:51 +000035void debug_use_color(int use_color);
Harald Welted3ff51d2009-06-09 20:21:57 +000036void debug_timestamp(int enable);
Harald Weltec125a682009-05-23 06:42:38 +000037extern unsigned int debug_mask;
Harald Weltead384642008-12-26 10:20:07 +000038
Harald Welte52b1f982008-12-23 20:25:15 +000039#endif /* _DEBUG_H */