; REQUIRES: x86-registered-target && aarch64-registered-target && riscv-registered-target ; RUN: llc %s -mtriple=x86_64 -o - | FileCheck %s ; RUN: llc %s -mtriple=aarch64 -o - | FileCheck %s ; RUN: llc %s -mtriple=riscv64 -o - | FileCheck %s @vtable = dso_local unnamed_addr constant i32 trunc (i64 sub (i64 ptrtoint (ptr @rtti.proxy to i64), i64 ptrtoint (ptr @vtable to i64)) to i32), align 4 @vtable_with_offset = dso_local unnamed_addr constant [2 x i32] [i32 0, i32 trunc (i64 sub (i64 ptrtoint (ptr @rtti.proxy to i64), i64 ptrtoint (ptr @vtable_with_offset to i64)) to i32)], align 4 @vtable_with_negative_offset = dso_local unnamed_addr constant [2 x i32] [ i32 trunc ( i64 sub ( i64 ptrtoint (ptr @rtti.proxy to i64), i64 ptrtoint (ptr getelementptr inbounds ([2 x i32], ptr @vtable_with_negative_offset, i32 0, i32 1) to i64) ) to i32), i32 0 ], align 4 @rtti = external global i8, align 8 @rtti.proxy = linkonce_odr hidden unnamed_addr constant ptr @rtti ; CHECK-NOT: rtti.proxy ; CHECK-LABEL: vtable: ; CHECK-NEXT: .{{word|long}} rtti@GOTPCREL+0{{$}} ; CHECK-LABEL: vtable_with_offset: ; CHECK-NEXT: .{{word|long}} 0 ; CHECK-NEXT: .{{word|long}} rtti@GOTPCREL+4{{$}} ; CHECK-LABEL: vtable_with_negative_offset: ; CHECK-NEXT: .{{word|long}} rtti@GOTPCREL-4{{$}} ; CHECK-NEXT: .{{word|long}} 0