From cf418902550d9ae2139ddd142d306b58dc5e7778 Mon Sep 17 00:00:00 2001 From: whitequark Date: Wed, 24 Feb 2016 17:44:07 +0000 Subject: [PATCH] Correctly display backtraces that contain inlined functions. --- artiq/compiler/targets.py | 25 ++++++++++++++++++------- artiq/coredevice/exceptions.py | 4 ++++ 2 files changed, 22 insertions(+), 7 deletions(-) diff --git a/artiq/compiler/targets.py b/artiq/compiler/targets.py index 81416ca7f..6f28ea0bf 100644 --- a/artiq/compiler/targets.py +++ b/artiq/compiler/targets.py @@ -151,20 +151,31 @@ class Target: if addresses == []: return [] - # Addresses point one instruction past the jump; offset them back by 1. - offset_addresses = [hex(addr - 1) for addr in addresses] - with RunTool([self.triple + "-addr2line", "--functions", "--inlines", + offset_addresses = [hex(addr) for addr in addresses] + with RunTool([self.triple + "-addr2line", "--addresses", "--functions", "--inlines", "--exe={library}"] + offset_addresses, library=library) \ as results: - lines = results["__stdout__"].rstrip().split("\n") + lines = iter(results["__stdout__"].rstrip().split("\n")) backtrace = [] - for function_name, location, address in zip(lines[::2], lines[1::2], addresses): + while True: + try: + address_or_function = next(lines) + except StopIteration: + break + if address_or_function[:2] == "0x": + address = int(address_or_function[2:], 16) + function = next(lines) + else: + address = backtrace[-1][4] # inlined + function = address_or_function + location = next(lines) + filename, line = location.rsplit(":", 1) - if filename == "??": + if filename == "??" or filename == "": continue # can't get column out of addr2line D: - backtrace.append((filename, int(line), -1, function_name, address)) + backtrace.append((filename, int(line), -1, function, address)) return backtrace class NativeTarget(Target): diff --git a/artiq/coredevice/exceptions.py b/artiq/coredevice/exceptions.py index 62d4c147a..05d9d1c29 100644 --- a/artiq/coredevice/exceptions.py +++ b/artiq/coredevice/exceptions.py @@ -27,6 +27,7 @@ class CoreException: def __str__(self): lines = [] lines.append("Core Device Traceback (most recent call last):") + last_address = 0 for (filename, line, column, function, address) in self.traceback: stub_globals = {"__name__": filename, "__loader__": source_loader} source_line = linecache.getline(filename, line, stub_globals) @@ -34,8 +35,11 @@ class CoreException: if address is None: formatted_address = "" + elif address == last_address: + formatted_address = " (inlined)" else: formatted_address = " (RA=0x{:x})".format(address) + last_address = address filename = filename.replace(artiq_dir, "") if column == -1: