perf lock: Always check min AND max wait time
When a lock is acquired after beeing contended, we update the wait time statistics for the given lock. But if the min wait time is updated, we don't check the max wait time. This is wrong because the first time we update the wait time, we want to update both min and max wait time. Before: Name acquired contended total wait (ns) max wait (ns) min wait (ns) key 8 1 21656 0 21656 After: Name acquired contended total wait (ns) max wait (ns) min wait (ns) key 8 1 21656 21656 21656 Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@elte.hu> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Paul Mackerras <paulus@samba.org> Cc: Hitoshi Mitake <mitake@dcl.info.waseda.ac.jp>
This commit is contained in:
parent
5efe08cf68
commit
90c0e5fc7b
@ -496,7 +496,7 @@ report_lock_acquired_event(struct trace_acquired_event *acquired_event,
|
|||||||
ls->wait_time_total += contended_term;
|
ls->wait_time_total += contended_term;
|
||||||
if (contended_term < ls->wait_time_min)
|
if (contended_term < ls->wait_time_min)
|
||||||
ls->wait_time_min = contended_term;
|
ls->wait_time_min = contended_term;
|
||||||
else if (ls->wait_time_max < contended_term)
|
if (ls->wait_time_max < contended_term)
|
||||||
ls->wait_time_max = contended_term;
|
ls->wait_time_max = contended_term;
|
||||||
break;
|
break;
|
||||||
case SEQ_STATE_RELEASED:
|
case SEQ_STATE_RELEASED:
|
||||||
|
Loading…
Reference in New Issue
Block a user