1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-30 15:32:52 +01:00
llvm-mirror/test/MC/MachO/i386-large-relocations.s
Jim Grosbach 22a8871d1f X86_32: Large Symbol+Offset relocations.
If the offset is more than 24-bits, it won't fit in a scattered
relocation offset field, so we fall back to using a non-scattered
relocation.

rdar://12358909

llvm-svn: 164724
2012-09-26 21:27:45 +00:00

37 lines
1.0 KiB
ArmAsm

// RUN: llvm-mc -triple i386-apple-darwin10 %s -filetype=obj -o - | macho-dump | FileCheck %s
.space 0x1ed280
.section __DATA,__const
.align 4
.space 0x5181020
_foo:
.long _bar
.long 0
.long _bar+8
.long _bar+24
.long 0
.long _bar+16
.zerofill __DATA,__bss,__dummy,0x5d780
.zerofill __DATA,__bss,_bar,48,4
// Normally scattered relocations are used for sym+offset expressions. When
// the value exceeds 24-bits, however, it's outside what MachO can encode,
// so the assembler falls back to non-scattered relocations.
// rdar://12358909
// CHECK: ('_relocations', [
// CHECK: # Relocation 0
// CHECK: (('word-0', 0x5181034),
// CHECK: ('word-1', 0x4000003)),
// CHECK: # Relocation 1
// CHECK: (('word-0', 0x518102c),
// CHECK: ('word-1', 0x4000003)),
// CHECK: # Relocation 2
// CHECK: (('word-0', 0x5181028),
// CHECK: ('word-1', 0x4000003)),
// CHECK: # Relocation 3
// CHECK: (('word-0', 0x5181020),
// CHECK: ('word-1', 0x4000003)),
// CHECK: ])