1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 11:13:28 +01:00
llvm-mirror/test/CodeGen/NVPTX/read-global-variable-constant.ll
Justin Lebar e721a7e2ee [NVPTX] Lower loads from global constants using ld.global.nc (aka LDG).
Summary:
After D43914, loads from global variables in addrspace(1) happen with
ld.global.  But since they're constants, even better would be to use
ld.global.nc, aka ldg.

Reviewers: tra

Subscribers: jholewinski, sanjoy, hiraditya, llvm-commits

Differential Revision: https://reviews.llvm.org/D43915

llvm-svn: 326390
2018-02-28 23:58:05 +00:00

30 lines
763 B
LLVM

; RUN: llc < %s -march=nvptx -mcpu=sm_35 | FileCheck %s
; Check load from constant global variables. These loads should be
; ld.global.nc (aka ldg).
@gv_float = external constant float
@gv_float2 = external constant <2 x float>
@gv_float4 = external constant <4 x float>
; CHECK-LABEL: test_gv_float()
define float @test_gv_float() {
; CHECK: ld.global.nc.f32
%v = load float, float* @gv_float
ret float %v
}
; CHECK-LABEL: test_gv_float2()
define <2 x float> @test_gv_float2() {
; CHECK: ld.global.nc.v2.f32
%v = load <2 x float>, <2 x float>* @gv_float2
ret <2 x float> %v
}
; CHECK-LABEL: test_gv_float4()
define <4 x float> @test_gv_float4() {
; CHECK: ld.global.nc.v4.f32
%v = load <4 x float>, <4 x float>* @gv_float4
ret <4 x float> %v
}