; REQUIRES: arm-registered-target ;; Verify that the generated assembly omits the RTTI proxy and uses the correct ;; relocations and addends. ; RUN: llc %s -mtriple=armv7 -o - | FileCheck %s ;; Verify that the generated object uses the correct relocations and addends. ; RUN: llc %s -filetype=obj -mtriple=thumbv7 -o %t.o ; RUN: llvm-readelf --relocs --hex-dump=.rodata %t.o | FileCheck --check-prefix=OBJ %s @vtable = dso_local unnamed_addr constant i32 sub (i32 ptrtoint (ptr @rtti.proxy to i32), i32 ptrtoint (ptr @vtable to i32)), align 4 @vtable_with_offset = dso_local unnamed_addr constant [2 x i32] [i32 0, i32 sub (i32 ptrtoint (ptr @rtti.proxy to i32), i32 ptrtoint (ptr @vtable_with_offset to i32))], align 4 @vtable_with_negative_offset = dso_local unnamed_addr constant [2 x i32] [ i32 sub ( i32 ptrtoint (ptr @rtti.proxy to i32), i32 ptrtoint (ptr getelementptr inbounds ([2 x i32], ptr @vtable_with_negative_offset, i32 0, i32 1) to i32) ), i32 0 ], align 4 @rtti = external global i8, align 4 @rtti.proxy = linkonce_odr hidden unnamed_addr constant ptr @rtti ; CHECK-NOT: rtti.proxy ; CHECK-LABEL: vtable: ; CHECK-NEXT: .long rtti(GOT_PREL)+0{{$}} ; CHECK-LABEL: vtable_with_offset: ; CHECK-NEXT: .long 0 ; CHECK-NEXT: .long rtti(GOT_PREL)+4{{$}} ; CHECK-LABEL: vtable_with_negative_offset: ; CHECK-NEXT: .long rtti(GOT_PREL)-4{{$}} ; CHECK-NEXT: .long 0 ; OBJ-LABEL: Relocation section '.rel.rodata' at offset [[#%#x,]] contains 3 entries: ; OBJ: {{^}}00000000 [[#]] R_ARM_GOT_PREL [[#]] rtti{{$}} ; OBJ-NEXT: {{^}}00000008 [[#]] R_ARM_GOT_PREL [[#]] rtti{{$}} ; OBJ-NEXT: {{^}}0000000c [[#]] R_ARM_GOT_PREL [[#]] rtti{{$}} ; OBJ-LABEL: Hex dump of section '.rodata': ; OBJ-NEXT: 0x00000000 00000000 00000000 04000000 fcffffff