Commit 21b2ea80 authored by ishell's avatar ishell Committed by Commit bot

Grokdump workaround for different layout of *_LIST structures written to minidumps on Mac.

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

Cr-Commit-Position: refs/heads/master@{#26456}
parent 87c79df9
...@@ -434,6 +434,12 @@ MINIDUMP_MEMORY_LIST = Descriptor([ ...@@ -434,6 +434,12 @@ MINIDUMP_MEMORY_LIST = Descriptor([
("ranges", lambda m: MINIDUMP_MEMORY_DESCRIPTOR.ctype * m.range_count) ("ranges", lambda m: MINIDUMP_MEMORY_DESCRIPTOR.ctype * m.range_count)
]) ])
MINIDUMP_MEMORY_LIST_Mac = Descriptor([
("range_count", ctypes.c_uint32),
("junk", ctypes.c_uint32),
("ranges", lambda m: MINIDUMP_MEMORY_DESCRIPTOR.ctype * m.range_count)
])
MINIDUMP_MEMORY_LIST64 = Descriptor([ MINIDUMP_MEMORY_LIST64 = Descriptor([
("range_count", ctypes.c_uint64), ("range_count", ctypes.c_uint64),
("base_rva", ctypes.c_uint64), ("base_rva", ctypes.c_uint64),
...@@ -455,6 +461,12 @@ MINIDUMP_THREAD_LIST = Descriptor([ ...@@ -455,6 +461,12 @@ MINIDUMP_THREAD_LIST = Descriptor([
("threads", lambda t: MINIDUMP_THREAD.ctype * t.thread_count) ("threads", lambda t: MINIDUMP_THREAD.ctype * t.thread_count)
]) ])
MINIDUMP_THREAD_LIST_Mac = Descriptor([
("thread_count", ctypes.c_uint32),
("junk", ctypes.c_uint32),
("threads", lambda t: MINIDUMP_THREAD.ctype * t.thread_count)
])
MINIDUMP_VS_FIXEDFILEINFO = Descriptor([ MINIDUMP_VS_FIXEDFILEINFO = Descriptor([
("dwSignature", ctypes.c_uint32), ("dwSignature", ctypes.c_uint32),
("dwStrucVersion", ctypes.c_uint32), ("dwStrucVersion", ctypes.c_uint32),
...@@ -489,6 +501,12 @@ MINIDUMP_MODULE_LIST = Descriptor([ ...@@ -489,6 +501,12 @@ MINIDUMP_MODULE_LIST = Descriptor([
("modules", lambda t: MINIDUMP_RAW_MODULE.ctype * t.number_of_modules) ("modules", lambda t: MINIDUMP_RAW_MODULE.ctype * t.number_of_modules)
]) ])
MINIDUMP_MODULE_LIST_Mac = Descriptor([
("number_of_modules", ctypes.c_uint32),
("junk", ctypes.c_uint32),
("modules", lambda t: MINIDUMP_RAW_MODULE.ctype * t.number_of_modules)
])
MINIDUMP_RAW_SYSTEM_INFO = Descriptor([ MINIDUMP_RAW_SYSTEM_INFO = Descriptor([
("processor_architecture", ctypes.c_uint16) ("processor_architecture", ctypes.c_uint16)
]) ])
...@@ -570,6 +588,9 @@ class MinidumpReader(object): ...@@ -570,6 +588,9 @@ class MinidumpReader(object):
DebugPrint(self.exception_context) DebugPrint(self.exception_context)
elif d.stream_type == MD_THREAD_LIST_STREAM: elif d.stream_type == MD_THREAD_LIST_STREAM:
thread_list = MINIDUMP_THREAD_LIST.Read(self.minidump, d.location.rva) thread_list = MINIDUMP_THREAD_LIST.Read(self.minidump, d.location.rva)
if ctypes.sizeof(thread_list) + 4 == d.location.data_size:
thread_list = MINIDUMP_THREAD_LIST_Mac.Read(
self.minidump, d.location.rva)
assert ctypes.sizeof(thread_list) == d.location.data_size assert ctypes.sizeof(thread_list) == d.location.data_size
DebugPrint(thread_list) DebugPrint(thread_list)
for thread in thread_list.threads: for thread in thread_list.threads:
...@@ -579,12 +600,19 @@ class MinidumpReader(object): ...@@ -579,12 +600,19 @@ class MinidumpReader(object):
assert self.module_list is None assert self.module_list is None
self.module_list = MINIDUMP_MODULE_LIST.Read( self.module_list = MINIDUMP_MODULE_LIST.Read(
self.minidump, d.location.rva) self.minidump, d.location.rva)
if ctypes.sizeof(self.module_list) + 4 == d.location.data_size:
self.module_list = MINIDUMP_MODULE_LIST_Mac.Read(
self.minidump, d.location.rva)
assert ctypes.sizeof(self.module_list) == d.location.data_size assert ctypes.sizeof(self.module_list) == d.location.data_size
DebugPrint(self.module_list)
elif d.stream_type == MD_MEMORY_LIST_STREAM: elif d.stream_type == MD_MEMORY_LIST_STREAM:
print >>sys.stderr, "Warning: This is not a full minidump!" print >>sys.stderr, "Warning: This is not a full minidump!"
assert self.memory_list is None assert self.memory_list is None
self.memory_list = MINIDUMP_MEMORY_LIST.Read( self.memory_list = MINIDUMP_MEMORY_LIST.Read(
self.minidump, d.location.rva) self.minidump, d.location.rva)
if ctypes.sizeof(self.memory_list) + 4 == d.location.data_size:
self.memory_list = MINIDUMP_MEMORY_LIST_Mac.Read(
self.minidump, d.location.rva)
assert ctypes.sizeof(self.memory_list) == d.location.data_size assert ctypes.sizeof(self.memory_list) == d.location.data_size
DebugPrint(self.memory_list) DebugPrint(self.memory_list)
elif d.stream_type == MD_MEMORY_64_LIST_STREAM: elif d.stream_type == MD_MEMORY_64_LIST_STREAM:
......
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