Home | History | Annotate | Download | only in R600
      1 ;RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck %s --check-prefix=EG-CHECK --check-prefix=FUNC
      2 ;RUN: llc < %s -march=r600 -mcpu=cayman | FileCheck %s --check-prefix=CM-CHECK --check-prefix=FUNC
      3 ;RUN: llc < %s -march=r600 -mcpu=SI | FileCheck %s --check-prefix=SI-CHECK --check-prefix=FUNC
      4 
      5 ;FUNC-LABEL: @test
      6 ;EG-CHECK: EXP_IEEE
      7 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
      8 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
      9 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     10 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}}
     11 ;SI-CHECK: V_EXP_F32
     12 
     13 define void @test(float addrspace(1)* %out, float %in) {
     14 entry:
     15    %0 = call float @llvm.exp2.f32(float %in)
     16    store float %0, float addrspace(1)* %out
     17    ret void
     18 }
     19 
     20 ;FUNC-LABEL: @testv2
     21 ;EG-CHECK: EXP_IEEE
     22 ;EG-CHECK: EXP_IEEE
     23 ; FIXME: We should be able to merge these packets together on Cayman so we
     24 ; have a maximum of 4 instructions.
     25 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     26 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     27 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     28 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     29 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     30 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     31 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}}
     32 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}}
     33 ;SI-CHECK: V_EXP_F32
     34 ;SI-CHECK: V_EXP_F32
     35 
     36 define void @testv2(<2 x float> addrspace(1)* %out, <2 x float> %in) {
     37 entry:
     38   %0 = call <2 x float> @llvm.exp2.v2f32(<2 x float> %in)
     39   store <2 x float> %0, <2 x float> addrspace(1)* %out
     40   ret void
     41 }
     42 
     43 ;FUNC-LABEL: @testv4
     44 ;EG-CHECK: EXP_IEEE
     45 ;EG-CHECK: EXP_IEEE
     46 ;EG-CHECK: EXP_IEEE
     47 ;EG-CHECK: EXP_IEEE
     48 ; FIXME: We should be able to merge these packets together on Cayman so we
     49 ; have a maximum of 4 instructions.
     50 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     51 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     52 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     53 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     54 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     55 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     56 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     57 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     58 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     59 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     60 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     61 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}} (MASKED)
     62 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}}
     63 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}}
     64 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}}
     65 ;CM-CHECK-DAG: EXP_IEEE T{{[0-9]+\.[XYZW]}}
     66 ;SI-CHECK: V_EXP_F32
     67 ;SI-CHECK: V_EXP_F32
     68 ;SI-CHECK: V_EXP_F32
     69 ;SI-CHECK: V_EXP_F32
     70 define void @testv4(<4 x float> addrspace(1)* %out, <4 x float> %in) {
     71 entry:
     72   %0 = call <4 x float> @llvm.exp2.v4f32(<4 x float> %in)
     73   store <4 x float> %0, <4 x float> addrspace(1)* %out
     74   ret void
     75 }
     76 
     77 declare float @llvm.exp2.f32(float) readnone
     78 declare <2 x float> @llvm.exp2.v2f32(<2 x float>) readnone
     79 declare <4 x float> @llvm.exp2.v4f32(<4 x float>) readnone
     80