Dump文件数据存储格式(五)
七、线程列表流(ThreadListStream)
ThreadListStream流包含线程核心信息。它紧挨着异常信息流(ExceptionStream)。
异常信息流如下
0x678+0n168=0x720。而线程列表流如下
可知偏移是0x720,即证明杂项信息流是紧挨着系统信息流,大小有3796字节。
ThreadListStream包含的数据结构如下:
typedef struct _MINIDUMP_THREAD_LIST { ULONG32 NumberOfThreads; MINIDUMP_THREAD Threads[0]; } MINIDUMP_THREAD_LIST, *PMINIDUMP_THREAD_LIST;
成员如下:
NumberOfThreads
线程数量的个数
Threads
一个 MINIDUMP_THREAD 结构的数组.
我们可知,线程列表流就是MINIDUMP_THREAD的数组流。而MINIDUMP_THREAD结构如下
typedef struct _MINIDUMP_THREAD { ULONG32 ThreadId; ULONG32 SuspendCount; ULONG32 PriorityClass; ULONG32 Priority; ULONG64 Teb; MINIDUMP_MEMORY_DESCRIPTOR Stack; MINIDUMP_LOCATION_DESCRIPTOR ThreadContext; } MINIDUMP_THREAD, *PMINIDUMP_THREAD;
这个结构包含特定线程的信息。成员如下:
ThreadId
线程标识
SuspendCount
线程的挂起计数。如果挂起计数大于零,则线程被挂起;否则,线程不挂起。最大值为MAXIMUM_SUSPEND_COUNT。
PriorityClass
线程的优先级类别
Priority
线程的优先级。
Teb
Stack
一个MINIDUMP_MEMORY_DESCRIPTOR 结构,指向线程栈.
ThreadContext
一个 MINIDUMP_LOCATION_DESCRIPTOR 结构.指向线程上下文
MINIDUMP_MEMORY_DESCRIPTOR结构是描述一定范围的内存。如下
typedef struct _MINIDUMP_MEMORY_DESCRIPTOR { ULONG64 StartOfMemoryRange; MINIDUMP_LOCATION_DESCRIPTOR Memory; } MINIDUMP_MEMORY_DESCRIPTOR, *PMINIDUMP_MEMORY_DESCRIPTOR;
成员如下:
StartOfMemoryRange
内存范围的起始地址。
Memory
一个MINIDUMP_LOCATION_DESCRIPTOR 结构.指向栈信息在文件里的偏移
从以上信息,我们可知,平时我们调试时,执行~*kb等指令的展示的数据主要就来源这个流了。