mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-23 21:45:46 -04:00

This makes the C++ ABI depend entirely on the target: MS ABI for -win32 triples, Itanium otherwise. It's no longer possible to do weird combinations. To be able to run a test with a specific ABI without constraining it to a specific triple, new substitutions are added to lit: %itanium_abi_triple and %ms_abi_triple can be used to get the current target triple adjusted to the desired ABI. For example, if the test suite is running with the i686-pc-win32 target, %itanium_abi_triple will expand to i686-pc-mingw32. Differential Revision: http://llvm-reviews.chandlerc.com/D2545 llvm-svn: 199250
88 lines
2.8 KiB
C
88 lines
2.8 KiB
C
// RUN: %clang_cc1 %s -triple %itanium_abi_triple -fsyntax-only -verify -Wc++-compat
|
|
|
|
// Note: Empty C structs are 4 bytes in the Microsoft ABI.
|
|
|
|
struct emp_1 { // expected-warning {{empty struct has size 0 in C, size 1 in C++}}
|
|
};
|
|
|
|
union emp_2 { // expected-warning {{empty union has size 0 in C, size 1 in C++}}
|
|
};
|
|
|
|
struct emp_3 { // expected-warning {{struct has size 0 in C, size 1 in C++}}
|
|
int : 0;
|
|
};
|
|
|
|
union emp_4 { // expected-warning {{union has size 0 in C, size 1 in C++}}
|
|
int : 0;
|
|
};
|
|
|
|
struct emp_5 { // expected-warning {{struct has size 0 in C, size 1 in C++}}
|
|
int : 0;
|
|
int : 0;
|
|
};
|
|
|
|
union emp_6 { // expected-warning {{union has size 0 in C, size 1 in C++}}
|
|
int : 0;
|
|
int : 0;
|
|
};
|
|
|
|
struct emp_7 { // expected-warning {{struct has size 0 in C, size 1 in C++}}
|
|
struct emp_1 f1;
|
|
};
|
|
|
|
union emp_8 { // expected-warning {{union has size 0 in C, size 1 in C++}}
|
|
struct emp_1 f1;
|
|
};
|
|
|
|
struct emp_9 { // expected-warning {{struct has size 0 in C, non-zero size in C++}}
|
|
struct emp_1 f1;
|
|
union emp_2 f2;
|
|
};
|
|
|
|
// Checks for pointer subtraction (PR15683)
|
|
struct emp_1 *func_1p(struct emp_1 *x) { return x - 5; }
|
|
|
|
int func_1() {
|
|
struct emp_1 v[1];
|
|
return v - v; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
|
|
}
|
|
|
|
int func_2(struct emp_1 *x) {
|
|
return 1 + x - x; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
|
|
}
|
|
|
|
int func_3(struct emp_1 *x, struct emp_1 *y) {
|
|
return x - y; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
|
|
}
|
|
|
|
int func_4(struct emp_1 *x, const struct emp_1 *y) {
|
|
return x - y; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
|
|
}
|
|
|
|
int func_5(volatile struct emp_1 *x, const struct emp_1 *y) {
|
|
return x - y; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
|
|
}
|
|
|
|
int func_6() {
|
|
union emp_2 v[1];
|
|
return v - v; // expected-warning {{subtraction of pointers to type 'union emp_2' of zero size has undefined behavior}}
|
|
}
|
|
|
|
struct A; // expected-note {{forward declaration of 'struct A'}}
|
|
|
|
int func_7(struct A *x, struct A *y) {
|
|
return x - y; // expected-error {{arithmetic on a pointer to an incomplete type 'struct A'}}
|
|
}
|
|
|
|
int func_8(struct emp_1 (*x)[10], struct emp_1 (*y)[10]) {
|
|
return x - y; // expected-warning {{subtraction of pointers to type 'struct emp_1 [10]' of zero size has undefined behavior}}
|
|
}
|
|
|
|
int func_9(struct emp_1 (*x)[], struct emp_1 (*y)[]) {
|
|
return x - y; // expected-error {{arithmetic on a pointer to an incomplete type 'struct emp_1 []'}}
|
|
}
|
|
|
|
int func_10(int (*x)[0], int (*y)[0]) {
|
|
return x - y; // expected-warning {{subtraction of pointers to type 'int [0]' of zero size has undefined behavior}}
|
|
}
|