2020-05-28 18:29:11 -07:00
|
|
|
"""Simple script that translates "Backtrace:" lines from the ESP output to files
|
|
|
|
and line numbers.
|
|
|
|
|
|
|
|
Run with: python3 tools/decode_backtrace.py <board>
|
|
|
|
|
|
|
|
Enter the backtrace line at the "? " prompt. CTRL-C to exit the script.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import subprocess
|
|
|
|
import sys
|
|
|
|
|
|
|
|
board = sys.argv[1]
|
|
|
|
print(board)
|
|
|
|
|
|
|
|
while True:
|
|
|
|
addresses = input("? ")
|
|
|
|
if addresses.startswith("Backtrace:"):
|
2021-03-15 19:27:36 +05:30
|
|
|
addresses = addresses[len("Backtrace:") :]
|
2020-05-28 18:29:11 -07:00
|
|
|
addresses = addresses.strip().split()
|
|
|
|
addresses = [address.split(":")[0] for address in addresses]
|
2021-03-15 19:27:36 +05:30
|
|
|
print("got", addresses)
|
|
|
|
subprocess.run(
|
|
|
|
["xtensa-esp32s2-elf-addr2line", "-e", "build-{}/firmware.elf".format(board)] + addresses
|
|
|
|
)
|