Files
clang-p2996/llvm/test/Support/interrupts.test
Serge Pavlov 1792852f86 [symbolizer] Change reaction on invalid input
If llvm-symbolizer finds a malformed command, it echoes it to the
standard output. New versions of binutils (starting from 2.39) allow to
specify an address by a symbols. Implementation of this feature in
llvm-symbolizer makes the current reaction on invalid input
inappropriate. Almost any invalid command may be treated as a symbol
name, so the right reaction should be "symbol not found" in such case.

The exception are commands that are recognized but have incorrect
syntax, like "FILE:FILE:". The utility must produce descriptive
diagnostic for such input and route it to the stderr.

This change implements the new reaction on invalid input and is a
prerequisite for implementation of symbol lookup in llvm-symbolizer.

Differential Revision: https://reviews.llvm.org/D157210
2023-08-30 17:54:37 +07:00

44 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: count 0 < %t.err
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)
# 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
proc = subprocess.Popen(args,
stderr=sys.stderr,
startupinfo=startupinfo,
creationflags=subprocess.CREATE_NEW_CONSOLE)
else:
proc = subprocess.Popen(args,
stderr=subprocess.PIPE)
if sys.argv[1] == 'wrapper':
run_wrapper()
else:
run_symbolizer()