Files
clang-p2996/llvm/test/CodeGen/AArch64/neg-selects.ll
Michael Platings 041ffc155f [Clang][Driver] Warn on invalid Arm or AArch64 baremetal target triple
A common user mistake is specifying a target of aarch64-none-eabi or
arm-none-elf whereas the correct names are aarch64-none-elf &
arm-none-eabi. Currently if a target of aarch64-none-eabi is specified
then the Generic_ELF toolchain is used, unlike aarch64-none-elf which
will use the BareMetal toolchain. This is unlikely to be intended by the
user so issue a warning that the target is invalid.

The target parser is liberal in what input it accepts so invalid triples
may yield behaviour that's sufficiently close to what the user intended.
Therefore invalid triples were used in many tests. This change updates
those tests to use valid triples.
One test (gnu-mcount.c) relies on the Generic_ELF toolchain behaviour so
change it to explicitly specify aarch64-unknown-none-gnu as the target.

Reviewed By: peter.smith, DavidSpickett

Differential Revision: https://reviews.llvm.org/D153430
2023-06-23 11:54:29 +01:00

80 lines
2.1 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mtriple=aarch64-none-elf %s -o - | FileCheck %s
define i32 @neg_select_neg(i32 %a, i32 %b, i1 %bb) {
; CHECK-LABEL: neg_select_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: tst w2, #0x1
; CHECK-NEXT: csel w0, w0, w1, ne
; CHECK-NEXT: ret
%nega = sub i32 0, %a
%negb = sub i32 0, %b
%sel = select i1 %bb, i32 %nega, i32 %negb
%res = sub i32 0, %sel
ret i32 %res
}
define i32 @negneg_select_nega(i32 %a, i32 %b, i1 %bb) {
; CHECK-LABEL: negneg_select_nega:
; CHECK: // %bb.0:
; CHECK-NEXT: tst w2, #0x1
; CHECK-NEXT: csneg w0, w1, w0, eq
; CHECK-NEXT: ret
%nega = sub i32 0, %a
%sel = select i1 %bb, i32 %nega, i32 %b
%nsel = sub i32 0, %sel
%res = sub i32 0, %nsel
ret i32 %res
}
define i32 @neg_select_nega(i32 %a, i32 %b, i1 %bb) {
; CHECK-LABEL: neg_select_nega:
; CHECK: // %bb.0:
; CHECK-NEXT: tst w2, #0x1
; CHECK-NEXT: csneg w0, w0, w1, ne
; CHECK-NEXT: ret
%nega = sub i32 0, %a
%sel = select i1 %bb, i32 %nega, i32 %b
%res = sub i32 0, %sel
ret i32 %res
}
define i32 @neg_select_negb(i32 %a, i32 %b, i1 %bb) {
; CHECK-LABEL: neg_select_negb:
; CHECK: // %bb.0:
; CHECK-NEXT: tst w2, #0x1
; CHECK-NEXT: csneg w0, w1, w0, eq
; CHECK-NEXT: ret
%negb = sub i32 0, %b
%sel = select i1 %bb, i32 %a, i32 %negb
%res = sub i32 0, %sel
ret i32 %res
}
define i32 @neg_select_ab(i32 %a, i32 %b, i1 %bb) {
; CHECK-LABEL: neg_select_ab:
; CHECK: // %bb.0:
; CHECK-NEXT: tst w2, #0x1
; CHECK-NEXT: csel w8, w0, w1, ne
; CHECK-NEXT: neg w0, w8
; CHECK-NEXT: ret
%sel = select i1 %bb, i32 %a, i32 %b
%res = sub i32 0, %sel
ret i32 %res
}
define i32 @neg_select_nega_with_use(i32 %a, i32 %b, i1 %bb) {
; CHECK-LABEL: neg_select_nega_with_use:
; CHECK: // %bb.0:
; CHECK-NEXT: tst w2, #0x1
; CHECK-NEXT: neg w8, w0
; CHECK-NEXT: csneg w9, w1, w0, eq
; CHECK-NEXT: sub w0, w8, w9
; CHECK-NEXT: ret
%nega = sub i32 0, %a
%sel = select i1 %bb, i32 %nega, i32 %b
%nsel = sub i32 0, %sel
%res = add i32 %nsel, %nega
ret i32 %res
}