You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
289 lines
8.8 KiB
289 lines
8.8 KiB
// RUN: llvm-mc -triple i386-apple-darwin9 %s -filetype=obj -o - | llvm-readobj -file-headers -s -sd -r -t -macho-segment -macho-dysymtab -macho-indirect-symbols | FileCheck %s
|
|
|
|
# 1 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
# nop
|
|
# 0x90
|
|
.align 1, 0x90
|
|
ret
|
|
# 2 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
# xchg %ax,%ax
|
|
# 0x66, 0x90
|
|
.align 2, 0x90
|
|
ret
|
|
# 3 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
# nopl (%[re]ax)
|
|
# 0x0f, 0x1f, 0x00
|
|
.align 2, 0x90
|
|
ret
|
|
# 4 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
# nopl 0(%[re]ax)
|
|
# 0x0f, 0x1f, 0x40, 0x00
|
|
.align 3, 0x90
|
|
ret
|
|
# 5 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
ret
|
|
# nopl 0(%[re]ax,%[re]ax,1)
|
|
# 0x0f, 0x1f, 0x44, 0x00, 0x00
|
|
.align 3, 0x90
|
|
ret
|
|
# 6 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
# nopw 0(%[re]ax,%[re]ax,1)
|
|
# 0x66, 0x0f, 0x1f, 0x44, 0x00, 0x00
|
|
.align 3, 0x90
|
|
ret
|
|
# 7 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
# nopl 0L(%[re]ax)
|
|
# 0x0f, 0x1f, 0x80, 0x00, 0x00, 0x00, 0x00
|
|
.align 3, 0x90
|
|
ret
|
|
# 8 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
# nopl 0L(%[re]ax,%[re]ax,1)
|
|
# 0x0f, 0x1f, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00
|
|
.align 3, 0x90
|
|
ret
|
|
# 9 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
# nopw 0L(%[re]ax,%[re]ax,1)
|
|
# 0x66, 0x0f, 0x1f, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00
|
|
.align 4, 0x90
|
|
ret
|
|
# 10 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
# nopw %cs:0L(%[re]ax,%[re]ax,1)
|
|
# 0x66, 0x2e, 0x0f, 0x1f, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00
|
|
.align 4, 0x90
|
|
ret
|
|
# 11 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
# nopw %cs:0L(%[re]ax,%[re]ax,1)
|
|
# 0x66, 0x66, 0x2e, 0x0f, 0x1f, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00
|
|
.align 4, 0x90
|
|
ret
|
|
# 12 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
ret
|
|
ret
|
|
# nopw 0(%[re]ax,%[re]ax,1)
|
|
# nopw 0(%[re]ax,%[re]ax,1)
|
|
# 0x66, 0x0f, 0x1f, 0x44, 0x00, 0x00,
|
|
# 0x66, 0x0f, 0x1f, 0x44, 0x00, 0x00
|
|
.align 4, 0x90
|
|
ret
|
|
# 13 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
ret
|
|
# nopw 0(%[re]ax,%[re]ax,1)
|
|
# nopl 0L(%[re]ax)
|
|
# 0x66, 0x0f, 0x1f, 0x44, 0x00, 0x00,
|
|
# 0x0f, 0x1f, 0x80, 0x00, 0x00, 0x00, 0x00
|
|
.align 4, 0x90
|
|
ret
|
|
# 14 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
ret
|
|
# nopl 0L(%[re]ax)
|
|
# nopl 0L(%[re]ax)
|
|
# 0x0f, 0x1f, 0x80, 0x00, 0x00, 0x00, 0x00,
|
|
# 0x0f, 0x1f, 0x80, 0x00, 0x00, 0x00, 0x00
|
|
.align 4, 0x90
|
|
ret
|
|
# 15 byte nop test
|
|
.align 4, 0 # start with 16 byte alignment filled with zeros
|
|
ret
|
|
# nopl 0L(%[re]ax)
|
|
# nopl 0L(%[re]ax,%[re]ax,1)
|
|
# 0x0f, 0x1f, 0x80, 0x00, 0x00, 0x00, 0x00,
|
|
# 0x0f, 0x1f, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00
|
|
.align 4, 0x90
|
|
ret
|
|
|
|
# Only the .text sections gets optimal nops.
|
|
.section __TEXT,__const
|
|
f0:
|
|
.byte 0
|
|
.align 4, 0x90
|
|
.long 0
|
|
|
|
// CHECK: File: <stdin>
|
|
// CHECK: Format: Mach-O 32-bit i386
|
|
// CHECK: Arch: i386
|
|
// CHECK: AddressSize: 32bit
|
|
// CHECK: MachHeader {
|
|
// CHECK: Magic: Magic (0xFEEDFACE)
|
|
// CHECK: CpuType: X86 (0x7)
|
|
// CHECK: CpuSubType: CPU_SUBTYPE_I386_ALL (0x3)
|
|
// CHECK: FileType: Relocatable (0x1)
|
|
// CHECK: NumOfLoadCommands: 4
|
|
// CHECK: SizeOfLoadCommands: 312
|
|
// CHECK: Flags [ (0x0)
|
|
// CHECK: ]
|
|
// CHECK: }
|
|
// CHECK: Sections [
|
|
// CHECK: Section {
|
|
// CHECK: Index: 0
|
|
// CHECK: Name: __text (5F 5F 74 65 78 74 00 00 00 00 00 00 00 00 00 00)
|
|
// CHECK: Segment: __TEXT (5F 5F 54 45 58 54 00 00 00 00 00 00 00 00 00 00)
|
|
// CHECK: Address: 0x0
|
|
// CHECK: Size: 0x151
|
|
// CHECK: Offset: 340
|
|
// CHECK: Alignment: 4
|
|
// CHECK: RelocationOffset: 0x0
|
|
// CHECK: RelocationCount: 0
|
|
// CHECK: Type: 0x0
|
|
// CHECK: Attributes [ (0x800004)
|
|
// CHECK: PureInstructions (0x800000)
|
|
// CHECK: SomeInstructions (0x4)
|
|
// CHECK: ]
|
|
// CHECK: Reserved1: 0x0
|
|
// CHECK: Reserved2: 0x0
|
|
// CHECK: SectionData (
|
|
// CHECK: 0000: C390C300 00000000 00000000 00000000 |................|
|
|
// CHECK: 0010: C3C36690 C3000000 00000000 00000000 |..f.............|
|
|
// CHECK: 0020: C30F1F00 C3000000 00000000 00000000 |................|
|
|
// CHECK: 0030: C3C3C3C3 0F1F4000 C3000000 00000000 |......@.........|
|
|
// CHECK: 0040: C3C3C30F 1F440000 C3000000 00000000 |.....D..........|
|
|
// CHECK: 0050: C3C3660F 1F440000 C3000000 00000000 |..f..D..........|
|
|
// CHECK: 0060: C30F1F80 00000000 C3000000 00000000 |................|
|
|
// CHECK: 0070: C3C3C3C3 C3C3C3C3 C3000000 00000000 |................|
|
|
// CHECK: 0080: C3C3C3C3 C3C3C366 0F1F8400 00000000 |.......f........|
|
|
// CHECK: 0090: C3000000 00000000 00000000 00000000 |................|
|
|
// CHECK: 00A0: C3C3C3C3 C3C3C366 0F1F8400 00000000 |.......f........|
|
|
// CHECK: 00B0: C3000000 00000000 00000000 00000000 |................|
|
|
// CHECK: 00C0: C3C3C3C3 C366662E 0F1F8400 00000000 |.....ff.........|
|
|
// CHECK: 00D0: C3000000 00000000 00000000 00000000 |................|
|
|
// CHECK: 00E0: C3C3C3C3 6666662E 0F1F8400 00000000 |....fff.........|
|
|
// CHECK: 00F0: C3000000 00000000 00000000 00000000 |................|
|
|
// CHECK: 0100: C3C3C366 6666662E 0F1F8400 00000000 |...ffff.........|
|
|
// CHECK: 0110: C3000000 00000000 00000000 00000000 |................|
|
|
// CHECK: 0120: C3C36666 6666662E 0F1F8400 00000000 |..fffff.........|
|
|
// CHECK: 0130: C3000000 00000000 00000000 00000000 |................|
|
|
// CHECK: 0140: C3666666 6666662E 0F1F8400 00000000 |.ffffff.........|
|
|
// CHECK: 0150: C3 |.|
|
|
// CHECK: )
|
|
// CHECK: }
|
|
// CHECK: Section {
|
|
// CHECK: Index: 1
|
|
// CHECK: Name: __const (5F 5F 63 6F 6E 73 74 00 00 00 00 00 00 00 00 00)
|
|
// CHECK: Segment: __TEXT (5F 5F 54 45 58 54 00 00 00 00 00 00 00 00 00 00)
|
|
// CHECK: Address: 0x160
|
|
// CHECK: Size: 0x14
|
|
// CHECK: Offset: 692
|
|
// CHECK: Alignment: 4
|
|
// CHECK: RelocationOffset: 0x0
|
|
// CHECK: RelocationCount: 0
|
|
// CHECK: Type: 0x0
|
|
// CHECK: Attributes [ (0x0)
|
|
// CHECK: ]
|
|
// CHECK: Reserved1: 0x0
|
|
// CHECK: Reserved2: 0x0
|
|
// CHECK: SectionData (
|
|
// CHECK: 0000: 00909090 90909090 90909090 90909090 |................|
|
|
// CHECK: 0010: 00000000 |....|
|
|
// CHECK: )
|
|
// CHECK: }
|
|
// CHECK: ]
|
|
// CHECK: Relocations [
|
|
// CHECK: ]
|
|
// CHECK: Symbols [
|
|
// CHECK: Symbol {
|
|
// CHECK: Name: f0 (1)
|
|
// CHECK: Type: Section (0xE)
|
|
// CHECK: Section: __const (0x2)
|
|
// CHECK: RefType: UndefinedNonLazy (0x0)
|
|
// CHECK: Flags [ (0x0)
|
|
// CHECK: ]
|
|
// CHECK: Value: 0x160
|
|
// CHECK: }
|
|
// CHECK: ]
|
|
// CHECK: Indirect Symbols {
|
|
// CHECK: Number: 0
|
|
// CHECK: Symbols [
|
|
// CHECK: ]
|
|
// CHECK: }
|
|
// CHECK: Segment {
|
|
// CHECK: Cmd: LC_SEGMENT
|
|
// CHECK: Name:
|
|
// CHECK: Size: 192
|
|
// CHECK: vmaddr: 0x0
|
|
// CHECK: vmsize: 0x174
|
|
// CHECK: fileoff: 340
|
|
// CHECK: filesize: 372
|
|
// CHECK: maxprot: rwx
|
|
// CHECK: initprot: rwx
|
|
// CHECK: nsects: 2
|
|
// CHECK: flags: 0x0
|
|
// CHECK: }
|
|
// CHECK: Dysymtab {
|
|
// CHECK: ilocalsym: 0
|
|
// CHECK: nlocalsym: 1
|
|
// CHECK: iextdefsym: 1
|
|
// CHECK: nextdefsym: 0
|
|
// CHECK: iundefsym: 1
|
|
// CHECK: nundefsym: 0
|
|
// CHECK: tocoff: 0
|
|
// CHECK: ntoc: 0
|
|
// CHECK: modtaboff: 0
|
|
// CHECK: nmodtab: 0
|
|
// CHECK: extrefsymoff: 0
|
|
// CHECK: nextrefsyms: 0
|
|
// CHECK: indirectsymoff: 0
|
|
// CHECK: nindirectsyms: 0
|
|
// CHECK: extreloff: 0
|
|
// CHECK: nextrel: 0
|
|
// CHECK: locreloff: 0
|
|
// CHECK: nlocrel: 0
|
|
// CHECK: }
|