Commit 2ffc970b authored by jacob.bramley's avatar jacob.bramley Committed by Commit bot

Fix ll_prof.py for static binaries.

BUG=

Review URL: https://codereview.chromium.org/1007613005

Cr-Commit-Position: refs/heads/master@{#27213}
parent 17ada20c
...@@ -711,6 +711,23 @@ class LibraryRepo(object): ...@@ -711,6 +711,23 @@ class LibraryRepo(object):
self.names = set() self.names = set()
self.ticks = {} self.ticks = {}
def HasDynamicSymbols(self, filename):
if filename.endswith(".ko"): return False
process = subprocess.Popen(
"%s -h %s" % (OBJDUMP_BIN, filename),
shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
pipe = process.stdout
try:
for line in pipe:
match = OBJDUMP_SECTION_HEADER_RE.match(line)
if match and match.group(1) == 'dynsym': return True
finally:
pipe.close()
assert process.wait() == 0, "Failed to objdump -h %s" % filename
return False
def Load(self, mmap_info, code_map, options): def Load(self, mmap_info, code_map, options):
# Skip kernel mmaps when requested using the fact that their tid # Skip kernel mmaps when requested using the fact that their tid
# is 0. # is 0.
...@@ -730,10 +747,10 @@ class LibraryRepo(object): ...@@ -730,10 +747,10 @@ class LibraryRepo(object):
# Unfortunately, section headers span two lines, so we have to # Unfortunately, section headers span two lines, so we have to
# keep the just seen section name (from the first line in each # keep the just seen section name (from the first line in each
# section header) in the after_section variable. # section header) in the after_section variable.
if mmap_info.filename.endswith(".ko"): if self.HasDynamicSymbols(mmap_info.filename):
dynamic_symbols = ""
else:
dynamic_symbols = "-T" dynamic_symbols = "-T"
else:
dynamic_symbols = ""
process = subprocess.Popen( process = subprocess.Popen(
"%s -h -t %s -C %s" % (OBJDUMP_BIN, dynamic_symbols, mmap_info.filename), "%s -h -t %s -C %s" % (OBJDUMP_BIN, dynamic_symbols, mmap_info.filename),
shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment