| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2 |
| ; RUN: llc -mtriple=aarch64-none-linux-gnu -verify-machineinstrs -global-isel -global-isel-abort=1 %s -o - | FileCheck %s |
| |
| declare i64 @llvm.get.fpenv.i64() |
| declare void @llvm.set.fpenv.i64(i64 %fpenv) |
| declare void @llvm.reset.fpenv() |
| |
| define i64 @get_fpenv_01() nounwind { |
| ; CHECK-LABEL: get_fpenv_01: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: add x0, sp, #8 |
| ; CHECK-NEXT: bl fegetenv |
| ; CHECK-NEXT: ldr x0, [sp, #8] |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| entry: |
| %fpenv = call i64 @llvm.get.fpenv.i64() |
| ret i64 %fpenv |
| } |
| |
| define void @set_fpenv_01(i64 %fpenv) nounwind { |
| ; CHECK-LABEL: set_fpenv_01: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: stp x30, x0, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: add x0, sp, #8 |
| ; CHECK-NEXT: bl fesetenv |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| entry: |
| call void @llvm.set.fpenv.i64(i64 %fpenv) |
| ret void |
| } |
| |
| define void @reset_fpenv_01() nounwind { |
| ; CHECK-LABEL: reset_fpenv_01: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: mov x0, #-1 // =0xffffffffffffffff |
| ; CHECK-NEXT: b fesetenv |
| entry: |
| call void @llvm.reset.fpenv() |
| ret void |
| } |