[RFC PATCH 5/5] tracing/events: modify kmem print to new format

From: Steven Rostedt
Date: Mon Jun 08 2009 - 21:48:31 EST


From: Steven Rostedt <srostedt@xxxxxxxxxx>

Use new format for better parsing of kmem events.

Signed-off-by: Steven Rostedt <rostedt@xxxxxxxxxxx>
---
include/trace/events/kmem.h | 97 +++++++++++++++++++------------------------
1 files changed, 43 insertions(+), 54 deletions(-)

diff --git a/include/trace/events/kmem.h b/include/trace/events/kmem.h
index 9baba50..2ffa8ae 100644
--- a/include/trace/events/kmem.h
+++ b/include/trace/events/kmem.h
@@ -17,32 +17,35 @@
*
* Thus most bits set go first.
*/
-#define show_gfp_flags(flags) \
- (flags) ? __print_flags(flags, "|", \
- {(unsigned long)GFP_HIGHUSER_MOVABLE, "GFP_HIGHUSER_MOVABLE"}, \
- {(unsigned long)GFP_HIGHUSER, "GFP_HIGHUSER"}, \
- {(unsigned long)GFP_USER, "GFP_USER"}, \
- {(unsigned long)GFP_TEMPORARY, "GFP_TEMPORARY"}, \
- {(unsigned long)GFP_KERNEL, "GFP_KERNEL"}, \
- {(unsigned long)GFP_NOFS, "GFP_NOFS"}, \
- {(unsigned long)GFP_ATOMIC, "GFP_ATOMIC"}, \
- {(unsigned long)GFP_NOIO, "GFP_NOIO"}, \
- {(unsigned long)__GFP_HIGH, "GFP_HIGH"}, \
- {(unsigned long)__GFP_WAIT, "GFP_WAIT"}, \
- {(unsigned long)__GFP_IO, "GFP_IO"}, \
- {(unsigned long)__GFP_COLD, "GFP_COLD"}, \
- {(unsigned long)__GFP_NOWARN, "GFP_NOWARN"}, \
- {(unsigned long)__GFP_REPEAT, "GFP_REPEAT"}, \
- {(unsigned long)__GFP_NOFAIL, "GFP_NOFAIL"}, \
- {(unsigned long)__GFP_NORETRY, "GFP_NORETRY"}, \
- {(unsigned long)__GFP_COMP, "GFP_COMP"}, \
- {(unsigned long)__GFP_ZERO, "GFP_ZERO"}, \
- {(unsigned long)__GFP_NOMEMALLOC, "GFP_NOMEMALLOC"}, \
- {(unsigned long)__GFP_HARDWALL, "GFP_HARDWALL"}, \
- {(unsigned long)__GFP_THISNODE, "GFP_THISNODE"}, \
- {(unsigned long)__GFP_RECLAIMABLE, "GFP_RECLAIMABLE"}, \
- {(unsigned long)__GFP_MOVABLE, "GFP_MOVABLE"} \
- ) : "GFP_NOWAIT"
+#define show_gfp_flags(end...) \
+ "0=GFP_NOWAIT," \
+ "0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s," \
+ "0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s," \
+ "0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s,0x%lx=%s," \
+ "0x%lx=%s,0x%lx=%s>" end , \
+ (unsigned long)GFP_HIGHUSER_MOVABLE, "GFP_HIGHUSER_MOVABLE", \
+ (unsigned long)GFP_HIGHUSER, "GFP_HIGHUSER", \
+ (unsigned long)GFP_USER, "GFP_USER", \
+ (unsigned long)GFP_TEMPORARY, "GFP_TEMPORARY", \
+ (unsigned long)GFP_KERNEL, "GFP_KERNEL", \
+ (unsigned long)GFP_NOFS, "GFP_NOFS", \
+ (unsigned long)GFP_ATOMIC, "GFP_ATOMIC", \
+ (unsigned long)GFP_NOIO, "GFP_NOIO", \
+ (unsigned long)__GFP_HIGH, "GFP_HIGH", \
+ (unsigned long)__GFP_WAIT, "GFP_WAIT", \
+ (unsigned long)__GFP_IO, "GFP_IO", \
+ (unsigned long)__GFP_COLD, "GFP_COLD", \
+ (unsigned long)__GFP_NOWARN, "GFP_NOWARN", \
+ (unsigned long)__GFP_REPEAT, "GFP_REPEAT", \
+ (unsigned long)__GFP_NOFAIL, "GFP_NOFAIL", \
+ (unsigned long)__GFP_NORETRY, "GFP_NORETRY", \
+ (unsigned long)__GFP_COMP, "GFP_COMP", \
+ (unsigned long)__GFP_ZERO, "GFP_ZERO", \
+ (unsigned long)__GFP_NOMEMALLOC, "GFP_NOMEMALLOC", \
+ (unsigned long)__GFP_HARDWALL, "GFP_HARDWALL", \
+ (unsigned long)__GFP_THISNODE, "GFP_THISNODE", \
+ (unsigned long)__GFP_RECLAIMABLE, "GFP_RECLAIMABLE", \
+ (unsigned long)__GFP_MOVABLE, "GFP_MOVABLE"

