Re: [PATCH v2 4/5] mm/compaction: more trace to understand when/why compaction start/finish

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 01/13/2015 08:16 AM, Joonsoo Kim wrote:
> On Mon, Jan 12, 2015 at 04:53:53PM +0100, Vlastimil Babka wrote:
>> On 01/12/2015 09:21 AM, Joonsoo Kim wrote:
>> > It is not well analyzed that when/why compaction start/finish or not. With
>> > these new tracepoints, we can know much more about start/finish reason of
>> > compaction. I can find following bug with these tracepoint.
>> > 
>> > http://www.spinics.net/lists/linux-mm/msg81582.html
>> > 
>> > Signed-off-by: Joonsoo Kim <iamjoonsoo.kim@xxxxxxx>
>> > ---
>> >  include/linux/compaction.h        |    3 ++
>> >  include/trace/events/compaction.h |   94 +++++++++++++++++++++++++++++++++++++
>> >  mm/compaction.c                   |   41 ++++++++++++++--
>> >  3 files changed, 134 insertions(+), 4 deletions(-)
>> > 
>> > diff --git a/include/linux/compaction.h b/include/linux/compaction.h
>> > index a9547b6..d82181a 100644
>> > --- a/include/linux/compaction.h
>> > +++ b/include/linux/compaction.h
>> > @@ -12,6 +12,9 @@
>> >  #define COMPACT_PARTIAL		3
>> >  /* The full zone was compacted */
>> >  #define COMPACT_COMPLETE	4
>> > +/* For more detailed tracepoint output */
>> > +#define COMPACT_NO_SUITABLE_PAGE	5
>> > +#define COMPACT_NOT_SUITABLE_ZONE	6
>> >  /* When adding new state, please change compaction_status_string, too */
>> >  
>> >  /* Used to signal whether compaction detected need_sched() or lock contention */
>> > diff --git a/include/trace/events/compaction.h b/include/trace/events/compaction.h
>> > index 139020b..839dd4f 100644
>> > --- a/include/trace/events/compaction.h
>> > +++ b/include/trace/events/compaction.h
>> > @@ -164,6 +164,100 @@ TRACE_EVENT(mm_compaction_end,
>> >  		compaction_status_string[__entry->status])
>> >  );
>> >  
>> > +TRACE_EVENT(mm_compaction_try_to_compact_pages,
>> > +
>> > +	TP_PROTO(
>> > +		int order,
>> > +		gfp_t gfp_mask,
>> > +		enum migrate_mode mode,
>> > +		int alloc_flags,
>> > +		int classzone_idx),
>> 
>> I wonder if alloc_flags and classzone_idx is particularly useful. It affects the
>> watermark checks, but those are a bit of blackbox anyway.
> 
> Yes, I think so. How about printing gfp_flag rather than these? It would
> tell us migratetype and other information so would be useful.

Yeah gfp_mask should be enough.

> 
> Thanks.
> 

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@xxxxxxxxx.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@xxxxxxxxx";> email@xxxxxxxxx </a>



[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]