|  | 
|  | 1 | +// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py | 
|  | 2 | +// REQUIRES: aarch64-registered-target | 
|  | 3 | + | 
|  | 4 | +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve2p1 -S -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s | 
|  | 5 | +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve2p1 -S -disable-O0-optnone -Werror -Wall -emit-llvm -o - -x c++ %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s -check-prefix=CPP-CHECK | 
|  | 6 | +// RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sve2p1 -S -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s | 
|  | 7 | +// RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sve2p1 -S -disable-O0-optnone -Werror -Wall -emit-llvm -o - -x c++ %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s -check-prefix=CPP-CHECK | 
|  | 8 | +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve2p1 -target-feature -S -disable-O0-optnone -Werror -Wall -o /dev/null %s | 
|  | 9 | + | 
|  | 10 | +#include <arm_sve.h> | 
|  | 11 | + | 
|  | 12 | +#ifdef SVE_OVERLOADED_FORMS | 
|  | 13 | +// A simple used,unused... macro, long enough to represent any SVE builtin. | 
|  | 14 | +#define SVE_ACLE_FUNC(A1,A2_UNUSED,A3,A4_UNUSED) A1##A3 | 
|  | 15 | +#else | 
|  | 16 | +#define SVE_ACLE_FUNC(A1,A2,A3,A4) A1##A2##A3##A4 | 
|  | 17 | +#endif | 
|  | 18 | + | 
|  | 19 | +// BFMLSLB | 
|  | 20 | + | 
|  | 21 | + | 
|  | 22 | +// CHECK-LABEL: @test_bfmlslb( | 
|  | 23 | +// CHECK-NEXT:  entry: | 
|  | 24 | +// CHECK-NEXT:    [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.bfmlslb(<vscale x 4 x float> [[ZDA:%.*]], <vscale x 8 x bfloat> [[ZN:%.*]], <vscale x 8 x bfloat> [[ZM:%.*]]) | 
|  | 25 | +// CHECK-NEXT:    ret <vscale x 4 x float> [[TMP0]] | 
|  | 26 | +// | 
|  | 27 | +// CPP-CHECK-LABEL: @_Z12test_bfmlslbu13__SVFloat32_tu14__SVBFloat16_tu14__SVBFloat16_t( | 
|  | 28 | +// CPP-CHECK-NEXT:  entry: | 
|  | 29 | +// CPP-CHECK-NEXT:    [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.bfmlslb(<vscale x 4 x float> [[ZDA:%.*]], <vscale x 8 x bfloat> [[ZN:%.*]], <vscale x 8 x bfloat> [[ZM:%.*]]) | 
|  | 30 | +// CPP-CHECK-NEXT:    ret <vscale x 4 x float> [[TMP0]] | 
|  | 31 | +// | 
|  | 32 | +svfloat32_t test_bfmlslb(svfloat32_t zda, svbfloat16_t zn, svbfloat16_t zm) | 
|  | 33 | +{ | 
|  | 34 | +  return SVE_ACLE_FUNC(svbfmlslb,_f32,,)(zda, zn, zm); | 
|  | 35 | +} | 
|  | 36 | + | 
|  | 37 | + | 
|  | 38 | +// CHECK-LABEL: @test_bfmlslb_lane( | 
|  | 39 | +// CHECK-NEXT:  entry: | 
|  | 40 | +// CHECK-NEXT:    [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.bfmlslb.lane(<vscale x 4 x float> [[ZDA:%.*]], <vscale x 8 x bfloat> [[ZN:%.*]], <vscale x 8 x bfloat> [[ZM:%.*]], i32 7) | 
|  | 41 | +// CHECK-NEXT:    ret <vscale x 4 x float> [[TMP0]] | 
|  | 42 | +// | 
|  | 43 | +// CPP-CHECK-LABEL: @_Z17test_bfmlslb_laneu13__SVFloat32_tu14__SVBFloat16_tu14__SVBFloat16_t( | 
|  | 44 | +// CPP-CHECK-NEXT:  entry: | 
|  | 45 | +// CPP-CHECK-NEXT:    [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.bfmlslb.lane(<vscale x 4 x float> [[ZDA:%.*]], <vscale x 8 x bfloat> [[ZN:%.*]], <vscale x 8 x bfloat> [[ZM:%.*]], i32 7) | 
|  | 46 | +// CPP-CHECK-NEXT:    ret <vscale x 4 x float> [[TMP0]] | 
|  | 47 | +// | 
|  | 48 | +svfloat32_t test_bfmlslb_lane(svfloat32_t zda, svbfloat16_t zn, svbfloat16_t zm) | 
|  | 49 | +{ | 
|  | 50 | +  return SVE_ACLE_FUNC(svbfmlslb_lane,_f32,,)(zda, zn, zm, 7); | 
|  | 51 | +} | 
|  | 52 | + | 
|  | 53 | +// BFMLSLT | 
|  | 54 | + | 
|  | 55 | + | 
|  | 56 | +// CHECK-LABEL: @test_bfmlslt( | 
|  | 57 | +// CHECK-NEXT:  entry: | 
|  | 58 | +// CHECK-NEXT:    [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.bfmlslt(<vscale x 4 x float> [[ZDA:%.*]], <vscale x 8 x bfloat> [[ZN:%.*]], <vscale x 8 x bfloat> [[ZM:%.*]]) | 
|  | 59 | +// CHECK-NEXT:    ret <vscale x 4 x float> [[TMP0]] | 
|  | 60 | +// | 
|  | 61 | +// CPP-CHECK-LABEL: @_Z12test_bfmlsltu13__SVFloat32_tu14__SVBFloat16_tu14__SVBFloat16_t( | 
|  | 62 | +// CPP-CHECK-NEXT:  entry: | 
|  | 63 | +// CPP-CHECK-NEXT:    [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.bfmlslt(<vscale x 4 x float> [[ZDA:%.*]], <vscale x 8 x bfloat> [[ZN:%.*]], <vscale x 8 x bfloat> [[ZM:%.*]]) | 
|  | 64 | +// CPP-CHECK-NEXT:    ret <vscale x 4 x float> [[TMP0]] | 
|  | 65 | +// | 
|  | 66 | +svfloat32_t test_bfmlslt(svfloat32_t zda, svbfloat16_t zn, svbfloat16_t zm) | 
|  | 67 | +{ | 
|  | 68 | +  return SVE_ACLE_FUNC(svbfmlslt,_f32,,)(zda, zn, zm); | 
|  | 69 | +} | 
|  | 70 | + | 
|  | 71 | + | 
|  | 72 | +// CHECK-LABEL: @test_bfmlslt_lane( | 
|  | 73 | +// CHECK-NEXT:  entry: | 
|  | 74 | +// CHECK-NEXT:    [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.bfmlslt.lane(<vscale x 4 x float> [[ZDA:%.*]], <vscale x 8 x bfloat> [[ZN:%.*]], <vscale x 8 x bfloat> [[ZM:%.*]], i32 7) | 
|  | 75 | +// CHECK-NEXT:    ret <vscale x 4 x float> [[TMP0]] | 
|  | 76 | +// | 
|  | 77 | +// CPP-CHECK-LABEL: @_Z17test_bfmlslt_laneu13__SVFloat32_tu14__SVBFloat16_tu14__SVBFloat16_t( | 
|  | 78 | +// CPP-CHECK-NEXT:  entry: | 
|  | 79 | +// CPP-CHECK-NEXT:    [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.bfmlslt.lane(<vscale x 4 x float> [[ZDA:%.*]], <vscale x 8 x bfloat> [[ZN:%.*]], <vscale x 8 x bfloat> [[ZM:%.*]], i32 7) | 
|  | 80 | +// CPP-CHECK-NEXT:    ret <vscale x 4 x float> [[TMP0]] | 
|  | 81 | +// | 
|  | 82 | +svfloat32_t test_bfmlslt_lane(svfloat32_t zda, svbfloat16_t zn, svbfloat16_t zm) | 
|  | 83 | +{ | 
|  | 84 | +  return SVE_ACLE_FUNC(svbfmlslt_lane,_f32,,)(zda, zn, zm, 7); | 
|  | 85 | +} | 
0 commit comments