TRACE_EVENT(kmalloc,

@@ -70,12 +73,9 @@ TRACE_EVENT(kmalloc,
__entry->gfp_flags = gfp_flags;
),

- TP_printk("call_site=%lx ptr=%p bytes_req=%zu bytes_alloc=%zu gfp_flags=%s",
- __entry->call_site,
- __entry->ptr,
- __entry->bytes_req,
- __entry->bytes_alloc,
- show_gfp_flags(__entry->gfp_flags))
+ TP_FORMAT("call_site=<hex:call_site> ptr=<ptr:ptr> bytes_req=<int:bytes_req> "
+ "bytes_alloc=<int:bytes_alloc> gfp_flags=<mask:gfp_flags:|:"
+ show_gfp_flags())
);

TRACE_EVENT(kmem_cache_alloc,
@@ -104,12 +104,9 @@ TRACE_EVENT(kmem_cache_alloc,
__entry->gfp_flags = gfp_flags;
),

- TP_printk("call_site=%lx ptr=%p bytes_req=%zu bytes_alloc=%zu gfp_flags=%s",
- __entry->call_site,
- __entry->ptr,
- __entry->bytes_req,
- __entry->bytes_alloc,
- show_gfp_flags(__entry->gfp_flags))
+ TP_FORMAT("call_site=<hex:call_site> ptr=<ptr:ptr> bytes_req=<int:bytes_req> "
+ "bytes_alloc=<int:bytes_alloc> gfp_flags=<mask:gfp_flags:|:"
+ show_gfp_flags())
);

TRACE_EVENT(kmalloc_node,
@@ -141,13 +138,9 @@ TRACE_EVENT(kmalloc_node,
__entry->node = node;
),

- TP_printk("call_site=%lx ptr=%p bytes_req=%zu bytes_alloc=%zu gfp_flags=%s node=%d",
- __entry->call_site,
- __entry->ptr,
- __entry->bytes_req,
- __entry->bytes_alloc,
- show_gfp_flags(__entry->gfp_flags),
- __entry->node)
+ TP_FORMAT("call_site=<hex:call_site> ptr=<ptr:ptr> bytes_req=<int:bytes_req> "
+ "bytes_alloc=<int:bytes_alloc> gfp_flags=<mask:gfp_flags:|:"
+ show_gfp_flags(" node=<int:node>"))
);

TRACE_EVENT(kmem_cache_alloc_node,
@@ -179,13 +172,9 @@ TRACE_EVENT(kmem_cache_alloc_node,
__entry->node = node;
),

- TP_printk("call_site=%lx ptr=%p bytes_req=%zu bytes_alloc=%zu gfp_flags=%s node=%d",
- __entry->call_site,
- __entry->ptr,
- __entry->bytes_req,
- __entry->bytes_alloc,
- show_gfp_flags(__entry->gfp_flags),
- __entry->node)
+ TP_FORMAT("call_site=<hex:call_site> ptr=<ptr:ptr> bytes_req=<int:bytes_req> "
+ "bytes_alloc=<int:bytes_alloc> gfp_flags=<mask:gfp_flags:|:"
+ show_gfp_flags(" node=<int:node>"))
);

TRACE_EVENT(kfree,
@@ -204,7 +193,7 @@ TRACE_EVENT(kfree,
__entry->ptr = ptr;
),

- TP_printk("call_site=%lx ptr=%p", __entry->call_site, __entry->ptr)
+ TP_FORMAT("call_site=<hex:call_site> ptr=<ptr:ptr>")
);

TRACE_EVENT(kmem_cache_free,
@@ -223,7 +212,7 @@ TRACE_EVENT(kmem_cache_free,
__entry->ptr = ptr;
),

- TP_printk("call_site=%lx ptr=%p", __entry->call_site, __entry->ptr)
+ TP_FORMAT("call_site=<hex:call_site> ptr=<ptr:ptr>")
);
#endif /* _TRACE_KMEM_H */

--
1.6.3.1

--
--
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/