| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --check-attributes --check-globals --version 2 |
| ; RUN: opt -S -mtriple=amdgcn-- -passes=amdgpu-simplifylib -amdgpu-prelink < %s | FileCheck %s |
| |
| target datalayout = "e-p:64:64-p1:64:64-p2:32:32-p3:32:32-p4:64:64-p5:32:32-p6:32:32-p7:160:256:256:32-p8:128:128-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024-v2048:2048-n32:64-S32-A5-G1-ni:7:8:9" |
| |
| declare float @_Z3sinf(float noundef) |
| declare float @_Z3cosf(float noundef) |
| declare <2 x float> @_Z3sinDv2_f(<2 x float> noundef) |
| declare <2 x float> @_Z3cosDv2_f(<2 x float> noundef) |
| |
| define void @sincos_f32_nobuiltin(float noundef %x, ptr addrspace(1) nocapture noundef writeonly %sin_out, ptr addrspace(1) nocapture noundef writeonly %cos_out) #0 { |
| ; CHECK: Function Attrs: nobuiltin |
| ; CHECK-LABEL: define void @sincos_f32_nobuiltin |
| ; CHECK-SAME: (float noundef [[X:%.*]], ptr addrspace(1) nocapture noundef writeonly [[SIN_OUT:%.*]], ptr addrspace(1) nocapture noundef writeonly [[COS_OUT:%.*]]) #[[ATTR0:[0-9]+]] { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[__SINCOS_:%.*]] = alloca float, align 4, addrspace(5) |
| ; CHECK-NEXT: [[TMP0:%.*]] = call contract float @_Z6sincosfPU3AS5f(float [[X]], ptr addrspace(5) [[__SINCOS_]]) |
| ; CHECK-NEXT: [[TMP1:%.*]] = load float, ptr addrspace(5) [[__SINCOS_]], align 4 |
| ; CHECK-NEXT: store float [[TMP0]], ptr addrspace(1) [[SIN_OUT]], align 4 |
| ; CHECK-NEXT: [[CALL1:%.*]] = tail call contract float @_Z3cosf(float noundef [[X]]) |
| ; CHECK-NEXT: store float [[TMP1]], ptr addrspace(1) [[COS_OUT]], align 4 |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| %call = tail call contract float @_Z3sinf(float noundef %x) |
| store float %call, ptr addrspace(1) %sin_out, align 4 |
| %call1 = tail call contract float @_Z3cosf(float noundef %x) |
| store float %call1, ptr addrspace(1) %cos_out, align 4 |
| ret void |
| } |
| |
| define void @sincos_v2f32_nobuiltin(<2 x float> noundef %x, ptr addrspace(1) nocapture noundef writeonly %sin_out, ptr addrspace(1) nocapture noundef writeonly %cos_out) #0 { |
| ; CHECK: Function Attrs: nobuiltin |
| ; CHECK-LABEL: define void @sincos_v2f32_nobuiltin |
| ; CHECK-SAME: (<2 x float> noundef [[X:%.*]], ptr addrspace(1) nocapture noundef writeonly [[SIN_OUT:%.*]], ptr addrspace(1) nocapture noundef writeonly [[COS_OUT:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[__SINCOS_:%.*]] = alloca <2 x float>, align 8, addrspace(5) |
| ; CHECK-NEXT: [[TMP0:%.*]] = call contract <2 x float> @_Z6sincosDv2_fPU3AS5S_(<2 x float> [[X]], ptr addrspace(5) [[__SINCOS_]]) |
| ; CHECK-NEXT: [[TMP1:%.*]] = load <2 x float>, ptr addrspace(5) [[__SINCOS_]], align 8 |
| ; CHECK-NEXT: store <2 x float> [[TMP0]], ptr addrspace(1) [[SIN_OUT]], align 8 |
| ; CHECK-NEXT: [[CALL1:%.*]] = tail call contract <2 x float> @_Z3cosDv2_f(<2 x float> noundef [[X]]) |
| ; CHECK-NEXT: store <2 x float> [[TMP1]], ptr addrspace(1) [[COS_OUT]], align 8 |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| %call = tail call contract <2 x float> @_Z3sinDv2_f(<2 x float> noundef %x) |
| store <2 x float> %call, ptr addrspace(1) %sin_out, align 8 |
| %call1 = tail call contract <2 x float> @_Z3cosDv2_f(<2 x float> noundef %x) |
| store <2 x float> %call1, ptr addrspace(1) %cos_out, align 8 |
| ret void |
| } |
| |
| define void @sincos_f32_no_builtins(float noundef %x, ptr addrspace(1) nocapture noundef writeonly %sin_out, ptr addrspace(1) nocapture noundef writeonly %cos_out) #1 { |
| ; CHECK-LABEL: define void @sincos_f32_no_builtins |
| ; CHECK-SAME: (float noundef [[X:%.*]], ptr addrspace(1) nocapture noundef writeonly [[SIN_OUT:%.*]], ptr addrspace(1) nocapture noundef writeonly [[COS_OUT:%.*]]) #[[ATTR1:[0-9]+]] { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[__SINCOS_:%.*]] = alloca float, align 4, addrspace(5) |
| ; CHECK-NEXT: [[TMP0:%.*]] = call contract float @_Z6sincosfPU3AS5f(float [[X]], ptr addrspace(5) [[__SINCOS_]]) |
| ; CHECK-NEXT: [[TMP1:%.*]] = load float, ptr addrspace(5) [[__SINCOS_]], align 4 |
| ; CHECK-NEXT: store float [[TMP0]], ptr addrspace(1) [[SIN_OUT]], align 4 |
| ; CHECK-NEXT: [[CALL1:%.*]] = tail call contract float @_Z3cosf(float noundef [[X]]) |
| ; CHECK-NEXT: store float [[TMP1]], ptr addrspace(1) [[COS_OUT]], align 4 |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| %call = tail call contract float @_Z3sinf(float noundef %x) |
| store float %call, ptr addrspace(1) %sin_out, align 4 |
| %call1 = tail call contract float @_Z3cosf(float noundef %x) |
| store float %call1, ptr addrspace(1) %cos_out, align 4 |
| ret void |
| } |
| |
| define void @sincos_v2f32_no_builtins(<2 x float> noundef %x, ptr addrspace(1) nocapture noundef writeonly %sin_out, ptr addrspace(1) nocapture noundef writeonly %cos_out) #1 { |
| ; CHECK-LABEL: define void @sincos_v2f32_no_builtins |
| ; CHECK-SAME: (<2 x float> noundef [[X:%.*]], ptr addrspace(1) nocapture noundef writeonly [[SIN_OUT:%.*]], ptr addrspace(1) nocapture noundef writeonly [[COS_OUT:%.*]]) #[[ATTR1]] { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[__SINCOS_:%.*]] = alloca <2 x float>, align 8, addrspace(5) |
| ; CHECK-NEXT: [[TMP0:%.*]] = call contract <2 x float> @_Z6sincosDv2_fPU3AS5S_(<2 x float> [[X]], ptr addrspace(5) [[__SINCOS_]]) |
| ; CHECK-NEXT: [[TMP1:%.*]] = load <2 x float>, ptr addrspace(5) [[__SINCOS_]], align 8 |
| ; CHECK-NEXT: store <2 x float> [[TMP0]], ptr addrspace(1) [[SIN_OUT]], align 8 |
| ; CHECK-NEXT: [[CALL1:%.*]] = tail call contract <2 x float> @_Z3cosDv2_f(<2 x float> noundef [[X]]) |
| ; CHECK-NEXT: store <2 x float> [[TMP1]], ptr addrspace(1) [[COS_OUT]], align 8 |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| %call = tail call contract <2 x float> @_Z3sinDv2_f(<2 x float> noundef %x) |
| store <2 x float> %call, ptr addrspace(1) %sin_out, align 8 |
| %call1 = tail call contract <2 x float> @_Z3cosDv2_f(<2 x float> noundef %x) |
| store <2 x float> %call1, ptr addrspace(1) %cos_out, align 8 |
| ret void |
| } |
| |
| define void @sincos_f32_nobuiltin_callsite(float noundef %x, ptr addrspace(1) nocapture noundef writeonly %sin_out, ptr addrspace(1) nocapture noundef writeonly %cos_out) { |
| ; CHECK-LABEL: define void @sincos_f32_nobuiltin_callsite |
| ; CHECK-SAME: (float noundef [[X:%.*]], ptr addrspace(1) nocapture noundef writeonly [[SIN_OUT:%.*]], ptr addrspace(1) nocapture noundef writeonly [[COS_OUT:%.*]]) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call contract float @_Z3sinf(float noundef [[X]]) #[[ATTR0]] |
| ; CHECK-NEXT: store float [[CALL]], ptr addrspace(1) [[SIN_OUT]], align 4 |
| ; CHECK-NEXT: [[CALL1:%.*]] = tail call contract float @_Z3cosf(float noundef [[X]]) #[[ATTR0]] |
| ; CHECK-NEXT: store float [[CALL1]], ptr addrspace(1) [[COS_OUT]], align 4 |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| %call = tail call contract float @_Z3sinf(float noundef %x) #0 |
| store float %call, ptr addrspace(1) %sin_out, align 4 |
| %call1 = tail call contract float @_Z3cosf(float noundef %x) #0 |
| store float %call1, ptr addrspace(1) %cos_out, align 4 |
| ret void |
| } |
| |
| define void @sincos_f32_nobuiltin_callsite0(float noundef %x, ptr addrspace(1) nocapture noundef writeonly %sin_out, ptr addrspace(1) nocapture noundef writeonly %cos_out) { |
| ; CHECK-LABEL: define void @sincos_f32_nobuiltin_callsite0 |
| ; CHECK-SAME: (float noundef [[X:%.*]], ptr addrspace(1) nocapture noundef writeonly [[SIN_OUT:%.*]], ptr addrspace(1) nocapture noundef writeonly [[COS_OUT:%.*]]) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call contract float @_Z3sinf(float noundef [[X]]) #[[ATTR0]] |
| ; CHECK-NEXT: store float [[CALL]], ptr addrspace(1) [[SIN_OUT]], align 4 |
| ; CHECK-NEXT: [[CALL1:%.*]] = tail call contract float @_Z3cosf(float noundef [[X]]) |
| ; CHECK-NEXT: store float [[CALL1]], ptr addrspace(1) [[COS_OUT]], align 4 |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| %call = tail call contract float @_Z3sinf(float noundef %x) #0 |
| store float %call, ptr addrspace(1) %sin_out, align 4 |
| %call1 = tail call contract float @_Z3cosf(float noundef %x) |
| store float %call1, ptr addrspace(1) %cos_out, align 4 |
| ret void |
| } |
| |
| define void @sincos_f32_nobuiltin_callsite1(float noundef %x, ptr addrspace(1) nocapture noundef writeonly %sin_out, ptr addrspace(1) nocapture noundef writeonly %cos_out) { |
| ; CHECK-LABEL: define void @sincos_f32_nobuiltin_callsite1 |
| ; CHECK-SAME: (float noundef [[X:%.*]], ptr addrspace(1) nocapture noundef writeonly [[SIN_OUT:%.*]], ptr addrspace(1) nocapture noundef writeonly [[COS_OUT:%.*]]) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call contract float @_Z3sinf(float noundef [[X]]) |
| ; CHECK-NEXT: store float [[CALL]], ptr addrspace(1) [[SIN_OUT]], align 4 |
| ; CHECK-NEXT: [[CALL1:%.*]] = tail call contract float @_Z3cosf(float noundef [[X]]) #[[ATTR0]] |
| ; CHECK-NEXT: store float [[CALL1]], ptr addrspace(1) [[COS_OUT]], align 4 |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| %call = tail call contract float @_Z3sinf(float noundef %x) |
| store float %call, ptr addrspace(1) %sin_out, align 4 |
| %call1 = tail call contract float @_Z3cosf(float noundef %x) #0 |
| store float %call1, ptr addrspace(1) %cos_out, align 4 |
| ret void |
| } |
| |
| define void @sincos_v2f32_nobuiltin_callsite(<2 x float> noundef %x, ptr addrspace(1) nocapture noundef writeonly %sin_out, ptr addrspace(1) nocapture noundef writeonly %cos_out) { |
| ; CHECK-LABEL: define void @sincos_v2f32_nobuiltin_callsite |
| ; CHECK-SAME: (<2 x float> noundef [[X:%.*]], ptr addrspace(1) nocapture noundef writeonly [[SIN_OUT:%.*]], ptr addrspace(1) nocapture noundef writeonly [[COS_OUT:%.*]]) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call contract <2 x float> @_Z3sinDv2_f(<2 x float> noundef [[X]]) #[[ATTR0]] |
| ; CHECK-NEXT: store <2 x float> [[CALL]], ptr addrspace(1) [[SIN_OUT]], align 8 |
| ; CHECK-NEXT: [[CALL1:%.*]] = tail call contract <2 x float> @_Z3cosDv2_f(<2 x float> noundef [[X]]) #[[ATTR0]] |
| ; CHECK-NEXT: store <2 x float> [[CALL1]], ptr addrspace(1) [[COS_OUT]], align 8 |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| %call = tail call contract <2 x float> @_Z3sinDv2_f(<2 x float> noundef %x) #0 |
| store <2 x float> %call, ptr addrspace(1) %sin_out, align 8 |
| %call1 = tail call contract <2 x float> @_Z3cosDv2_f(<2 x float> noundef %x) #0 |
| store <2 x float> %call1, ptr addrspace(1) %cos_out, align 8 |
| ret void |
| } |
| |
| ; TODO: Handle single function forms |
| attributes #0 = { nobuiltin } |
| attributes #1 = { "no-builtins" } |
| ;. |
| ; CHECK: attributes #[[ATTR0]] = { nobuiltin } |
| ; CHECK: attributes #[[ATTR1]] = { "no-builtins" } |
| ;. |