summaryrefslogtreecommitdiff
path: root/mwl_debug.h
diff options
context:
space:
mode:
Diffstat (limited to 'mwl_debug.h')
-rw-r--r--mwl_debug.h118
1 files changed, 118 insertions, 0 deletions
diff --git a/mwl_debug.h b/mwl_debug.h
new file mode 100644
index 0000000..6e9d74e
--- /dev/null
+++ b/mwl_debug.h
@@ -0,0 +1,118 @@
+/*
+* Copyright (c) 2006-2014 Marvell International Ltd.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
+* SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
+* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
+* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+/*
+*
+* Description: This file defines debug related functions.
+*
+*/
+
+#ifndef _mwl_debug_h_
+#define _mwl_debug_h_
+
+#include <linux/types.h>
+
+/* CONSTANTS AND MACROS
+*/
+
+#define DBG_LEVEL_0 (1<<0) /* mwl_main.c */
+#define DBG_LEVEL_1 (1<<1) /* mwl_fwdl.c */
+#define DBG_LEVEL_2 (1<<2) /* mwl_fwcmd.c */
+#define DBG_LEVEL_3 (1<<3) /* mwl_tx.c */
+#define DBG_LEVEL_4 (1<<4) /* mwl_rx.c */
+#define DBG_LEVEL_5 (1<<5) /* mwl_mac80211.c */
+#define DBG_LEVEL_6 (1<<6)
+#define DBG_LEVEL_7 (1<<7)
+#define DBG_LEVEL_8 (1<<8)
+#define DBG_LEVEL_9 (1<<9)
+#define DBG_LEVEL_10 (1<<10)
+#define DBG_LEVEL_11 (1<<11)
+#define DBG_LEVEL_12 (1<<12)
+#define DBG_LEVEL_13 (1<<13)
+#define DBG_LEVEL_14 (1<<14)
+#define DBG_LEVEL_15 (1<<15)
+
+#define DBG_CLASS_PANIC (1<<16)
+#define DBG_CLASS_ERROR (1<<17)
+#define DBG_CLASS_WARNING (1<<18)
+#define DBG_CLASS_ENTER (1<<19)
+#define DBG_CLASS_EXIT (1<<20)
+#define DBG_CLASS_INFO (1<<21)
+#define DBG_CLASS_DATA (1<<22)
+#define DBG_CLASS_7 (1<<23)
+#define DBG_CLASS_8 (1<<24)
+#define DBG_CLASS_9 (1<<25)
+#define DBG_CLASS_10 (1<<26)
+#define DBG_CLASS_11 (1<<27)
+#define DBG_CLASS_12 (1<<28)
+#define DBG_CLASS_13 (1<<29)
+#define DBG_CLASS_14 (1<<30)
+#define DBG_CLASS_15 (1<<31)
+
+#define WLDBG_PRINT(...) \
+ mwl_debug_prt(0, __FUNCTION__, __VA_ARGS__)
+
+#ifdef MWL_DEBUG
+
+#define WLDBG_DUMP_DATA(classlevel, data, len) \
+ mwl_debug_prtdata(classlevel|DBG_CLASS_DATA, __FUNCTION__, data, len, NULL)
+
+#define WLDBG_ENTER(classlevel) \
+ mwl_debug_prt(classlevel|DBG_CLASS_ENTER, __FUNCTION__, NULL)
+
+#define WLDBG_ENTER_INFO(classlevel, ...) \
+ mwl_debug_prt(classlevel|DBG_CLASS_ENTER, __FUNCTION__, __VA_ARGS__)
+
+#define WLDBG_EXIT(classlevel) \
+ mwl_debug_prt(classlevel|DBG_CLASS_EXIT, __FUNCTION__, NULL)
+
+#define WLDBG_EXIT_INFO(classlevel, ...) \
+ mwl_debug_prt(classlevel|DBG_CLASS_EXIT, __FUNCTION__, __VA_ARGS__)
+
+#define WLDBG_INFO(classlevel, ...) \
+ mwl_debug_prt(classlevel|DBG_CLASS_INFO, __FUNCTION__, __VA_ARGS__)
+
+#define WLDBG_WARNING(classlevel, ...) \
+ mwl_debug_prt(classlevel|DBG_CLASS_WARNING, __FUNCTION__, __VA_ARGS__)
+
+#define WLDBG_ERROR(classlevel, ...) \
+ mwl_debug_prt(classlevel|DBG_CLASS_ERROR, __FUNCTION__, __VA_ARGS__)
+
+#define WLDBG_PANIC(classlevel, ...) \
+ mwl_debug_prt(classlevel|DBG_CLASS_PANIC, __FUNCTION__, __VA_ARGS__)
+
+#else
+
+#define WLDBG_DUMP_DATA(classlevel, data, len)
+#define WLDBG_ENTER(classlevel)
+#define WLDBG_ENTER_INFO(classlevel, ...)
+#define WLDBG_EXIT(classlevel)
+#define WLDBG_EXIT_INFO(classlevel, ...)
+#define WLDBG_INFO(classlevel, ...)
+#define WLDBG_WARNING(classlevel, ...)
+#define WLDBG_ERROR(classlevel, ...)
+#define WLDBG_PANIC(classlevel, ...)
+
+#endif /* MWL_DEBUG */
+
+/* PUBLIC FUNCTION DECLARATION
+*/
+
+void mwl_debug_prt(u32 classlevel, const char *func, const char *format, ...);
+void mwl_debug_prtdata(u32 classlevel, const char *func, const void *data, int len, const char *format, ...);
+void mwl_debug_dumpdata(const void *data, int len, char *marker);
+
+#endif /* _mwl_debug_h_ */