Home | History | Annotate | Download | only in SystemZ
      1 ; Test 128-bit addition in which the second operand is constant.
      2 ;
      3 ; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z10 | FileCheck %s
      4 
      5 ; Check additions of 1.  The XOR ensures that we don't instead load the
      6 ; constant into a register and use memory addition.
      7 define void @f1(i128 *%aptr) {
      8 ; CHECK-LABEL: f1:
      9 ; CHECK: algfi {{%r[0-5]}}, 1
     10 ; CHECK: alcg
     11 ; CHECK: br %r14
     12   %a = load i128 *%aptr
     13   %xor = xor i128 %a, 128
     14   %add = add i128 %xor, 1
     15   store i128 %add, i128 *%aptr
     16   ret void
     17 }
     18 
     19 ; Check the high end of the ALGFI range.
     20 define void @f2(i128 *%aptr) {
     21 ; CHECK-LABEL: f2:
     22 ; CHECK: algfi {{%r[0-5]}}, 4294967295
     23 ; CHECK: alcg
     24 ; CHECK: br %r14
     25   %a = load i128 *%aptr
     26   %xor = xor i128 %a, 128
     27   %add = add i128 %xor, 4294967295
     28   store i128 %add, i128 *%aptr
     29   ret void
     30 }
     31 
     32 ; Check the next value up, which must use register addition.
     33 define void @f3(i128 *%aptr) {
     34 ; CHECK-LABEL: f3:
     35 ; CHECK: algr
     36 ; CHECK: alcg
     37 ; CHECK: br %r14
     38   %a = load i128 *%aptr
     39   %xor = xor i128 %a, 128
     40   %add = add i128 %xor, 4294967296
     41   store i128 %add, i128 *%aptr
     42   ret void
     43 }
     44 
     45 ; Check addition of -1, which must also use register addition.
     46 define void @f4(i128 *%aptr) {
     47 ; CHECK-LABEL: f4:
     48 ; CHECK: algr
     49 ; CHECK: alcg
     50 ; CHECK: br %r14
     51   %a = load i128 *%aptr
     52   %xor = xor i128 %a, 128
     53   %add = add i128 %xor, -1
     54   store i128 %add, i128 *%aptr
     55   ret void
     56 }
     57