|
| 1 | +// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --include-generated-funcs --version 5 |
| 2 | +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -emit-llvm -o - %s | FileCheck %s |
| 3 | + |
| 4 | +// Priority biskmasks after feature dependency expansion: |
| 5 | +// |
| 6 | +// MSB LSB |
| 7 | +// |
| 8 | +// sme2 | ls64 | sme | bf16 | | | fp16 | simd | fp |
| 9 | +// -----+------+-----+------+-------+------+------+------+--- |
| 10 | +// sme2 | | sme | bf16 | rcpc2 | rcpc | fp16 | simd | fp |
| 11 | +// |
| 12 | +// Dependencies should not affect priorities, since a |
| 13 | +// feature can only depend on lower priority features. |
| 14 | + |
| 15 | +__attribute__((target_version("sme2+ls64"))) int fn(void); |
| 16 | +__attribute__((target_version("sme2+rcpc2"))) int fn(void); |
| 17 | +__attribute__((target_version("default"))) int fn(void) { return 0; } |
| 18 | + |
| 19 | +int call() { return fn(); } |
| 20 | + |
| 21 | +// CHECK-LABEL: define dso_local i32 @fn.default( |
| 22 | +// CHECK-SAME: ) #[[ATTR0:[0-9]+]] { |
| 23 | +// CHECK-NEXT: [[ENTRY:.*:]] |
| 24 | +// CHECK-NEXT: ret i32 0 |
| 25 | +// |
| 26 | +// |
| 27 | +// CHECK-LABEL: define dso_local i32 @call( |
| 28 | +// CHECK-SAME: ) #[[ATTR0]] { |
| 29 | +// CHECK-NEXT: [[ENTRY:.*:]] |
| 30 | +// CHECK-NEXT: [[CALL:%.*]] = call i32 @fn() |
| 31 | +// CHECK-NEXT: ret i32 [[CALL]] |
| 32 | +// |
| 33 | +// |
| 34 | +// CHECK-LABEL: define weak_odr ptr @fn.resolver() comdat { |
| 35 | +// CHECK-NEXT: [[RESOLVER_ENTRY:.*:]] |
| 36 | +// CHECK-NEXT: call void @__init_cpu_features_resolver() |
| 37 | +// CHECK-NEXT: [[TMP0:%.*]] = load i64, ptr @__aarch64_cpu_features, align 8 |
| 38 | +// CHECK-NEXT: [[TMP1:%.*]] = and i64 [[TMP0]], 153126785511392000 |
| 39 | +// CHECK-NEXT: [[TMP2:%.*]] = icmp eq i64 [[TMP1]], 153126785511392000 |
| 40 | +// CHECK-NEXT: [[TMP3:%.*]] = and i1 true, [[TMP2]] |
| 41 | +// CHECK-NEXT: br i1 [[TMP3]], label %[[RESOLVER_RETURN:.*]], label %[[RESOLVER_ELSE:.*]] |
| 42 | +// CHECK: [[RESOLVER_RETURN]]: |
| 43 | +// CHECK-NEXT: ret ptr @fn._Mls64Msme2 |
| 44 | +// CHECK: [[RESOLVER_ELSE]]: |
| 45 | +// CHECK-NEXT: [[TMP4:%.*]] = load i64, ptr @__aarch64_cpu_features, align 8 |
| 46 | +// CHECK-NEXT: [[TMP5:%.*]] = and i64 [[TMP4]], 144119586269233920 |
| 47 | +// CHECK-NEXT: [[TMP6:%.*]] = icmp eq i64 [[TMP5]], 144119586269233920 |
| 48 | +// CHECK-NEXT: [[TMP7:%.*]] = and i1 true, [[TMP6]] |
| 49 | +// CHECK-NEXT: br i1 [[TMP7]], label %[[RESOLVER_RETURN1:.*]], label %[[RESOLVER_ELSE2:.*]] |
| 50 | +// CHECK: [[RESOLVER_RETURN1]]: |
| 51 | +// CHECK-NEXT: ret ptr @fn._Mrcpc2Msme2 |
| 52 | +// CHECK: [[RESOLVER_ELSE2]]: |
| 53 | +// CHECK-NEXT: ret ptr @fn.default |
| 54 | +// |
0 commit comments