| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py |
| ; RUN: opt < %s -passes=instsimplify -S | FileCheck %s |
| |
| define i64 @vscale_i64_range_none() #0 { |
| ; CHECK-LABEL: @vscale_i64_range_none( |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.vscale.i64() |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.vscale.i64() |
| ret i64 %out |
| } |
| |
| define i64 @vscale_i64_range_1_1() #1 { |
| ; CHECK-LABEL: @vscale_i64_range_1_1( |
| ; CHECK-NEXT: ret i64 1 |
| ; |
| %out = call i64 @llvm.vscale.i64() |
| ret i64 %out |
| } |
| |
| define i32 @vscale_i32_range_2_2() #2 { |
| ; CHECK-LABEL: @vscale_i32_range_2_2( |
| ; CHECK-NEXT: ret i32 2 |
| ; |
| %out = call i32 @llvm.vscale.i32() |
| ret i32 %out |
| } |
| |
| define i64 @vscale_i64_range_2_4() #3 { |
| ; CHECK-LABEL: @vscale_i64_range_2_4( |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.vscale.i64() |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.vscale.i64() |
| ret i64 %out |
| } |
| |
| ; Function Attrs: nofree nosync nounwind readnone willreturn |
| declare i64 @llvm.vscale.i64() #0 |
| |
| ; Function Attrs: nofree nosync nounwind readnone willreturn |
| declare i32 @llvm.vscale.i32() #0 |
| |
| attributes #0 = { nofree nosync nounwind readnone willreturn } |
| attributes #1 = { mustprogress nofree nosync nounwind uwtable vscale_range(1,1) } |
| attributes #2 = { mustprogress nofree nosync nounwind uwtable vscale_range(2,2) } |
| attributes #3 = { mustprogress nofree nosync nounwind uwtable vscale_range(2,4) } |
| |
| |