1*a07aba5dSTimm Baeder // RUN: %clang_cc1 -fsyntax-only -verify=both,ref -triple x86_64-linux %s -Wno-tautological-pointer-compare -Wno-pointer-to-int-cast 2*a07aba5dSTimm Baeder // RUN: %clang_cc1 -fsyntax-only -verify=both,expected -triple x86_64-linux %s -Wno-tautological-pointer-compare -Wno-pointer-to-int-cast -fexperimental-new-constant-interpreter -DNEW_INTERP 3*a07aba5dSTimm Baeder // RUN: %clang_cc1 -fsyntax-only -verify=both,ref -triple powerpc64-ibm-aix-xcoff %s -Wno-tautological-pointer-compare -Wno-pointer-to-int-cast 4*a07aba5dSTimm Baeder // RUN: %clang_cc1 -fsyntax-only -verify=both,expected -triple powerpc64-ibm-aix-xcoff %s -Wno-tautological-pointer-compare -Wno-pointer-to-int-cast -fexperimental-new-constant-interpreter -DNEW_INTERP 5*a07aba5dSTimm Baeder 6*a07aba5dSTimm Baeder /// This is a version of test/Sema/const-eval.c with the 7*a07aba5dSTimm Baeder /// tests commented out that the new constant expression interpreter does 8*a07aba5dSTimm Baeder /// not support yet. They are all marked with the NEW_INTERP define: 9*a07aba5dSTimm Baeder /// 10*a07aba5dSTimm Baeder /// - builtin_constant_p 11*a07aba5dSTimm Baeder /// - unions 12*a07aba5dSTimm Baeder 13*a07aba5dSTimm Baeder 14*a07aba5dSTimm Baeder #define EVAL_EXPR(testno, expr) enum { test##testno = (expr) }; struct check_positive##testno { int a[test##testno]; }; 15*a07aba5dSTimm Baeder int x; 16*a07aba5dSTimm Baeder EVAL_EXPR(1, (_Bool)&x) 17*a07aba5dSTimm Baeder EVAL_EXPR(2, (int)(1.0+(double)4)) 18*a07aba5dSTimm Baeder EVAL_EXPR(3, (int)(1.0+(float)4.0)) 19*a07aba5dSTimm Baeder EVAL_EXPR(4, (_Bool)(1 ? (void*)&x : 0)) 20*a07aba5dSTimm Baeder EVAL_EXPR(5, (_Bool)(int[]){0}) 21*a07aba5dSTimm Baeder struct y {int x,y;}; 22*a07aba5dSTimm Baeder EVAL_EXPR(6, (int)(1+(struct y*)0)) 23*a07aba5dSTimm Baeder _Static_assert((long)&((struct y*)0)->y > 0, ""); 24*a07aba5dSTimm Baeder EVAL_EXPR(7, (int)&((struct y*)0)->y) 25*a07aba5dSTimm Baeder EVAL_EXPR(8, (_Bool)"asdf") 26*a07aba5dSTimm Baeder EVAL_EXPR(9, !!&x) 27*a07aba5dSTimm Baeder EVAL_EXPR(10, ((void)1, 12)) 28*a07aba5dSTimm Baeder void g0(void); 29*a07aba5dSTimm Baeder EVAL_EXPR(11, (g0(), 12)) // both-error {{not an integer constant expression}} 30*a07aba5dSTimm Baeder EVAL_EXPR(12, 1.0&&2.0) 31*a07aba5dSTimm Baeder EVAL_EXPR(13, x || 3.0) // both-error {{not an integer constant expression}} 32*a07aba5dSTimm Baeder 33*a07aba5dSTimm Baeder unsigned int l_19 = 1; 34*a07aba5dSTimm Baeder EVAL_EXPR(14, (1 ^ l_19) && 1); // both-error {{not an integer constant expression}} 35*a07aba5dSTimm Baeder 36*a07aba5dSTimm Baeder void f(void) 37*a07aba5dSTimm Baeder { 38*a07aba5dSTimm Baeder int a; 39*a07aba5dSTimm Baeder EVAL_EXPR(15, (_Bool)&a); 40*a07aba5dSTimm Baeder } 41*a07aba5dSTimm Baeder 42*a07aba5dSTimm Baeder _Complex float g16 = (1.0f + 1.0fi); 43*a07aba5dSTimm Baeder 44*a07aba5dSTimm Baeder // ?: in constant expressions. 45*a07aba5dSTimm Baeder int g17[(3?:1) - 2]; 46*a07aba5dSTimm Baeder 47*a07aba5dSTimm Baeder EVAL_EXPR(18, ((int)((void*)10 + 10)) == 20 ? 1 : -1); 48*a07aba5dSTimm Baeder 49*a07aba5dSTimm Baeder struct s { 50*a07aba5dSTimm Baeder int a[(int)-1.0f]; // both-error {{array size is negative}} 51*a07aba5dSTimm Baeder }; 52*a07aba5dSTimm Baeder 53*a07aba5dSTimm Baeder EVAL_EXPR(19, ((int)&*(char*)10 == 10 ? 1 : -1)); 54*a07aba5dSTimm Baeder 55*a07aba5dSTimm Baeder #ifndef NEW_INTERP 56*a07aba5dSTimm Baeder EVAL_EXPR(20, __builtin_constant_p(*((int*) 10))); 57*a07aba5dSTimm Baeder #endif 58*a07aba5dSTimm Baeder 59*a07aba5dSTimm Baeder EVAL_EXPR(21, (__imag__ 2i) == 2 ? 1 : -1); 60*a07aba5dSTimm Baeder 61*a07aba5dSTimm Baeder EVAL_EXPR(22, (__real__ (2i+3)) == 3 ? 1 : -1); 62*a07aba5dSTimm Baeder 63*a07aba5dSTimm Baeder int g23[(int)(1.0 / 1.0)] = { 1 }; // both-warning {{folded to constant array}} 64*a07aba5dSTimm Baeder int g24[(int)(1.0 / 1.0)] = { 1 , 2 }; // both-warning {{folded to constant array}} \ 65*a07aba5dSTimm Baeder // both-warning {{excess elements in array initializer}} 66*a07aba5dSTimm Baeder int g25[(int)(1.0 + 1.0)], g26 = sizeof(g25); // both-warning {{folded to constant array}} 67*a07aba5dSTimm Baeder 68*a07aba5dSTimm Baeder EVAL_EXPR(26, (_Complex double)0 ? -1 : 1) 69*a07aba5dSTimm Baeder EVAL_EXPR(27, (_Complex int)0 ? -1 : 1) 70*a07aba5dSTimm Baeder EVAL_EXPR(28, (_Complex double)1 ? 1 : -1) 71*a07aba5dSTimm Baeder EVAL_EXPR(29, (_Complex int)1 ? 1 : -1) 72*a07aba5dSTimm Baeder 73*a07aba5dSTimm Baeder // PR4027 74*a07aba5dSTimm Baeder struct a { int x, y; }; 75*a07aba5dSTimm Baeder static struct a V2 = (struct a)(struct a){ 1, 2}; 76*a07aba5dSTimm Baeder static const struct a V1 = (struct a){ 1, 2}; 77*a07aba5dSTimm Baeder 78*a07aba5dSTimm Baeder EVAL_EXPR(30, (int)(_Complex float)((1<<30)-1) == (1<<30) ? 1 : -1) 79*a07aba5dSTimm Baeder EVAL_EXPR(31, (int*)0 == (int*)0 ? 1 : -1) 80*a07aba5dSTimm Baeder EVAL_EXPR(32, (int*)0 != (int*)0 ? -1 : 1) 81*a07aba5dSTimm Baeder EVAL_EXPR(33, (void*)0 - (void*)0 == 0 ? 1 : -1) 82*a07aba5dSTimm Baeder 83*a07aba5dSTimm Baeder void foo(void) {} 84*a07aba5dSTimm Baeder EVAL_EXPR(34, (foo == (void *)0) ? -1 : 1) 85*a07aba5dSTimm Baeder 86*a07aba5dSTimm Baeder // No PR. Mismatched bitwidths lead to a crash on second evaluation. 87*a07aba5dSTimm Baeder const _Bool constbool = 0; 88*a07aba5dSTimm Baeder EVAL_EXPR(35, constbool) 89*a07aba5dSTimm Baeder EVAL_EXPR(36, constbool) 90*a07aba5dSTimm Baeder 91*a07aba5dSTimm Baeder EVAL_EXPR(37, ((void)1,2.0) == 2.0 ? 1 : -1) 92*a07aba5dSTimm Baeder EVAL_EXPR(38, __builtin_expect(1,1) == 1 ? 1 : -1) 93*a07aba5dSTimm Baeder 94*a07aba5dSTimm Baeder // PR7884 95*a07aba5dSTimm Baeder EVAL_EXPR(39, __real__(1.f) == 1 ? 1 : -1) 96*a07aba5dSTimm Baeder EVAL_EXPR(40, __imag__(1.f) == 0 ? 1 : -1) 97*a07aba5dSTimm Baeder 98*a07aba5dSTimm Baeder // From gcc testsuite 99*a07aba5dSTimm Baeder EVAL_EXPR(41, (int)(1+(_Complex unsigned)2)) 100*a07aba5dSTimm Baeder 101*a07aba5dSTimm Baeder void rdar8875946(void) { 102*a07aba5dSTimm Baeder double _Complex P; 103*a07aba5dSTimm Baeder float _Complex P2 = 3.3f + P; 104*a07aba5dSTimm Baeder } 105*a07aba5dSTimm Baeder 106*a07aba5dSTimm Baeder double d = (d = 0.0); // both-error {{not a compile-time constant}} 107*a07aba5dSTimm Baeder double d2 = ++d; // both-error {{not a compile-time constant}} 108*a07aba5dSTimm Baeder 109*a07aba5dSTimm Baeder int n = 2; 110*a07aba5dSTimm Baeder int intLvalue[*(int*)((long)&n ?: 1)] = { 1, 2 }; // both-error {{variable length array}} 111*a07aba5dSTimm Baeder 112*a07aba5dSTimm Baeder union u { int a; char b[4]; }; 113*a07aba5dSTimm Baeder char c = ((union u)(123456)).b[0]; // both-error {{not a compile-time constant}} 114*a07aba5dSTimm Baeder 115*a07aba5dSTimm Baeder #ifndef NEW_INTERP 116*a07aba5dSTimm Baeder extern const int weak_int __attribute__((weak)); 117*a07aba5dSTimm Baeder const int weak_int = 42; 118*a07aba5dSTimm Baeder int weak_int_test = weak_int; // both-error {{not a compile-time constant}} 119*a07aba5dSTimm Baeder #endif 120*a07aba5dSTimm Baeder 121*a07aba5dSTimm Baeder int literalVsNull1 = "foo" == 0; 122*a07aba5dSTimm Baeder int literalVsNull2 = 0 == "foo"; 123*a07aba5dSTimm Baeder 124*a07aba5dSTimm Baeder // PR11385. 125*a07aba5dSTimm Baeder int castViaInt[*(int*)(unsigned long)"test"]; // both-error {{variable length array}} 126*a07aba5dSTimm Baeder 127*a07aba5dSTimm Baeder // PR11391. 128*a07aba5dSTimm Baeder #ifndef NEW_INTERP 129*a07aba5dSTimm Baeder struct PR11391 { _Complex float f; } pr11391; 130*a07aba5dSTimm Baeder EVAL_EXPR(42, __builtin_constant_p(pr11391.f = 1)) 131*a07aba5dSTimm Baeder #endif 132*a07aba5dSTimm Baeder 133*a07aba5dSTimm Baeder // PR12043 134*a07aba5dSTimm Baeder float varfloat; 135*a07aba5dSTimm Baeder const float constfloat = 0; 136*a07aba5dSTimm Baeder EVAL_EXPR(43, varfloat && constfloat) // both-error {{not an integer constant expression}} 137*a07aba5dSTimm Baeder EVAL_EXPR(45, ((char*)-1) + 1 == 0 ? 1 : -1) 138*a07aba5dSTimm Baeder EVAL_EXPR(46, ((char*)-1) + 1 < (char*) -1 ? 1 : -1) 139*a07aba5dSTimm Baeder EVAL_EXPR(47, &x < &x + 1 ? 1 : -1) 140*a07aba5dSTimm Baeder EVAL_EXPR(48, &x != &x - 1 ? 1 : -1) 141*a07aba5dSTimm Baeder EVAL_EXPR(49, &x < &x - 100 ? 1 : -1) // ref-error {{not an integer constant expression}} 142*a07aba5dSTimm Baeder 143*a07aba5dSTimm Baeder extern struct Test50S Test50; 144*a07aba5dSTimm Baeder EVAL_EXPR(50, &Test50 < (struct Test50S*)((unsigned long)&Test50 + 10)) // both-error {{not an integer constant expression}} 145*a07aba5dSTimm Baeder 146*a07aba5dSTimm Baeder EVAL_EXPR(51, 0 != (float)1e99) 147*a07aba5dSTimm Baeder 148*a07aba5dSTimm Baeder // PR21945 149*a07aba5dSTimm Baeder void PR21945(void) { int i = (({}), 0l); } 150*a07aba5dSTimm Baeder 151*a07aba5dSTimm Baeder void PR24622(void); 152*a07aba5dSTimm Baeder struct PR24622 {} pr24622; 153*a07aba5dSTimm Baeder EVAL_EXPR(52, &pr24622 == (void *)&PR24622); 154*a07aba5dSTimm Baeder 155*a07aba5dSTimm Baeder // We evaluate these by providing 2s' complement semantics in constant 156*a07aba5dSTimm Baeder // expressions, like we do for integers. 157*a07aba5dSTimm Baeder void *PR28739a = (__int128)(unsigned long)-1 + &PR28739a; // both-warning {{the pointer incremented by 18446744073709551615 refers past the last possible element for an array in 64-bit address space containing 64-bit (8-byte) elements (max possible 2305843009213693952 elements)}} 158*a07aba5dSTimm Baeder 159*a07aba5dSTimm Baeder void *PR28739b = &PR28739b + (__int128)(unsigned long)-1; // both-warning {{refers past the last possible element}} 160*a07aba5dSTimm Baeder __int128 PR28739c = (&PR28739c + (__int128)(unsigned long)-1) - &PR28739c; // both-warning {{refers past the last possible element}} 161*a07aba5dSTimm Baeder void *PR28739d = &(&PR28739d)[(__int128)(unsigned long)-1]; // both-warning {{refers past the last possible element}} 162*a07aba5dSTimm Baeder 163*a07aba5dSTimm Baeder struct PR35214_X { 164*a07aba5dSTimm Baeder int k; 165*a07aba5dSTimm Baeder int arr[]; 166*a07aba5dSTimm Baeder }; 167*a07aba5dSTimm Baeder int PR35214_x; 168*a07aba5dSTimm Baeder int PR35214_y = ((struct PR35214_X *)&PR35214_x)->arr[1]; // both-error {{not a compile-time constant}} 169*a07aba5dSTimm Baeder #ifndef NEW_INTERP 170*a07aba5dSTimm Baeder int *PR35214_z = &((struct PR35214_X *)&PR35214_x)->arr[1]; // ok, &PR35214_x + 2 171*a07aba5dSTimm Baeder #endif 172*a07aba5dSTimm Baeder 173*a07aba5dSTimm Baeder /// From const-eval-64.c 174*a07aba5dSTimm Baeder EVAL_EXPR(53, ((char*)-1LL) + 1 == 0 ? 1 : -1) 175*a07aba5dSTimm Baeder EVAL_EXPR(54, ((char*)-1LL) + 1 < (char*) -1 ? 1 : -1) 176*a07aba5dSTimm Baeder 177*a07aba5dSTimm Baeder /// === Additions === 178*a07aba5dSTimm Baeder #if __SIZEOF_INT__ == 4 179*a07aba5dSTimm Baeder typedef __INTPTR_TYPE__ intptr_t; 180*a07aba5dSTimm Baeder const intptr_t A = (intptr_t)(((int*) 0) + 1); 181*a07aba5dSTimm Baeder const intptr_t B = (intptr_t)(((char*)0) + 3); 182*a07aba5dSTimm Baeder _Static_assert(A > B, ""); 183*a07aba5dSTimm Baeder #else 184*a07aba5dSTimm Baeder #error :( 185*a07aba5dSTimm Baeder #endif 186