blob: daf46fa699b0fb4e2a3e2e480bf3955ff0da1a12 [file] [log] [blame]
; RUN: llc -mtriple=riscv64 < %s | FileCheck %s --match-full-lines
; RUN: llc -mtriple=riscv32 < %s | FileCheck %s --match-full-lines
declare void @extern_func()
; CHECK-LABEL: const:
; CHECK-NEXT: .word %pltpcrel(extern_func)
;; Note that for riscv32, the ptrtoint will actually upcast the ptr it to an
;; oversized 64-bit pointer that eventually gets truncated. This isn't needed
;; for riscv32, but this unifies the RV64 and RV32 test cases.
@const = dso_local constant i32 trunc (i64 sub (i64 ptrtoint (ptr dso_local_equivalent @extern_func to i64), i64 ptrtoint (ptr @const to i64)) to i32)
@_ZTV1B = dso_local constant { [7 x i32] } { [7 x i32] [
i32 0,
i32 0,
i32 trunc (i64 sub (i64 ptrtoint (ptr dso_local_equivalent @f0 to i64), i64 ptrtoint (ptr getelementptr inbounds ({ [7 x i32] }, ptr @_ZTV1B, i32 0, i32 0, i32 2) to i64)) to i32),
i32 trunc (i64 sub (i64 ptrtoint (ptr dso_local_equivalent @f1 to i64), i64 ptrtoint (ptr getelementptr inbounds ({ [7 x i32] }, ptr @_ZTV1B, i32 0, i32 0, i32 2) to i64)) to i32),
i32 trunc (i64 sub (i64 ptrtoint (ptr dso_local_equivalent @f2 to i64), i64 ptrtoint (ptr getelementptr inbounds ({ [7 x i32] }, ptr @_ZTV1B, i32 0, i32 0, i32 2) to i64)) to i32),
i32 trunc (i64 sub (i64 ptrtoint (ptr dso_local_equivalent @f3 to i64), i64 ptrtoint (ptr getelementptr inbounds ({ [7 x i32] }, ptr @_ZTV1B, i32 0, i32 0, i32 2) to i64)) to i32),
i32 trunc (i64 sub (i64 ptrtoint (ptr dso_local_equivalent @f4 to i64), i64 ptrtoint (ptr getelementptr inbounds ({ [7 x i32] }, ptr @_ZTV1B, i32 0, i32 0, i32 2) to i64)) to i32)
] }, align 4
; CHECK-LABEL: _ZTV1B:
; CHECK-NEXT: .word 0 # 0x0
; CHECK-NEXT: .word 0 # 0x0
; CHECK-NEXT: .word %pltpcrel(f0)
; CHECK-NEXT: .word %pltpcrel(f1+4)
; CHECK-NEXT: .word %pltpcrel(f2+8)
; CHECK-NEXT: .word %pltpcrel(f3+12)
; CHECK-NEXT: .word %pltpcrel(f4+16)
; CHECK-NEXT: .size _ZTV1B, 28
declare void @f0()
declare void @f1()
define dso_local void @f2() {
ret void
}
define void @f3() {
ret void
}
define hidden void @f4() {
ret void
}