
This is a follow-up patch to 6f7835f309b9. As explained previously, when running from an IDE, it can happen that the IDE imports some lldb scripts by itself. If the user also tries to import these commands, lldb will show the following message: ``` error: cannot add command: user command exists and force replace not set ``` This message is confusing to the user, because it suggests that the command import failed and that the execution should stop. However, in this case, lldb will continue the execution with the command added previously by the user. To prevent that, this patch updates every first-party lldb-packaged custom commands to override commands that were pre-imported in lldb. Differential Revision: https://reviews.llvm.org/D140293 Signed-off-by: Med Ismail Bennani <medismail.bennani@gmail.com>
69 lines
2.6 KiB
Python
Executable File
69 lines
2.6 KiB
Python
Executable File
#!/usr/bin/env python
|
|
import lldb
|
|
import optparse
|
|
import shlex
|
|
|
|
|
|
def stack_frames(debugger, command, result, dict):
|
|
command_args = shlex.split(command)
|
|
usage = "usage: %prog [options] <PATH> [PATH ...]"
|
|
description = '''This command will enumerate all stack frames, print the stack size for each, and print an aggregation of which functions have the largest stack frame sizes at the end.'''
|
|
parser = optparse.OptionParser(
|
|
description=description, prog='ls', usage=usage)
|
|
parser.add_option(
|
|
'-v',
|
|
'--verbose',
|
|
action='store_true',
|
|
dest='verbose',
|
|
help='display verbose debug info',
|
|
default=False)
|
|
try:
|
|
(options, args) = parser.parse_args(command_args)
|
|
except:
|
|
return
|
|
|
|
target = debugger.GetSelectedTarget()
|
|
process = target.GetProcess()
|
|
|
|
frame_info = {}
|
|
for thread in process:
|
|
last_frame = None
|
|
print("thread %u" % (thread.id))
|
|
for frame in thread.frames:
|
|
if last_frame:
|
|
frame_size = 0
|
|
if frame.idx == 1:
|
|
if frame.fp == last_frame.fp:
|
|
# No frame one the first frame (might be right at the
|
|
# entry point)
|
|
first_frame_size = 0
|
|
frame_size = frame.fp - frame.sp
|
|
else:
|
|
# First frame that has a valid size
|
|
first_frame_size = last_frame.fp - last_frame.sp
|
|
print("<%#7x> %s" % (first_frame_size, last_frame))
|
|
if first_frame_size:
|
|
name = last_frame.name
|
|
if name not in frame_info:
|
|
frame_info[name] = first_frame_size
|
|
else:
|
|
frame_info[name] += first_frame_size
|
|
else:
|
|
# Second or higher frame
|
|
frame_size = frame.fp - last_frame.fp
|
|
print("<%#7x> %s" % (frame_size, frame))
|
|
if frame_size > 0:
|
|
name = frame.name
|
|
if name not in frame_info:
|
|
frame_info[name] = frame_size
|
|
else:
|
|
frame_info[name] += frame_size
|
|
last_frame = frame
|
|
print(frame_info)
|
|
|
|
|
|
def __lldb_init_module(debugger, internal_dict):
|
|
debugger.HandleCommand(
|
|
"command script add -o -f stacks.stack_frames stack_frames")
|
|
print("A new command called 'stack_frames' was added, type 'stack_frames --help' for more information.")
|