// 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