X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=test%2FCodeGen%2FR600%2Fllvm.rint.ll;h=496cf07e7ca87d436ed1c959f6010fbab131f58e;hb=47f47f5d2a94c2fcd2b3090d2547ec1f4bf4b03b;hp=c174b335f0e84df7d433bfd9d0b660aa2200f2f2;hpb=39867850462b1eefd76510e25bca4f2a51f65a70;p=oota-llvm.git diff --git a/test/CodeGen/R600/llvm.rint.ll b/test/CodeGen/R600/llvm.rint.ll index c174b335f0e..496cf07e7ca 100644 --- a/test/CodeGen/R600/llvm.rint.ll +++ b/test/CodeGen/R600/llvm.rint.ll @@ -1,54 +1,61 @@ -; RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck %s --check-prefix=R600-CHECK -; RUN: llc < %s -march=r600 -mcpu=SI -verify-machineinstrs | FileCheck %s --check-prefix=SI-CHECK - -; R600-CHECK: @f32 -; R600-CHECK: RNDNE -; SI-CHECK: @f32 -; SI-CHECK: V_RNDNE_F32_e32 -define void @f32(float addrspace(1)* %out, float %in) { +; RUN: llc -march=r600 -mcpu=redwood < %s | FileCheck %s -check-prefix=R600 -check-prefix=FUNC +; RUN: llc -march=amdgcn -mcpu=SI -verify-machineinstrs < %s | FileCheck -check-prefix=SI -check-prefix=FUNC %s + +; FUNC-LABEL: {{^}}rint_f32: +; R600: RNDNE + +; SI: v_rndne_f32_e32 +define void @rint_f32(float addrspace(1)* %out, float %in) { entry: - %0 = call float @llvm.rint.f32(float %in) + %0 = call float @llvm.rint.f32(float %in) #0 store float %0, float addrspace(1)* %out ret void } -; R600-CHECK: @v2f32 -; R600-CHECK: RNDNE -; R600-CHECK: RNDNE -; SI-CHECK: @v2f32 -; SI-CHECK: V_RNDNE_F32_e32 -; SI-CHECK: V_RNDNE_F32_e32 -define void @v2f32(<2 x float> addrspace(1)* %out, <2 x float> %in) { +; FUNC-LABEL: {{^}}rint_v2f32: +; R600: RNDNE +; R600: RNDNE + +; SI: v_rndne_f32_e32 +; SI: v_rndne_f32_e32 +define void @rint_v2f32(<2 x float> addrspace(1)* %out, <2 x float> %in) { entry: - %0 = call <2 x float> @llvm.rint.v2f32(<2 x float> %in) + %0 = call <2 x float> @llvm.rint.v2f32(<2 x float> %in) #0 store <2 x float> %0, <2 x float> addrspace(1)* %out ret void } -; R600-CHECK: @v4f32 -; R600-CHECK: RNDNE -; R600-CHECK: RNDNE -; R600-CHECK: RNDNE -; R600-CHECK: RNDNE -; SI-CHECK: @v4f32 -; SI-CHECK: V_RNDNE_F32_e32 -; SI-CHECK: V_RNDNE_F32_e32 -; SI-CHECK: V_RNDNE_F32_e32 -; SI-CHECK: V_RNDNE_F32_e32 -define void @v4f32(<4 x float> addrspace(1)* %out, <4 x float> %in) { +; FUNC-LABEL: {{^}}rint_v4f32: +; R600: RNDNE +; R600: RNDNE +; R600: RNDNE +; R600: RNDNE + +; SI: v_rndne_f32_e32 +; SI: v_rndne_f32_e32 +; SI: v_rndne_f32_e32 +; SI: v_rndne_f32_e32 +define void @rint_v4f32(<4 x float> addrspace(1)* %out, <4 x float> %in) { entry: - %0 = call <4 x float> @llvm.rint.v4f32(<4 x float> %in) + %0 = call <4 x float> @llvm.rint.v4f32(<4 x float> %in) #0 store <4 x float> %0, <4 x float> addrspace(1)* %out ret void } -; Function Attrs: nounwind readonly -declare float @llvm.rint.f32(float) #0 +; FUNC-LABEL: {{^}}legacy_amdil_round_nearest_f32: +; R600: RNDNE -; Function Attrs: nounwind readonly -declare <2 x float> @llvm.rint.v2f32(<2 x float>) #0 +; SI: v_rndne_f32_e32 +define void @legacy_amdil_round_nearest_f32(float addrspace(1)* %out, float %in) { +entry: + %0 = call float @llvm.AMDIL.round.nearest.f32(float %in) #0 + store float %0, float addrspace(1)* %out + ret void +} -; Function Attrs: nounwind readonly +declare float @llvm.AMDIL.round.nearest.f32(float) #0 +declare float @llvm.rint.f32(float) #0 +declare <2 x float> @llvm.rint.v2f32(<2 x float>) #0 declare <4 x float> @llvm.rint.v4f32(<4 x float>) #0 -attributes #0 = { nounwind readonly } +attributes #0 = { nounwind readnone }