29 lines
968 B
C
29 lines
968 B
C
// RUN: %clang_cc1 -triple s390x-ibm-linux -target-cpu arch10 -emit-llvm \
|
|
// RUN: -fzvector -o - %s 2>&1 | FileCheck %s --check-prefix=MODFLAG
|
|
//
|
|
// Test the emission of the "s390x-visible-vector-ABI" module flag.
|
|
|
|
// REQUIRES: systemz-registered-target
|
|
// RUN: %clang_cc1 -triple s390x-ibm-linux -target-cpu arch10 -S \
|
|
// RUN: -fzvector -o - %s 2>&1 | FileCheck %s --check-prefix=ARCH10-ASM
|
|
// RUN: %clang_cc1 -triple s390x-ibm-linux -target-cpu arch13 -S \
|
|
// RUN: -fzvector -o - %s 2>&1 | FileCheck %s --check-prefix=ARCH13-ASM
|
|
//
|
|
// Test the emission of a gnu attribute describing the vector ABI.
|
|
|
|
// Call to external function with vector argument.
|
|
|
|
typedef __attribute__((vector_size(16))) int v4i32;
|
|
|
|
void bar(v4i32 Arg);
|
|
|
|
void foo() {
|
|
v4i32 Var = {0, 0, 0, 0};
|
|
bar(Var);
|
|
}
|
|
|
|
//MODFLAG: !llvm.module.flags = !{!0, !1}
|
|
//MODFLAG: !0 = !{i32 2, !"s390x-visible-vector-ABI", i32 1}
|
|
|
|
//ARCH10-ASM: .gnu_attribute 8, 1
|
|
//ARCH13-ASM: .gnu_attribute 8, 2
|