; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2 ; RUN: llc -mtriple=aarch64-eabi %s -o - | FileCheck %s --check-prefixes=CHECK-ISEL ; RUN: llc -mtriple=aarch64-eabi %s -o - -mattr=cssc | FileCheck %s --check-prefixes=CHECK-CSSC ; RUN: llc -mtriple=aarch64-eabi -global-isel %s -o - | FileCheck %s --check-prefixes=CHECK-GLOBAL ; RUN: llc -mtriple=aarch64-eabi -global-isel %s -o - -mattr=cssc | FileCheck %s --check-prefixes=CHECK-CSSC ; These tests check for @llvm.smax, @llvm.smin combines. ; SMAX declare i8 @llvm.smax.i8(i8 %a, i8 %b) readnone define i8 @smaxi8_zero(i8 %a) { ; CHECK-ISEL-LABEL: smaxi8_zero: ; CHECK-ISEL: // %bb.0: ; CHECK-ISEL-NEXT: sxtb w8, w0 ; CHECK-ISEL-NEXT: bic w0, w8, w8, asr #31 ; CHECK-ISEL-NEXT: ret ; ; CHECK-CSSC-LABEL: smaxi8_zero: ; CHECK-CSSC: // %bb.0: ; CHECK-CSSC-NEXT: sxtb w8, w0 ; CHECK-CSSC-NEXT: smax w0, w8, #0 ; CHECK-CSSC-NEXT: ret ; ; CHECK-GLOBAL-LABEL: smaxi8_zero: ; CHECK-GLOBAL: // %bb.0: ; CHECK-GLOBAL-NEXT: sxtb w8, w0 ; CHECK-GLOBAL-NEXT: cmp w8, #0 ; CHECK-GLOBAL-NEXT: csel w0, w0, wzr, gt ; CHECK-GLOBAL-NEXT: ret %c = call i8 @llvm.smax.i8(i8 %a, i8 0) ret i8 %c } declare i16 @llvm.smax.i16(i16 %a, i16 %b) readnone define i16 @smaxi16_zero(i16 %a) { ; CHECK-ISEL-LABEL: smaxi16_zero: ; CHECK-ISEL: // %bb.0: ; CHECK-ISEL-NEXT: sxth w8, w0 ; CHECK-ISEL-NEXT: bic w0, w8, w8, asr #31 ; CHECK-ISEL-NEXT: ret ; ; CHECK-CSSC-LABEL: smaxi16_zero: ; CHECK-CSSC: // %bb.0: ; CHECK-CSSC-NEXT: sxth w8, w0 ; CHECK-CSSC-NEXT: smax w0, w8, #0 ; CHECK-CSSC-NEXT: ret ; ; CHECK-GLOBAL-LABEL: smaxi16_zero: ; CHECK-GLOBAL: // %bb.0: ; CHECK-GLOBAL-NEXT: sxth w8, w0 ; CHECK-GLOBAL-NEXT: cmp w8, #0 ; CHECK-GLOBAL-NEXT: csel w0, w0, wzr, gt ; CHECK-GLOBAL-NEXT: ret %c = call i16 @llvm.smax.i16(i16 %a, i16 0) ret i16 %c } declare i32 @llvm.smax.i32(i32 %a, i32 %b) readnone define i32 @smaxi32_zero(i32 %a) { ; CHECK-ISEL-LABEL: smaxi32_zero: ; CHECK-ISEL: // %bb.0: ; CHECK-ISEL-NEXT: bic w0, w0, w0, asr #31 ; CHECK-ISEL-NEXT: ret ; ; CHECK-CSSC-LABEL: smaxi32_zero: ; CHECK-CSSC: // %bb.0: ; CHECK-CSSC-NEXT: smax w0, w0, #0 ; CHECK-CSSC-NEXT: ret ; ; CHECK-GLOBAL-LABEL: smaxi32_zero: ; CHECK-GLOBAL: // %bb.0: ; CHECK-GLOBAL-NEXT: cmp w0, #0 ; CHECK-GLOBAL-NEXT: csel w0, w0, wzr, gt ; CHECK-GLOBAL-NEXT: ret %c = call i32 @llvm.smax.i32(i32 %a, i32 0) ret i32 %c } declare i64 @llvm.smax.i64(i64 %a, i64 %b) readnone define i64 @smaxi64_zero(i64 %a) { ; CHECK-ISEL-LABEL: smaxi64_zero: ; CHECK-ISEL: // %bb.0: ; CHECK-ISEL-NEXT: bic x0, x0, x0, asr #63 ; CHECK-ISEL-NEXT: ret ; ; CHECK-CSSC-LABEL: smaxi64_zero: ; CHECK-CSSC: // %bb.0: ; CHECK-CSSC-NEXT: smax x0, x0, #0 ; CHECK-CSSC-NEXT: ret ; ; CHECK-GLOBAL-LABEL: smaxi64_zero: ; CHECK-GLOBAL: // %bb.0: ; CHECK-GLOBAL-NEXT: cmp x0, #0 ; CHECK-GLOBAL-NEXT: csel x0, x0, xzr, gt ; CHECK-GLOBAL-NEXT: ret %c = call i64 @llvm.smax.i64(i64 %a, i64 0) ret i64 %c } ; SMIN declare i8 @llvm.smin.i8(i8 %a, i8 %b) readnone define i8 @smini8_zero(i8 %a) { ; CHECK-ISEL-LABEL: smini8_zero: ; CHECK-ISEL: // %bb.0: ; CHECK-ISEL-NEXT: sxtb w8, w0 ; CHECK-ISEL-NEXT: and w0, w8, w8, asr #31 ; CHECK-ISEL-NEXT: ret ; ; CHECK-CSSC-LABEL: smini8_zero: ; CHECK-CSSC: // %bb.0: ; CHECK-CSSC-NEXT: sxtb w8, w0 ; CHECK-CSSC-NEXT: smin w0, w8, #0 ; CHECK-CSSC-NEXT: ret ; ; CHECK-GLOBAL-LABEL: smini8_zero: ; CHECK-GLOBAL: // %bb.0: ; CHECK-GLOBAL-NEXT: sxtb w8, w0 ; CHECK-GLOBAL-NEXT: cmp w8, #0 ; CHECK-GLOBAL-NEXT: csel w0, w0, wzr, lt ; CHECK-GLOBAL-NEXT: ret %c = call i8 @llvm.smin.i8(i8 %a, i8 0) ret i8 %c } declare i16 @llvm.smin.i16(i16 %a, i16 %b) readnone define i16 @smini16_zero(i16 %a) { ; CHECK-ISEL-LABEL: smini16_zero: ; CHECK-ISEL: // %bb.0: ; CHECK-ISEL-NEXT: sxth w8, w0 ; CHECK-ISEL-NEXT: and w0, w8, w8, asr #31 ; CHECK-ISEL-NEXT: ret ; ; CHECK-CSSC-LABEL: smini16_zero: ; CHECK-CSSC: // %bb.0: ; CHECK-CSSC-NEXT: sxth w8, w0 ; CHECK-CSSC-NEXT: smin w0, w8, #0 ; CHECK-CSSC-NEXT: ret ; ; CHECK-GLOBAL-LABEL: smini16_zero: ; CHECK-GLOBAL: // %bb.0: ; CHECK-GLOBAL-NEXT: sxth w8, w0 ; CHECK-GLOBAL-NEXT: cmp w8, #0 ; CHECK-GLOBAL-NEXT: csel w0, w0, wzr, lt ; CHECK-GLOBAL-NEXT: ret %c = call i16 @llvm.smin.i16(i16 %a, i16 0) ret i16 %c } declare i32 @llvm.smin.i32(i32 %a, i32 %b) readnone define i32 @smini32_zero(i32 %a) { ; CHECK-ISEL-LABEL: smini32_zero: ; CHECK-ISEL: // %bb.0: ; CHECK-ISEL-NEXT: and w0, w0, w0, asr #31 ; CHECK-ISEL-NEXT: ret ; ; CHECK-CSSC-LABEL: smini32_zero: ; CHECK-CSSC: // %bb.0: ; CHECK-CSSC-NEXT: smin w0, w0, #0 ; CHECK-CSSC-NEXT: ret ; ; CHECK-GLOBAL-LABEL: smini32_zero: ; CHECK-GLOBAL: // %bb.0: ; CHECK-GLOBAL-NEXT: cmp w0, #0 ; CHECK-GLOBAL-NEXT: csel w0, w0, wzr, lt ; CHECK-GLOBAL-NEXT: ret %c = call i32 @llvm.smin.i32(i32 %a, i32 0) ret i32 %c } declare i64 @llvm.smin.i64(i64 %a, i64 %b) readnone define i64 @smini64_zero(i64 %a) { ; CHECK-ISEL-LABEL: smini64_zero: ; CHECK-ISEL: // %bb.0: ; CHECK-ISEL-NEXT: and x0, x0, x0, asr #63 ; CHECK-ISEL-NEXT: ret ; ; CHECK-CSSC-LABEL: smini64_zero: ; CHECK-CSSC: // %bb.0: ; CHECK-CSSC-NEXT: smin x0, x0, #0 ; CHECK-CSSC-NEXT: ret ; ; CHECK-GLOBAL-LABEL: smini64_zero: ; CHECK-GLOBAL: // %bb.0: ; CHECK-GLOBAL-NEXT: cmp x0, #0 ; CHECK-GLOBAL-NEXT: csel x0, x0, xzr, lt ; CHECK-GLOBAL-NEXT: ret %c = call i64 @llvm.smin.i64(i64 %a, i64 0) ret i64 %c }