mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-13 23:18:51 +00:00
For llvm-objdump for Mach-O files add printing of
the ARM_THREAD_STATE in the same format as otool-classic(1) on darwin. Also remove an extra space in printing the initprot to make the output match otool-classic(1) on darwin. rdar://28851457 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@284852 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
be29b1044e
commit
bbe3a735a8
BIN
test/tools/llvm-objdump/ARM/Inputs/thumb.armv7m
Executable file
BIN
test/tools/llvm-objdump/ARM/Inputs/thumb.armv7m
Executable file
Binary file not shown.
@ -1,6 +1,8 @@
|
|||||||
// RUN: llvm-objdump -p %p/Inputs/hello.obj.macho-arm | FileCheck %s
|
// RUN: llvm-objdump -p %p/Inputs/hello.obj.macho-arm | FileCheck %s
|
||||||
// RUN: llvm-objdump -p %p/Inputs/hello.exe.macho-arm \
|
// RUN: llvm-objdump -p %p/Inputs/hello.exe.macho-arm \
|
||||||
// RUN: | FileCheck %s -check-prefix=EXE
|
// RUN: | FileCheck %s -check-prefix=EXE
|
||||||
|
// RUN: llvm-objdump -macho -private-headers %p/Inputs/thumb.armv7m \
|
||||||
|
// RUN: | FileCheck %s -check-prefix=THREAD
|
||||||
|
|
||||||
CHECK: Mach header
|
CHECK: Mach header
|
||||||
CHECK: magic cputype cpusubtype caps filetype ncmds sizeofcmds flags
|
CHECK: magic cputype cpusubtype caps filetype ncmds sizeofcmds flags
|
||||||
@ -343,3 +345,14 @@ EXE: cmd LC_DYLIB_CODE_SIGN_DRS
|
|||||||
EXE: cmdsize 16
|
EXE: cmdsize 16
|
||||||
EXE: dataoff 49244
|
EXE: dataoff 49244
|
||||||
EXE: datasize 20
|
EXE: datasize 20
|
||||||
|
|
||||||
|
THREAD: Load command 6
|
||||||
|
THREAD: cmd LC_UNIXTHREAD
|
||||||
|
THREAD: cmdsize 84
|
||||||
|
THREAD: flavor ARM_THREAD_STATE
|
||||||
|
THREAD: count ARM_THREAD_STATE_COUNT
|
||||||
|
THREAD: r0 0x00000000 r1 0x00000000 r2 0x00000000 r3 0x00000000
|
||||||
|
THREAD: r4 0x00000000 r5 0x00000000 r6 0x00000000 r7 0x00000000
|
||||||
|
THREAD: r8 0x00000000 r9 0x00000000 r10 0x00000000 r11 0x00000000
|
||||||
|
THREAD: r12 0x00000000 sp 0x00000000 lr 0x00000000 pc 0x00001fff
|
||||||
|
THREAD: cpsr 0x00000000
|
||||||
|
@ -7745,9 +7745,9 @@ static void PrintSegmentCommand(uint32_t cmd, uint32_t cmdsize,
|
|||||||
if ((initprot &
|
if ((initprot &
|
||||||
~(MachO::VM_PROT_READ | MachO::VM_PROT_WRITE |
|
~(MachO::VM_PROT_READ | MachO::VM_PROT_WRITE |
|
||||||
MachO::VM_PROT_EXECUTE)) != 0)
|
MachO::VM_PROT_EXECUTE)) != 0)
|
||||||
outs() << " initprot ?" << format("0x%08" PRIx32, initprot) << "\n";
|
outs() << " initprot ?" << format("0x%08" PRIx32, initprot) << "\n";
|
||||||
else {
|
else {
|
||||||
outs() << " initprot ";
|
outs() << " initprot ";
|
||||||
outs() << ((initprot & MachO::VM_PROT_READ) ? "r" : "-");
|
outs() << ((initprot & MachO::VM_PROT_READ) ? "r" : "-");
|
||||||
outs() << ((initprot & MachO::VM_PROT_WRITE) ? "w" : "-");
|
outs() << ((initprot & MachO::VM_PROT_WRITE) ? "w" : "-");
|
||||||
outs() << ((initprot & MachO::VM_PROT_EXECUTE) ? "x\n" : "-\n");
|
outs() << ((initprot & MachO::VM_PROT_EXECUTE) ? "x\n" : "-\n");
|
||||||
@ -8640,6 +8640,26 @@ static void Print_x86_exception_state_t(MachO::x86_exception_state64_t &exc64) {
|
|||||||
outs() << " faultvaddr " << format("0x%016" PRIx64, exc64.faultvaddr) << "\n";
|
outs() << " faultvaddr " << format("0x%016" PRIx64, exc64.faultvaddr) << "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void Print_arm_thread_state32_t(MachO::arm_thread_state32_t &cpu32) {
|
||||||
|
outs() << "\t r0 " << format("0x%08" PRIx32, cpu32.r[0]);
|
||||||
|
outs() << " r1 " << format("0x%08" PRIx32, cpu32.r[1]);
|
||||||
|
outs() << " r2 " << format("0x%08" PRIx32, cpu32.r[2]);
|
||||||
|
outs() << " r3 " << format("0x%08" PRIx32, cpu32.r[3]) << "\n";
|
||||||
|
outs() << "\t r4 " << format("0x%08" PRIx32, cpu32.r[4]);
|
||||||
|
outs() << " r5 " << format("0x%08" PRIx32, cpu32.r[5]);
|
||||||
|
outs() << " r6 " << format("0x%08" PRIx32, cpu32.r[6]);
|
||||||
|
outs() << " r7 " << format("0x%08" PRIx32, cpu32.r[7]) << "\n";
|
||||||
|
outs() << "\t r8 " << format("0x%08" PRIx32, cpu32.r[8]);
|
||||||
|
outs() << " r9 " << format("0x%08" PRIx32, cpu32.r[9]);
|
||||||
|
outs() << " r10 " << format("0x%08" PRIx32, cpu32.r[10]);
|
||||||
|
outs() << " r11 " << format("0x%08" PRIx32, cpu32.r[11]) << "\n";
|
||||||
|
outs() << "\t r12 " << format("0x%08" PRIx32, cpu32.r[12]);
|
||||||
|
outs() << " sp " << format("0x%08" PRIx32, cpu32.sp);
|
||||||
|
outs() << " lr " << format("0x%08" PRIx32, cpu32.lr);
|
||||||
|
outs() << " pc " << format("0x%08" PRIx32, cpu32.pc) << "\n";
|
||||||
|
outs() << "\t cpsr " << format("0x%08" PRIx32, cpu32.cpsr) << "\n";
|
||||||
|
}
|
||||||
|
|
||||||
static void PrintThreadCommand(MachO::thread_command t, const char *Ptr,
|
static void PrintThreadCommand(MachO::thread_command t, const char *Ptr,
|
||||||
bool isLittleEndian, uint32_t cputype) {
|
bool isLittleEndian, uint32_t cputype) {
|
||||||
if (t.cmd == MachO::LC_THREAD)
|
if (t.cmd == MachO::LC_THREAD)
|
||||||
@ -8796,6 +8816,53 @@ static void PrintThreadCommand(MachO::thread_command t, const char *Ptr,
|
|||||||
begin += count * sizeof(uint32_t);
|
begin += count * sizeof(uint32_t);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (cputype == MachO::CPU_TYPE_ARM) {
|
||||||
|
while (begin < end) {
|
||||||
|
if (end - begin > (ptrdiff_t)sizeof(uint32_t)) {
|
||||||
|
memcpy((char *)&flavor, begin, sizeof(uint32_t));
|
||||||
|
begin += sizeof(uint32_t);
|
||||||
|
} else {
|
||||||
|
flavor = 0;
|
||||||
|
begin = end;
|
||||||
|
}
|
||||||
|
if (isLittleEndian != sys::IsLittleEndianHost)
|
||||||
|
sys::swapByteOrder(flavor);
|
||||||
|
if (end - begin > (ptrdiff_t)sizeof(uint32_t)) {
|
||||||
|
memcpy((char *)&count, begin, sizeof(uint32_t));
|
||||||
|
begin += sizeof(uint32_t);
|
||||||
|
} else {
|
||||||
|
count = 0;
|
||||||
|
begin = end;
|
||||||
|
}
|
||||||
|
if (isLittleEndian != sys::IsLittleEndianHost)
|
||||||
|
sys::swapByteOrder(count);
|
||||||
|
if (flavor == MachO::ARM_THREAD_STATE) {
|
||||||
|
outs() << " flavor ARM_THREAD_STATE\n";
|
||||||
|
if (count == MachO::ARM_THREAD_STATE_COUNT)
|
||||||
|
outs() << " count ARM_THREAD_STATE_COUNT\n";
|
||||||
|
else
|
||||||
|
outs() << " count " << count
|
||||||
|
<< " (not ARM_THREAD_STATE_COUNT)\n";
|
||||||
|
MachO::arm_thread_state32_t cpu32;
|
||||||
|
left = end - begin;
|
||||||
|
if (left >= sizeof(MachO::arm_thread_state32_t)) {
|
||||||
|
memcpy(&cpu32, begin, sizeof(MachO::arm_thread_state32_t));
|
||||||
|
begin += sizeof(MachO::arm_thread_state32_t);
|
||||||
|
} else {
|
||||||
|
memset(&cpu32, '\0', sizeof(MachO::arm_thread_state32_t));
|
||||||
|
memcpy(&cpu32, begin, left);
|
||||||
|
begin += left;
|
||||||
|
}
|
||||||
|
if (isLittleEndian != sys::IsLittleEndianHost)
|
||||||
|
swapStruct(cpu32);
|
||||||
|
Print_arm_thread_state32_t(cpu32);
|
||||||
|
} else {
|
||||||
|
outs() << " flavor " << flavor << " (unknown)\n";
|
||||||
|
outs() << " count " << count << "\n";
|
||||||
|
outs() << " state (unknown)\n";
|
||||||
|
begin += count * sizeof(uint32_t);
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
while (begin < end) {
|
while (begin < end) {
|
||||||
if (end - begin > (ptrdiff_t)sizeof(uint32_t)) {
|
if (end - begin > (ptrdiff_t)sizeof(uint32_t)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user