[PATCH 2/2] dynamic printk: add support for pr_debug_hex_dump

From: Roman Fietze
Date: Fri Dec 03 2010 - 09:00:43 EST


Use dynamic printk wrapper to support turning pr_debug_hex_dump on and
off similar to pr_debug using the dynamic debug sysfs control file.

Signed-off-by: Roman Fietze <roman.fietze@xxxxxxxxxxxxx>
---
include/linux/dynamic_debug.h | 22 ++++++++++++++++++++++
include/linux/printk.h | 16 ++++++++++++----
2 files changed, 34 insertions(+), 4 deletions(-)

diff --git a/include/linux/dynamic_debug.h b/include/linux/dynamic_debug.h
index a90b389..0610e74 100644
--- a/include/linux/dynamic_debug.h
+++ b/include/linux/dynamic_debug.h
@@ -74,6 +74,24 @@ do_printk: \
out: ; \
} while (0)

+#define dynamic_pr_hex_dump(prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii) \
+ do { \
+ __label__ do_hex_dump; \
+ __label__ out; \
+ static struct _ddebug descriptor \
+ __used \
+ __attribute__((section("__verbose"), aligned(8))) = { \
+ KBUILD_MODNAME, __func__, __FILE__, prfx_str, __LINE__, \
+ _DPRINTK_FLAGS_DEFAULT }; \
+ JUMP_LABEL(&descriptor.enabled, do_hex_dump); \
+ goto out; \
+ do_hex_dump: \
+ print_hex_dump(KERN_DEBUG, prfx_str, prfx_type, \
+ rowsz, grpsz, buf, len, ascii); \
+ out: ; \
+ } while (0)
+
#else

static inline int ddebug_remove_module(const char *mod)
@@ -85,6 +103,10 @@ static inline int ddebug_remove_module(const char *mod)
do { if (0) printk(KERN_DEBUG pr_fmt(fmt), ##__VA_ARGS__); } while (0)
#define dynamic_dev_dbg(dev, fmt, ...) \
do { if (0) dev_printk(KERN_DEBUG, dev, fmt, ##__VA_ARGS__); } while (0)
+#define dynamic_pr_hex_dump(prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii) \
+ do { if (0) print_hex_dump(KERN_DEBUG, prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii); } while (0)
#endif

#endif
diff --git a/include/linux/printk.h b/include/linux/printk.h
index 77903f1..5bf4483 100644
--- a/include/linux/printk.h
+++ b/include/linux/printk.h
@@ -212,10 +212,6 @@ extern void print_hex_dump_bytes(const char *prefix_str, int prefix_type,
buf, len, ascii) \
print_hex_dump(KERN_CONT, prfx_str, prfx_type, rowsz, grpsz, \
buf, len, ascii)
-#define pr_debug_hex_dump(prfx_str, prfx_type, rowsz, grpsz, \
- buf, len, ascii) \
- print_hex_dump(KERN_DEBUG, prfx_str, prfx_type, rowsz, grpsz, \
- buf, len, ascii)

/* pr_devel() should produce zero code unless DEBUG is defined */
#ifdef DEBUG
@@ -230,13 +226,25 @@ extern void print_hex_dump_bytes(const char *prefix_str, int prefix_type,
#if defined(DEBUG)
#define pr_debug(fmt, ...) \
printk(KERN_DEBUG pr_fmt(fmt), ##__VA_ARGS__)
+#define pr_debug_hex_dump(prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii) \
+ print_hex_dump(KERN_DEBUG, prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii)
#elif defined(CONFIG_DYNAMIC_DEBUG)
/* dynamic_pr_debug() uses pr_fmt() internally so we don't need it here */
#define pr_debug(fmt, ...) \
dynamic_pr_debug(fmt, ##__VA_ARGS__)
+#define pr_debug_hex_dump(prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii) \
+ dynamic_pr_hex_dump(prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii)
#else
#define pr_debug(fmt, ...) \
({ if (0) printk(KERN_DEBUG pr_fmt(fmt), ##__VA_ARGS__); 0; })
+#define pr_debug_hex_dump(prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii) \
+ do { if (0) print_hex_dump(KERN_DEBUG, prfx_str, prfx_type, rowsz, grpsz, \
+ buf, len, ascii); } while (0)
#endif

/*
--
1.7.3.2




--
Roman Fietze Telemotive AG Buero Muehlhausen
Breitwiesen 73347 Muehlhausen
Tel.: +49(0)7335/18493-45 http://www.telemotive.de
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/