lockdep: Fix backtraces
authorPeter Zijlstra <a.p.zijlstra@chello.nl>
Mon, 20 Jul 2009 13:27:04 +0000 (15:27 +0200)
committerIngo Molnar <mingo@elte.hu>
Sun, 2 Aug 2009 13:41:31 +0000 (15:41 +0200)
Truncate stupid -1 entries in backtraces.

Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <1248096665.15751.8816.camel@twins>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
kernel/lockdep.c

index 1cedb00e3e7a9d664165af50c8c1f7d5574d5265..2f0970297e30e9c3e06b1c6fc3c3b7e2007d2ee4 100644 (file)
@@ -367,11 +367,21 @@ static int save_trace(struct stack_trace *trace)
 
        save_stack_trace(trace);
 
+       /*
+        * Some daft arches put -1 at the end to indicate its a full trace.
+        *
+        * <rant> this is buggy anyway, since it takes a whole extra entry so a
+        * complete trace that maxes out the entries provided will be reported
+        * as incomplete, friggin useless </rant>
+        */
+       if (trace->entries[trace->nr_entries-1] == ULONG_MAX)
+               trace->nr_entries--;
+
        trace->max_entries = trace->nr_entries;
 
        nr_stack_trace_entries += trace->nr_entries;
 
-       if (nr_stack_trace_entries == MAX_STACK_TRACE_ENTRIES) {
+       if (nr_stack_trace_entries >= MAX_STACK_TRACE_ENTRIES-1) {
                if (!debug_locks_off_graph_unlock())
                        return 0;