
Recent versions of GNU binutils starting from 2.39 support symbol+offset lookup in addition to the usual numeric address lookup. This change adds symbol lookup to llvm-symbolize and llvm-addr2line. Now llvm-symbolize behaves closer to GNU addr2line, - if the value specified as address in command line or input stream is not a number, it is treated as a symbol name. For example: llvm-symbolize --obj=abc.so func_22 llvm-symbolize --obj=abc.so "CODE func_22" This lookup is now supported only for functions. Specification with offset is not supported yet. This is a recommit of 2b27948783e4bbc1132d3220d8517ef62607b558, reverted in 39fec5457c0925bd39f67f63fe17391584e08258 because the test llvm/test/Support/interrupts.test started failing on Windows. The test was changed in 18f036d0105589c3175bb51a518c5d272dae61e2 and is also updated in this commit. Differential Revision: https://reviews.llvm.org/D149759
45 lines
1.4 KiB
Plaintext
45 lines
1.4 KiB
Plaintext
## Show that SIGINT and similar signals don't cause crash messages to be
|
|
## reported.
|
|
# RUN: %python %s wrapper llvm-symbolizer 2> %t.err
|
|
# RUN: FileCheck --input-file=%t.err %s
|
|
|
|
# CHECK: {{.*}} error: 'foo': {{[Nn]}}o such file or directory
|
|
# CHECK-NOT: {{.+}}
|
|
|
|
import os
|
|
import signal
|
|
import subprocess
|
|
import sys
|
|
import time
|
|
|
|
def run_symbolizer():
|
|
proc = subprocess.Popen([sys.argv[2]], stdout=subprocess.PIPE,
|
|
stdin=subprocess.PIPE, stderr=sys.stderr)
|
|
# Write then read some output to ensure the process has started fully.
|
|
proc.stdin.write(b'foo bar\n')
|
|
proc.stdin.flush()
|
|
proc.stdout.readline()
|
|
# Windows handles signals differently.
|
|
if os.name == 'nt':
|
|
os.kill(0, signal.CTRL_BREAK_EVENT)
|
|
else:
|
|
proc.send_signal(signal.SIGINT)
|
|
|
|
# On Windows, this function spawns the subprocess in its own (hidden) console,
|
|
# so that signals do not interfere with the calling test. This isn't necessary
|
|
# on other systems.
|
|
def run_wrapper():
|
|
args = [sys.executable, __file__, 'symbolizer'] + sys.argv[2:]
|
|
if os.name == 'nt':
|
|
startupinfo = subprocess.STARTUPINFO()
|
|
startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOW
|
|
subprocess.run(args, stderr=sys.stderr, startupinfo=startupinfo,
|
|
creationflags=subprocess.CREATE_NEW_CONSOLE)
|
|
else:
|
|
subprocess.run(args, stderr=sys.stderr)
|
|
|
|
if sys.argv[1] == 'wrapper':
|
|
run_wrapper()
|
|
else:
|
|
run_symbolizer()
|