Nikita Popov 532dc62b90 [OpaquePtrs][Clang] Add -no-opaque-pointers to tests (NFC)
This adds -no-opaque-pointers to clang tests whose output will
change when opaque pointers are enabled by default. This is
intended to be part of the migration approach described in
https://discourse.llvm.org/t/enabling-opaque-pointers-by-default/61322/9.

The patch has been produced by replacing %clang_cc1 with
%clang_cc1 -no-opaque-pointers for tests that fail with opaque
pointers enabled. Worth noting that this doesn't cover all tests,
there's a remaining ~40 tests not using %clang_cc1 that will need
a followup change.

Differential Revision: https://reviews.llvm.org/D123115
2022-04-07 12:09:47 +02:00

32 lines
1.2 KiB
Common Lisp

// RUN: %clang_cc1 -no-opaque-pointers %s -triple "spirv32-unknown-unknown" -verify -emit-llvm -o - | FileCheck %s -check-prefix=SPIRV32
// RUN: %clang_cc1 -no-opaque-pointers %s -triple "spirv64-unknown-unknown" -verify -emit-llvm -o - | FileCheck %s -check-prefix=SPIRV64
// SPIRV32: target triple = "spirv32-unknown-unknown"
// SPIRV64: target triple = "spirv64-unknown-unknown"
typedef struct {
char c;
void *v;
void *v2;
} my_st;
kernel void foo(global long *arg) {
#if __SPIRV32__ == 1
int res1[sizeof(my_st) == 12 ? 1 : -1]; // expected-no-diagnostics
int res2[sizeof(void *) == 4 ? 1 : -1]; // expected-no-diagnostics
int res3[sizeof(arg) == 4 ? 1 : -1]; // expected-no-diagnostics
#elif __SPIRV64__ == 1
int res1[sizeof(my_st) == 24 ? 1 : -1]; // expected-no-diagnostics
int res2[sizeof(void *) == 8 ? 1 : -1]; // expected-no-diagnostics
int res3[sizeof(arg) == 8 ? 1 : -1]; // expected-no-diagnostics
#endif
my_st *tmp = 0;
// SPIRV32: store i64 4, i64 addrspace(1)*
// SPIRV64: store i64 8, i64 addrspace(1)*
arg[0] = (long)(&tmp->v);
// SPIRV32: store i64 8, i64 addrspace(1)*
// SPIRV64: store i64 16, i64 addrspace(1)*
arg[1] = (long)(&tmp->v2);
}