1*fdc4ea34SJonas Paulsson; Test of subtraction that involves a constant as the first operand 2*fdc4ea34SJonas Paulsson; 3*fdc4ea34SJonas Paulsson; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z196 | FileCheck %s 4*fdc4ea34SJonas Paulsson 5*fdc4ea34SJonas Paulsson; Check highest 16-bit signed int immediate value. 6*fdc4ea34SJonas Paulssondefine i64 @f1(i64 %a) { 7*fdc4ea34SJonas Paulsson; CHECK-LABEL: f1: 8*fdc4ea34SJonas Paulsson; CHECK: lghi %r0, 32767 9*fdc4ea34SJonas Paulsson; CHECK: sgrk %r2, %r0, %r2 10*fdc4ea34SJonas Paulsson; CHECK: br %r14 11*fdc4ea34SJonas Paulsson %sub = sub i64 32767, %a 12*fdc4ea34SJonas Paulsson ret i64 %sub 13*fdc4ea34SJonas Paulsson} 14*fdc4ea34SJonas Paulsson; Check highest 32-bit signed int immediate value. 15*fdc4ea34SJonas Paulssondefine i64 @f2(i64 %a) { 16*fdc4ea34SJonas Paulsson; CHECK-LABEL: f2: 17*fdc4ea34SJonas Paulsson; CHECK: lgfi %r0, 2147483647 18*fdc4ea34SJonas Paulsson; CHECK: sgrk %r2, %r0, %r2 19*fdc4ea34SJonas Paulsson; CHECK: br %r14 20*fdc4ea34SJonas Paulsson %sub = sub i64 2147483647, %a 21*fdc4ea34SJonas Paulsson ret i64 %sub 22*fdc4ea34SJonas Paulsson} 23