arch/tile: support new info op generated by compiler
authorChris Metcalf <cmetcalf@tilera.com>
Thu, 14 Oct 2010 20:46:22 +0000 (16:46 -0400)
committerChris Metcalf <cmetcalf@tilera.com>
Fri, 15 Oct 2010 19:39:25 +0000 (15:39 -0400)
This just syncs the backtracing support in the kernel to the
upstream backtrace library.

Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
arch/tile/include/asm/backtrace.h
arch/tile/kernel/backtrace.c

index 758ca4619d50017bffdec27c460edc2a95bfd38e..f18887d823999f8a7778defa2196ab10b586b81d 100644 (file)
@@ -146,7 +146,10 @@ enum {
 
        CALLER_SP_IN_R52_BASE = 4,
 
-       CALLER_SP_OFFSET_BASE = 8
+       CALLER_SP_OFFSET_BASE = 8,
+
+       /* Marks the entry point of certain functions. */
+       ENTRY_POINT_INFO_OP = 16
 };
 
 
index d3c41c1ff6bd9dae73908276cd7a41b1c70696a6..55a6a74974b4dad8c973484bcf2dc1934c34b309 100644 (file)
@@ -369,6 +369,10 @@ static void find_caller_pc_and_caller_sp(CallerLocation *location,
                                        /* Weird; reserved value, ignore it. */
                                        continue;
                                }
+                               if (info_operand & ENTRY_POINT_INFO_OP) {
+                                       /* This info op is ignored by the backtracer. */
+                                       continue;
+                               }
 
                                /* Skip info ops which are not in the
                                 * "one_ago" mode we want right now.