| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6 |
| ; RUN: llc -mtriple=aarch64 -verify-machineinstrs -global-isel=0 %s -o - | FileCheck %s --check-prefixes=CHECK,CHECK-SD |
| ; RUN: llc -mtriple=aarch64 -verify-machineinstrs -mattr=-fp-armv8 %s -o - | FileCheck %s --check-prefix=CHECK-NOFP |
| |
| define i1 @isfinite_bf16(bfloat %x) { |
| ; CHECK-LABEL: isfinite_bf16: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: // kill: def $h0 killed $h0 def $s0 |
| ; CHECK-NEXT: fmov w8, s0 |
| ; CHECK-NEXT: ubfx w8, w8, #7, #8 |
| ; CHECK-NEXT: cmp w8, #255 |
| ; CHECK-NEXT: cset w0, lo |
| ; CHECK-NEXT: ret |
| ; |
| ; CHECK-NOFP-LABEL: isfinite_bf16: |
| ; CHECK-NOFP: // %bb.0: // %entry |
| ; CHECK-NOFP-NEXT: ubfx w8, w0, #7, #8 |
| ; CHECK-NOFP-NEXT: cmp w8, #255 |
| ; CHECK-NOFP-NEXT: cset w0, lo |
| ; CHECK-NOFP-NEXT: ret |
| entry: |
| %0 = tail call i1 @llvm.is.fpclass.bf16(bfloat %x, i32 504) ; 0x1f8 = "finite" |
| ret i1 %0 |
| } |
| |
| define i1 @not_isfinite_bf16(bfloat %x) { |
| ; CHECK-LABEL: not_isfinite_bf16: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: // kill: def $h0 killed $h0 def $s0 |
| ; CHECK-NEXT: fmov w8, s0 |
| ; CHECK-NEXT: ubfx w8, w8, #7, #8 |
| ; CHECK-NEXT: cmp w8, #254 |
| ; CHECK-NEXT: cset w0, hi |
| ; CHECK-NEXT: ret |
| ; |
| ; CHECK-NOFP-LABEL: not_isfinite_bf16: |
| ; CHECK-NOFP: // %bb.0: // %entry |
| ; CHECK-NOFP-NEXT: ubfx w8, w0, #7, #8 |
| ; CHECK-NOFP-NEXT: cmp w8, #254 |
| ; CHECK-NOFP-NEXT: cset w0, hi |
| ; CHECK-NOFP-NEXT: ret |
| entry: |
| %0 = tail call i1 @llvm.is.fpclass.bf16(bfloat %x, i32 519) ; ~0x1f8 = "~finite" |
| ret i1 %0 |
| } |
| |
| |
| define <4 x i1> @isfinite_v4bf16(<4 x bfloat> %x) { |
| ; CHECK-LABEL: isfinite_v4bf16: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: movi d1, #0xff00ff00ff00ff00 |
| ; CHECK-NEXT: add v0.4h, v0.4h, v0.4h |
| ; CHECK-NEXT: cmhi v0.4h, v1.4h, v0.4h |
| ; CHECK-NEXT: ret |
| ; |
| ; CHECK-NOFP-LABEL: isfinite_v4bf16: |
| ; CHECK-NOFP: // %bb.0: // %entry |
| ; CHECK-NOFP-NEXT: ubfx w8, w0, #7, #8 |
| ; CHECK-NOFP-NEXT: ubfx w9, w1, #7, #8 |
| ; CHECK-NOFP-NEXT: cmp w8, #255 |
| ; CHECK-NOFP-NEXT: ubfx w8, w2, #7, #8 |
| ; CHECK-NOFP-NEXT: cset w0, lo |
| ; CHECK-NOFP-NEXT: cmp w9, #255 |
| ; CHECK-NOFP-NEXT: ubfx w9, w3, #7, #8 |
| ; CHECK-NOFP-NEXT: cset w1, lo |
| ; CHECK-NOFP-NEXT: cmp w8, #255 |
| ; CHECK-NOFP-NEXT: cset w2, lo |
| ; CHECK-NOFP-NEXT: cmp w9, #255 |
| ; CHECK-NOFP-NEXT: cset w3, lo |
| ; CHECK-NOFP-NEXT: ret |
| entry: |
| %0 = tail call <4 x i1> @llvm.is.fpclass.v4bf16(<4 x bfloat> %x, i32 504) ; 0x1f8 = "finite" |
| ret <4 x i1> %0 |
| } |
| |
| define <4 x i1> @not_isfinite_v4bf16(<4 x bfloat> %x) { |
| ; CHECK-LABEL: not_isfinite_v4bf16: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: movi d1, #0xff00ff00ff00ff00 |
| ; CHECK-NEXT: add v0.4h, v0.4h, v0.4h |
| ; CHECK-NEXT: cmhs v0.4h, v0.4h, v1.4h |
| ; CHECK-NEXT: ret |
| ; |
| ; CHECK-NOFP-LABEL: not_isfinite_v4bf16: |
| ; CHECK-NOFP: // %bb.0: // %entry |
| ; CHECK-NOFP-NEXT: ubfx w8, w0, #7, #8 |
| ; CHECK-NOFP-NEXT: ubfx w9, w1, #7, #8 |
| ; CHECK-NOFP-NEXT: cmp w8, #254 |
| ; CHECK-NOFP-NEXT: ubfx w8, w2, #7, #8 |
| ; CHECK-NOFP-NEXT: cset w0, hi |
| ; CHECK-NOFP-NEXT: cmp w9, #254 |
| ; CHECK-NOFP-NEXT: ubfx w9, w3, #7, #8 |
| ; CHECK-NOFP-NEXT: cset w1, hi |
| ; CHECK-NOFP-NEXT: cmp w8, #254 |
| ; CHECK-NOFP-NEXT: cset w2, hi |
| ; CHECK-NOFP-NEXT: cmp w9, #254 |
| ; CHECK-NOFP-NEXT: cset w3, hi |
| ; CHECK-NOFP-NEXT: ret |
| entry: |
| %0 = tail call <4 x i1> @llvm.is.fpclass.v4bf16(<4 x bfloat> %x, i32 519) ; ~0x1f8 = "~finite" |
| ret <4 x i1> %0 |
| } |
| ;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line: |
| ; CHECK-SD: {{.*}} |