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