Home | History | Annotate | Download | only in SystemZ
      1 ; RUN: opt < %s -cost-model -analyze -mtriple=systemz-unknown -mcpu=z13 \
      2 ; RUN:   | FileCheck -check-prefix=CHECK -check-prefix=CHECK-Z13 %s
      3 ; RUN: opt < %s -cost-model -analyze -mtriple=systemz-unknown -mcpu=z14 \
      4 ; RUN:   | FileCheck -check-prefix=CHECK -check-prefix=CHECK-Z14 %s
      5 ;
      6 ; Note: The scalarized vector instructions cost is not including any
      7 ; extracts, due to the undef operands
      8 ;
      9 ; Note: FRem is implemented with libcall, so not included here.
     10 
     11 define void @fadd() {
     12   %res0 = fadd float undef, undef
     13   %res1 = fadd double undef, undef
     14   %res2 = fadd fp128 undef, undef
     15   %res3 = fadd <2 x float> undef, undef
     16   %res4 = fadd <2 x double> undef, undef
     17   %res5 = fadd <4 x float> undef, undef
     18   %res6 = fadd <4 x double> undef, undef
     19   %res7 = fadd <8 x float> undef, undef
     20   %res8 = fadd <8 x double> undef, undef
     21   %res9 = fadd <16 x float> undef, undef
     22   %res10 = fadd <16 x double> undef, undef
     23 
     24 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res0 = fadd float undef, undef
     25 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res1 = fadd double undef, undef
     26 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res2 = fadd fp128 undef, undef
     27 ; CHECK-Z13: Cost Model: Found an estimated cost of 8 for instruction:   %res3 = fadd <2 x float> undef, undef
     28 ; CHECK-Z14: Cost Model: Found an estimated cost of 1 for instruction:   %res3 = fadd <2 x float> undef, undef
     29 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res4 = fadd <2 x double> undef, undef
     30 ; CHECK-Z13: Cost Model: Found an estimated cost of 8 for instruction:   %res5 = fadd <4 x float> undef, undef
     31 ; CHECK-Z14: Cost Model: Found an estimated cost of 1 for instruction:   %res5 = fadd <4 x float> undef, undef
     32 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction:   %res6 = fadd <4 x double> undef, undef
     33 ; CHECK-Z13: Cost Model: Found an estimated cost of 16 for instruction:   %res7 = fadd <8 x float> undef, undef
     34 ; CHECK-Z14: Cost Model: Found an estimated cost of 2 for instruction:   %res7 = fadd <8 x float> undef, undef
     35 ; CHECK: Cost Model: Found an estimated cost of 4 for instruction:   %res8 = fadd <8 x double> undef, undef
     36 ; CHECK-Z13: Cost Model: Found an estimated cost of 32 for instruction:   %res9 = fadd <16 x float> undef, undef
     37 ; CHECK-Z14: Cost Model: Found an estimated cost of 4 for instruction:   %res9 = fadd <16 x float> undef, undef
     38 ; CHECK: Cost Model: Found an estimated cost of 8 for instruction:   %res10 = fadd <16 x double> undef, undef
     39 
     40   ret void;
     41 }
     42 
     43 define void @fsub() {
     44   %res0 = fsub float undef, undef
     45   %res1 = fsub double undef, undef
     46   %res2 = fsub fp128 undef, undef
     47   %res3 = fsub <2 x float> undef, undef
     48   %res4 = fsub <2 x double> undef, undef
     49   %res5 = fsub <4 x float> undef, undef
     50   %res6 = fsub <4 x double> undef, undef
     51   %res7 = fsub <8 x float> undef, undef
     52   %res8 = fsub <8 x double> undef, undef
     53   %res9 = fsub <16 x float> undef, undef
     54   %res10 = fsub <16 x double> undef, undef
     55 
     56 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res0 = fsub float undef, undef
     57 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res1 = fsub double undef, undef
     58 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res2 = fsub fp128 undef, undef
     59 ; CHECK-Z13: Cost Model: Found an estimated cost of 8 for instruction:   %res3 = fsub <2 x float> undef, undef
     60 ; CHECK-Z14: Cost Model: Found an estimated cost of 1 for instruction:   %res3 = fsub <2 x float> undef, undef
     61 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res4 = fsub <2 x double> undef, undef
     62 ; CHECK-Z13: Cost Model: Found an estimated cost of 8 for instruction:   %res5 = fsub <4 x float> undef, undef
     63 ; CHECK-Z14: Cost Model: Found an estimated cost of 1 for instruction:   %res5 = fsub <4 x float> undef, undef
     64 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction:   %res6 = fsub <4 x double> undef, undef
     65 ; CHECK-Z13: Cost Model: Found an estimated cost of 16 for instruction:   %res7 = fsub <8 x float> undef, undef
     66 ; CHECK-Z14: Cost Model: Found an estimated cost of 2 for instruction:   %res7 = fsub <8 x float> undef, undef
     67 ; CHECK: Cost Model: Found an estimated cost of 4 for instruction:   %res8 = fsub <8 x double> undef, undef
     68 ; CHECK-Z13: Cost Model: Found an estimated cost of 32 for instruction:   %res9 = fsub <16 x float> undef, undef
     69 ; CHECK-Z14: Cost Model: Found an estimated cost of 4 for instruction:   %res9 = fsub <16 x float> undef, undef
     70 ; CHECK: Cost Model: Found an estimated cost of 8 for instruction:   %res10 = fsub <16 x double> undef, undef
     71 
     72   ret void;
     73 }
     74 
     75 define void @fmul() {
     76   %res0 = fmul float undef, undef
     77   %res1 = fmul double undef, undef
     78   %res2 = fmul fp128 undef, undef
     79   %res3 = fmul <2 x float> undef, undef
     80   %res4 = fmul <2 x double> undef, undef
     81   %res5 = fmul <4 x float> undef, undef
     82   %res6 = fmul <4 x double> undef, undef
     83   %res7 = fmul <8 x float> undef, undef
     84   %res8 = fmul <8 x double> undef, undef
     85   %res9 = fmul <16 x float> undef, undef
     86   %res10 = fmul <16 x double> undef, undef
     87 
     88 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res0 = fmul float undef, undef
     89 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res1 = fmul double undef, undef
     90 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res2 = fmul fp128 undef, undef
     91 ; CHECK-Z13: Cost Model: Found an estimated cost of 8 for instruction:   %res3 = fmul <2 x float> undef, undef
     92 ; CHECK-Z14: Cost Model: Found an estimated cost of 1 for instruction:   %res3 = fmul <2 x float> undef, undef
     93 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res4 = fmul <2 x double> undef, undef
     94 ; CHECK-Z13: Cost Model: Found an estimated cost of 8 for instruction:   %res5 = fmul <4 x float> undef, undef
     95 ; CHECK-Z14: Cost Model: Found an estimated cost of 1 for instruction:   %res5 = fmul <4 x float> undef, undef
     96 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction:   %res6 = fmul <4 x double> undef, undef
     97 ; CHECK-Z13: Cost Model: Found an estimated cost of 16 for instruction:   %res7 = fmul <8 x float> undef, undef
     98 ; CHECK-Z14: Cost Model: Found an estimated cost of 2 for instruction:   %res7 = fmul <8 x float> undef, undef
     99 ; CHECK: Cost Model: Found an estimated cost of 4 for instruction:   %res8 = fmul <8 x double> undef, undef
    100 ; CHECK-Z13: Cost Model: Found an estimated cost of 32 for instruction:   %res9 = fmul <16 x float> undef, undef
    101 ; CHECK-Z14: Cost Model: Found an estimated cost of 4 for instruction:   %res9 = fmul <16 x float> undef, undef
    102 ; CHECK: Cost Model: Found an estimated cost of 8 for instruction:   %res10 = fmul <16 x double> undef, undef
    103 
    104   ret void;
    105 }
    106 
    107 define void @fdiv() {
    108   %res0 = fdiv float undef, undef
    109   %res1 = fdiv double undef, undef
    110   %res2 = fdiv fp128 undef, undef
    111   %res3 = fdiv <2 x float> undef, undef
    112   %res4 = fdiv <2 x double> undef, undef
    113   %res5 = fdiv <4 x float> undef, undef
    114   %res6 = fdiv <4 x double> undef, undef
    115   %res7 = fdiv <8 x float> undef, undef
    116   %res8 = fdiv <8 x double> undef, undef
    117   %res9 = fdiv <16 x float> undef, undef
    118   %res10 = fdiv <16 x double> undef, undef
    119 
    120 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res0 = fdiv float undef, undef
    121 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res1 = fdiv double undef, undef
    122 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res2 = fdiv fp128 undef, undef
    123 ; CHECK-Z13: Cost Model: Found an estimated cost of 8 for instruction:   %res3 = fdiv <2 x float> undef, undef
    124 ; CHECK-Z14: Cost Model: Found an estimated cost of 1 for instruction:   %res3 = fdiv <2 x float> undef, undef
    125 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction:   %res4 = fdiv <2 x double> undef, undef
    126 ; CHECK-Z13: Cost Model: Found an estimated cost of 8 for instruction:   %res5 = fdiv <4 x float> undef, undef
    127 ; CHECK-Z14: Cost Model: Found an estimated cost of 1 for instruction:   %res5 = fdiv <4 x float> undef, undef
    128 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction:   %res6 = fdiv <4 x double> undef, undef
    129 ; CHECK-Z13: Cost Model: Found an estimated cost of 16 for instruction:   %res7 = fdiv <8 x float> undef, undef
    130 ; CHECK-Z14: Cost Model: Found an estimated cost of 2 for instruction:   %res7 = fdiv <8 x float> undef, undef
    131 ; CHECK: Cost Model: Found an estimated cost of 4 for instruction:   %res8 = fdiv <8 x double> undef, undef
    132 ; CHECK-Z13: Cost Model: Found an estimated cost of 32 for instruction:   %res9 = fdiv <16 x float> undef, undef
    133 ; CHECK-Z14: Cost Model: Found an estimated cost of 4 for instruction:   %res9 = fdiv <16 x float> undef, undef
    134 ; CHECK: Cost Model: Found an estimated cost of 8 for instruction:   %res10 = fdiv <16 x double> undef, undef
    135 
    136   ret void;
    137 }
    138 
    139