289 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			289 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
| // 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: }
 |