blob: 3d6282675967dfc2c105f2b5bcb489ab41bc7f64 [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -instsimplify -S | FileCheck %s
declare float @llvm.amdgcn.cubema(float, float, float)
define void @test(float* %p) {
; CHECK-LABEL: @test(
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P:%.*]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float 1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: store volatile float -1.000000e+01, float* [[P]]
; CHECK-NEXT: ret void
;
%p3p4p5 = call float @llvm.amdgcn.cubema(float +3.0, float +4.0, float +5.0)
store volatile float %p3p4p5, float* %p
%p3p5p4 = call float @llvm.amdgcn.cubema(float +3.0, float +5.0, float +4.0)
store volatile float %p3p5p4, float* %p
%p4p3p5 = call float @llvm.amdgcn.cubema(float +4.0, float +3.0, float +5.0)
store volatile float %p4p3p5, float* %p
%p4p5p3 = call float @llvm.amdgcn.cubema(float +4.0, float +5.0, float +3.0)
store volatile float %p4p5p3, float* %p
%p5p3p4 = call float @llvm.amdgcn.cubema(float +5.0, float +3.0, float +4.0)
store volatile float %p5p3p4, float* %p
%p5p4p3 = call float @llvm.amdgcn.cubema(float +5.0, float +4.0, float +3.0)
store volatile float %p5p4p3, float* %p
%p3p4n5 = call float @llvm.amdgcn.cubema(float +3.0, float +4.0, float -5.0)
store volatile float %p3p4n5, float* %p
%p3p5n4 = call float @llvm.amdgcn.cubema(float +3.0, float +5.0, float -4.0)
store volatile float %p3p5n4, float* %p
%p4p3n5 = call float @llvm.amdgcn.cubema(float +4.0, float +3.0, float -5.0)
store volatile float %p4p3n5, float* %p
%p4p5n3 = call float @llvm.amdgcn.cubema(float +4.0, float +5.0, float -3.0)
store volatile float %p4p5n3, float* %p
%p5p3n4 = call float @llvm.amdgcn.cubema(float +5.0, float +3.0, float -4.0)
store volatile float %p5p3n4, float* %p
%p5p4n3 = call float @llvm.amdgcn.cubema(float +5.0, float +4.0, float -3.0)
store volatile float %p5p4n3, float* %p
%p3n4p5 = call float @llvm.amdgcn.cubema(float +3.0, float -4.0, float +5.0)
store volatile float %p3n4p5, float* %p
%p3n5p4 = call float @llvm.amdgcn.cubema(float +3.0, float -5.0, float +4.0)
store volatile float %p3n5p4, float* %p
%p4n3p5 = call float @llvm.amdgcn.cubema(float +4.0, float -3.0, float +5.0)
store volatile float %p4n3p5, float* %p
%p4n5p3 = call float @llvm.amdgcn.cubema(float +4.0, float -5.0, float +3.0)
store volatile float %p4n5p3, float* %p
%p5n3p4 = call float @llvm.amdgcn.cubema(float +5.0, float -3.0, float +4.0)
store volatile float %p5n3p4, float* %p
%p5n4p3 = call float @llvm.amdgcn.cubema(float +5.0, float -4.0, float +3.0)
store volatile float %p5n4p3, float* %p
%p3n4n5 = call float @llvm.amdgcn.cubema(float +3.0, float -4.0, float -5.0)
store volatile float %p3n4n5, float* %p
%p3n5n4 = call float @llvm.amdgcn.cubema(float +3.0, float -5.0, float -4.0)
store volatile float %p3n5n4, float* %p
%p4n3n5 = call float @llvm.amdgcn.cubema(float +4.0, float -3.0, float -5.0)
store volatile float %p4n3n5, float* %p
%p4n5n3 = call float @llvm.amdgcn.cubema(float +4.0, float -5.0, float -3.0)
store volatile float %p4n5n3, float* %p
%p5n3n4 = call float @llvm.amdgcn.cubema(float +5.0, float -3.0, float -4.0)
store volatile float %p5n3n4, float* %p
%p5n4n3 = call float @llvm.amdgcn.cubema(float +5.0, float -4.0, float -3.0)
store volatile float %p5n4n3, float* %p
%n3p4p5 = call float @llvm.amdgcn.cubema(float -3.0, float +4.0, float +5.0)
store volatile float %n3p4p5, float* %p
%n3p5p4 = call float @llvm.amdgcn.cubema(float -3.0, float +5.0, float +4.0)
store volatile float %n3p5p4, float* %p
%n4p3p5 = call float @llvm.amdgcn.cubema(float -4.0, float +3.0, float +5.0)
store volatile float %n4p3p5, float* %p
%n4p5p3 = call float @llvm.amdgcn.cubema(float -4.0, float +5.0, float +3.0)
store volatile float %n4p5p3, float* %p
%n5p3p4 = call float @llvm.amdgcn.cubema(float -5.0, float +3.0, float +4.0)
store volatile float %n5p3p4, float* %p
%n5p4p3 = call float @llvm.amdgcn.cubema(float -5.0, float +4.0, float +3.0)
store volatile float %n5p4p3, float* %p
%n3p4n5 = call float @llvm.amdgcn.cubema(float -3.0, float +4.0, float -5.0)
store volatile float %n3p4n5, float* %p
%n3p5n4 = call float @llvm.amdgcn.cubema(float -3.0, float +5.0, float -4.0)
store volatile float %n3p5n4, float* %p
%n4p3n5 = call float @llvm.amdgcn.cubema(float -4.0, float +3.0, float -5.0)
store volatile float %n4p3n5, float* %p
%n4p5n3 = call float @llvm.amdgcn.cubema(float -4.0, float +5.0, float -3.0)
store volatile float %n4p5n3, float* %p
%n5p3n4 = call float @llvm.amdgcn.cubema(float -5.0, float +3.0, float -4.0)
store volatile float %n5p3n4, float* %p
%n5p4n3 = call float @llvm.amdgcn.cubema(float -5.0, float +4.0, float -3.0)
store volatile float %n5p4n3, float* %p
%n3n4p5 = call float @llvm.amdgcn.cubema(float -3.0, float -4.0, float +5.0)
store volatile float %n3n4p5, float* %p
%n3n5p4 = call float @llvm.amdgcn.cubema(float -3.0, float -5.0, float +4.0)
store volatile float %n3n5p4, float* %p
%n4n3p5 = call float @llvm.amdgcn.cubema(float -4.0, float -3.0, float +5.0)
store volatile float %n4n3p5, float* %p
%n4n5p3 = call float @llvm.amdgcn.cubema(float -4.0, float -5.0, float +3.0)
store volatile float %n4n5p3, float* %p
%n5n3p4 = call float @llvm.amdgcn.cubema(float -5.0, float -3.0, float +4.0)
store volatile float %n5n3p4, float* %p
%n5n4p3 = call float @llvm.amdgcn.cubema(float -5.0, float -4.0, float +3.0)
store volatile float %n5n4p3, float* %p
%n3n4n5 = call float @llvm.amdgcn.cubema(float -3.0, float -4.0, float -5.0)
store volatile float %n3n4n5, float* %p
%n3n5n4 = call float @llvm.amdgcn.cubema(float -3.0, float -5.0, float -4.0)
store volatile float %n3n5n4, float* %p
%n4n3n5 = call float @llvm.amdgcn.cubema(float -4.0, float -3.0, float -5.0)
store volatile float %n4n3n5, float* %p
%n4n5n3 = call float @llvm.amdgcn.cubema(float -4.0, float -5.0, float -3.0)
store volatile float %n4n5n3, float* %p
%n5n3n4 = call float @llvm.amdgcn.cubema(float -5.0, float -3.0, float -4.0)
store volatile float %n5n3n4, float* %p
%n5n4n3 = call float @llvm.amdgcn.cubema(float -5.0, float -4.0, float -3.0)
store volatile float %n5n4n3, float* %p
ret void
}