Index: test/tools/llvm-objdump/X86/disassemble-align.s =================================================================== --- /dev/null +++ test/tools/llvm-objdump/X86/disassemble-align.s @@ -0,0 +1,30 @@ +# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s | \ +# RUN: llvm-objdump -d -print-imm-hex - | sed 's/\t/ /g' | FileCheck -strict-whitespace %s + +# -w/--wide is ignored. llvm-objdump always produces wide output. +# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s | \ +# RUN: llvm-objdump -wd -print-imm-hex - | sed 's/\t/ /g' | FileCheck -strict-whitespace %s +# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s | \ +# RUN: llvm-objdump --wide -d -print-imm-hex - | sed 's/\t/ /g' | FileCheck -strict-whitespace %s + +# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s | \ +# RUN: llvm-objdump -d -print-imm-hex -no-show-raw-insn - | sed 's/\t/ /g' | \ +# RUN: FileCheck -check-prefix=NORAW -strict-whitespace %s + +# Instructions are expected to be aligned if the instruction in hex is not too long. + +# CHECK: 0: 55 pushq %rbp +# CHECK-NEXT: 1: 48 8b 05 56 34 12 00 movq 0x123456(%rip), %rax +# CHECK-NEXT: 8: 48 b8 54 55 55 55 55 55 55 55 movabsq $0x5555555555555554, %rax +# CHECK-NEXT: 12: c3 retq + +# NORAW: 0: pushq %rbp +# NORAW-NEXT: 1: movq 0x123456(%rip), %rax +# NORAW-NEXT: 8: movabsq $0x5555555555555554, %rax +# NORAW-NEXT: 12: retq + +.text + pushq %rbp + movq 0x123456(%rip),%rax + movabs $0x5555555555555554,%rax + ret Index: tools/llvm-objdump/llvm-objdump.cpp =================================================================== --- tools/llvm-objdump/llvm-objdump.cpp +++ tools/llvm-objdump/llvm-objdump.cpp @@ -303,6 +303,10 @@ cl::CommaSeparated, cl::aliasopt(DisassemblerOptions)); +static cl::opt + Wide("wide", cl::desc("Ignored for compatibility with GNU objdump")); +static cl::alias WideShort("w", cl::Grouping, cl::aliasopt(Wide)); + static StringRef ToolName; typedef std::vector> SectionSymbolsTy; @@ -602,16 +606,25 @@ std::vector *Rels = nullptr) { if (SP && (PrintSource || PrintLines)) SP->printSourceLine(OS, Address); - if (!NoLeadingAddr) + unsigned Column = 0; + if (!NoLeadingAddr) { OS << format("%8" PRIx64 ":", Address.Address); + Column += 9; + } if (!NoShowRawInsn) { OS << "\t"; + Column = (Column + 7) & -8; dumpBytes(Bytes, OS); + Column += 3 * Bytes.size(); } + // The output of printInst always starts with a tab. Print some spaces so + // that the tab advances to a tab stop. + unsigned TabStop = NoShowRawInsn ? 16 : 40; + OS.indent(Column < TabStop - 1 ? TabStop - 1 - Column : 7 - (Column & 7)); if (MI) IP.printInst(MI, OS, "", STI); else - OS << " "; + OS << "\t"; } }; PrettyPrinter PrettyPrinterInst;