mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 53d884a667
			
		
	
	
		53d884a667
		
	
	
	
	
		
			
			Some trace event formats print PFNs as hex while others print them as
decimal.  This is rather annoying when attempting to grep through traces
to understand what's going on with a particular page.
 $ git grep -ho 'pfn=[0x%lu]\+' include/trace/events/ | sort | uniq -c
      11 pfn=0x%lx
      12 pfn=%lu
       2 pfn=%lx
Printing as hex is in the majority in the trace events, and all the normal
printks in mm/ also print PFNs as hex, so change all the PFN formats in
the trace events to use 0x%lx.
Link: https://lkml.kernel.org/r/20210602092608.1493-1-vincent.whitchurch@axis.com
Signed-off-by: Vincent Whitchurch <vincent.whitchurch@axis.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jesper Dangaard Brouer <hawk@kernel.org>
Cc: Ilias Apalodimas <ilias.apalodimas@linaro.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
	
			
		
			
				
	
	
		
			118 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #undef TRACE_SYSTEM
 | |
| #define TRACE_SYSTEM page_pool
 | |
| 
 | |
| #if !defined(_TRACE_PAGE_POOL_H) || defined(TRACE_HEADER_MULTI_READ)
 | |
| #define      _TRACE_PAGE_POOL_H
 | |
| 
 | |
| #include <linux/types.h>
 | |
| #include <linux/tracepoint.h>
 | |
| 
 | |
| #include <trace/events/mmflags.h>
 | |
| #include <net/page_pool.h>
 | |
| 
 | |
| TRACE_EVENT(page_pool_release,
 | |
| 
 | |
| 	TP_PROTO(const struct page_pool *pool,
 | |
| 		 s32 inflight, u32 hold, u32 release),
 | |
| 
 | |
| 	TP_ARGS(pool, inflight, hold, release),
 | |
| 
 | |
| 	TP_STRUCT__entry(
 | |
| 		__field(const struct page_pool *, pool)
 | |
| 		__field(s32,	inflight)
 | |
| 		__field(u32,	hold)
 | |
| 		__field(u32,	release)
 | |
| 		__field(u64,	cnt)
 | |
| 	),
 | |
| 
 | |
| 	TP_fast_assign(
 | |
| 		__entry->pool		= pool;
 | |
| 		__entry->inflight	= inflight;
 | |
| 		__entry->hold		= hold;
 | |
| 		__entry->release	= release;
 | |
| 		__entry->cnt		= pool->destroy_cnt;
 | |
| 	),
 | |
| 
 | |
| 	TP_printk("page_pool=%p inflight=%d hold=%u release=%u cnt=%llu",
 | |
| 		__entry->pool, __entry->inflight, __entry->hold,
 | |
| 		__entry->release, __entry->cnt)
 | |
| );
 | |
| 
 | |
| TRACE_EVENT(page_pool_state_release,
 | |
| 
 | |
| 	TP_PROTO(const struct page_pool *pool,
 | |
| 		 const struct page *page, u32 release),
 | |
| 
 | |
| 	TP_ARGS(pool, page, release),
 | |
| 
 | |
| 	TP_STRUCT__entry(
 | |
| 		__field(const struct page_pool *,	pool)
 | |
| 		__field(const struct page *,		page)
 | |
| 		__field(u32,				release)
 | |
| 		__field(unsigned long,			pfn)
 | |
| 	),
 | |
| 
 | |
| 	TP_fast_assign(
 | |
| 		__entry->pool		= pool;
 | |
| 		__entry->page		= page;
 | |
| 		__entry->release	= release;
 | |
| 		__entry->pfn		= page_to_pfn(page);
 | |
| 	),
 | |
| 
 | |
| 	TP_printk("page_pool=%p page=%p pfn=0x%lx release=%u",
 | |
| 		  __entry->pool, __entry->page, __entry->pfn, __entry->release)
 | |
| );
 | |
| 
 | |
| TRACE_EVENT(page_pool_state_hold,
 | |
| 
 | |
| 	TP_PROTO(const struct page_pool *pool,
 | |
| 		 const struct page *page, u32 hold),
 | |
| 
 | |
| 	TP_ARGS(pool, page, hold),
 | |
| 
 | |
| 	TP_STRUCT__entry(
 | |
| 		__field(const struct page_pool *,	pool)
 | |
| 		__field(const struct page *,		page)
 | |
| 		__field(u32,				hold)
 | |
| 		__field(unsigned long,			pfn)
 | |
| 	),
 | |
| 
 | |
| 	TP_fast_assign(
 | |
| 		__entry->pool	= pool;
 | |
| 		__entry->page	= page;
 | |
| 		__entry->hold	= hold;
 | |
| 		__entry->pfn	= page_to_pfn(page);
 | |
| 	),
 | |
| 
 | |
| 	TP_printk("page_pool=%p page=%p pfn=0x%lx hold=%u",
 | |
| 		  __entry->pool, __entry->page, __entry->pfn, __entry->hold)
 | |
| );
 | |
| 
 | |
| TRACE_EVENT(page_pool_update_nid,
 | |
| 
 | |
| 	TP_PROTO(const struct page_pool *pool, int new_nid),
 | |
| 
 | |
| 	TP_ARGS(pool, new_nid),
 | |
| 
 | |
| 	TP_STRUCT__entry(
 | |
| 		__field(const struct page_pool *, pool)
 | |
| 		__field(int,			  pool_nid)
 | |
| 		__field(int,			  new_nid)
 | |
| 	),
 | |
| 
 | |
| 	TP_fast_assign(
 | |
| 		__entry->pool		= pool;
 | |
| 		__entry->pool_nid	= pool->p.nid;
 | |
| 		__entry->new_nid	= new_nid;
 | |
| 	),
 | |
| 
 | |
| 	TP_printk("page_pool=%p pool_nid=%d new_nid=%d",
 | |
| 		  __entry->pool, __entry->pool_nid, __entry->new_nid)
 | |
| );
 | |
| 
 | |
| #endif /* _TRACE_PAGE_POOL_H */
 | |
| 
 | |
| /* This part must be outside protection */
 | |
| #include <trace/define_trace.h>
 |