Home | History | Annotate | Download | only in NVPTX
      1 ; RUN: llc < %s -march=nvptx -mcpu=sm_20 -fp-contract=fast | FileCheck %s
      2 ; RUN: llc < %s -march=nvptx64 -mcpu=sm_20 -fp-contract=fast | FileCheck %s
      3 
      4 ;; These tests should run for all targets
      5 
      6 ;;===-- Basic instruction selection tests ---------------------------------===;;
      7 
      8 
      9 ;;; f64
     10 
     11 define double @fadd_f64(double %a, double %b) {
     12 ; CHECK: add.f64 %fd{{[0-9]+}}, %fd{{[0-9]+}}, %fd{{[0-9]+}}
     13 ; CHECK: ret
     14   %ret = fadd double %a, %b
     15   ret double %ret
     16 }
     17 
     18 define double @fsub_f64(double %a, double %b) {
     19 ; CHECK: sub.f64 %fd{{[0-9]+}}, %fd{{[0-9]+}}, %fd{{[0-9]+}}
     20 ; CHECK: ret
     21   %ret = fsub double %a, %b
     22   ret double %ret
     23 }
     24 
     25 define double @fmul_f64(double %a, double %b) {
     26 ; CHECK: mul.f64 %fd{{[0-9]+}}, %fd{{[0-9]+}}, %fd{{[0-9]+}}
     27 ; CHECK: ret
     28   %ret = fmul double %a, %b
     29   ret double %ret
     30 }
     31 
     32 define double @fdiv_f64(double %a, double %b) {
     33 ; CHECK: div.rn.f64 %fd{{[0-9]+}}, %fd{{[0-9]+}}, %fd{{[0-9]+}}
     34 ; CHECK: ret
     35   %ret = fdiv double %a, %b
     36   ret double %ret
     37 }
     38 
     39 ;; PTX does not have a floating-point rem instruction
     40 
     41 
     42 ;;; f32
     43 
     44 define float @fadd_f32(float %a, float %b) {
     45 ; CHECK: add.f32 %f{{[0-9]+}}, %f{{[0-9]+}}, %f{{[0-9]+}}
     46 ; CHECK: ret
     47   %ret = fadd float %a, %b
     48   ret float %ret
     49 }
     50 
     51 define float @fsub_f32(float %a, float %b) {
     52 ; CHECK: sub.f32 %f{{[0-9]+}}, %f{{[0-9]+}}, %f{{[0-9]+}}
     53 ; CHECK: ret
     54   %ret = fsub float %a, %b
     55   ret float %ret
     56 }
     57 
     58 define float @fmul_f32(float %a, float %b) {
     59 ; CHECK: mul.f32 %f{{[0-9]+}}, %f{{[0-9]+}}, %f{{[0-9]+}}
     60 ; CHECK: ret
     61   %ret = fmul float %a, %b
     62   ret float %ret
     63 }
     64 
     65 define float @fdiv_f32(float %a, float %b) {
     66 ; CHECK: div.rn.f32 %f{{[0-9]+}}, %f{{[0-9]+}}, %f{{[0-9]+}}
     67 ; CHECK: ret
     68   %ret = fdiv float %a, %b
     69   ret float %ret
     70 }
     71 
     72 ;; PTX does not have a floating-point rem instruction
     73