xref: /aosp_15_r20/external/clang/test/Parser/MicrosoftExtensions.c (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: %clang_cc1 -triple i386-mingw32 -fsyntax-only -Wno-missing-declarations -verify -fms-extensions  %s
2*67e74705SXin Li __stdcall int func0(void);
3*67e74705SXin Li int __stdcall func(void);
4*67e74705SXin Li typedef int (__cdecl *tptr)(void);
5*67e74705SXin Li void (*__fastcall fastpfunc)(void);
6*67e74705SXin Li extern __declspec(dllimport) void __stdcall VarR4FromDec(void);
7*67e74705SXin Li __declspec(deprecated) __declspec(deprecated) char * __cdecl ltoa( long _Val, char * _DstBuf, int _Radix);
8*67e74705SXin Li __declspec(safebuffers) __declspec(noalias) __declspec(restrict) void * __cdecl xxx(void *_Memory); /* expected-warning{{__declspec attribute 'safebuffers' is not supported}} */
9*67e74705SXin Li typedef __w64 unsigned long ULONG_PTR, *PULONG_PTR;
10*67e74705SXin Li 
PtrToPtr64(const void * p)11*67e74705SXin Li void * __ptr64 PtrToPtr64(const void *p) {
12*67e74705SXin Li   return((void * __ptr64) (unsigned __int64) (ULONG_PTR)p );
13*67e74705SXin Li }
14*67e74705SXin Li 
PtrToPtr32(const void * p)15*67e74705SXin Li void * __ptr32 PtrToPtr32(const void *p) {
16*67e74705SXin Li   return((void * __ptr32) (unsigned __int32) (ULONG_PTR)p );
17*67e74705SXin Li }
18*67e74705SXin Li 
19*67e74705SXin Li /* Both inline and __forceinline is OK. */
pr8264(void)20*67e74705SXin Li inline void __forceinline pr8264(void) {}
pr8264_1(void)21*67e74705SXin Li __forceinline void inline pr8264_1(void) {}
pr8264_2(void)22*67e74705SXin Li void inline __forceinline pr8264_2(void) {}
pr8264_3(void)23*67e74705SXin Li void __forceinline inline pr8264_3(void) {}
24*67e74705SXin Li /* But duplicate __forceinline causes warning. */
pr8264_4(void)25*67e74705SXin Li void __forceinline __forceinline pr8264_4(void) {  /* expected-warning{{duplicate '__forceinline' declaration specifier}} */
26*67e74705SXin Li }
27*67e74705SXin Li 
foo99(void)28*67e74705SXin Li _inline int foo99(void) { return 99; }
29*67e74705SXin Li 
test_ms_alignof_alias(void)30*67e74705SXin Li void test_ms_alignof_alias(void) {
31*67e74705SXin Li   unsigned int s = _alignof(int);
32*67e74705SXin Li   s = __builtin_alignof(int);
33*67e74705SXin Li }
34*67e74705SXin Li 
35*67e74705SXin Li /* Charify extension. */
36*67e74705SXin Li #define FOO(x) #@x
37*67e74705SXin Li char x = FOO(a);
38*67e74705SXin Li #define HASHAT #@
39*67e74705SXin Li #define MISSING_ARG(x) #@
40*67e74705SXin Li /* expected-error@-1 {{'#@' is not followed by a macro parameter}} */
41*67e74705SXin Li 
42*67e74705SXin Li typedef enum E { e1 };
43*67e74705SXin Li 
44*67e74705SXin Li enum __declspec(deprecated) E2 { i, j, k }; /* expected-note {{'E2' has been explicitly marked deprecated here}} */
45*67e74705SXin Li __declspec(deprecated) enum E3 { a, b, c } e; /* expected-note {{'e' has been explicitly marked deprecated here}} */
46*67e74705SXin Li 
deprecated_enum_test(void)47*67e74705SXin Li void deprecated_enum_test(void) {
48*67e74705SXin Li   /* Test to make sure the deprecated warning follows the right thing */
49*67e74705SXin Li   enum E2 e1;  /* expected-warning {{'E2' is deprecated}} */
50*67e74705SXin Li   enum E3 e2; /* No warning expected, the deprecation follows the variable */
51*67e74705SXin Li   enum E3 e3 = e;  /* expected-warning {{'e' is deprecated}} */
52*67e74705SXin Li }
53*67e74705SXin Li 
54*67e74705SXin Li /* Microsoft attribute tests */
55*67e74705SXin Li [returnvalue:SA_Post( attr=1)]
56*67e74705SXin Li int foo1([SA_Post(attr=1)] void *param);
57*67e74705SXin Li 
58*67e74705SXin Li [unbalanced(attribute) /* expected-note {{to match this '['}} */
59*67e74705SXin Li void f(void); /* expected-error {{expected ']'}} */
60*67e74705SXin Li 
61*67e74705SXin Li void ms_intrinsics(int a) {
62*67e74705SXin Li   __noop();
63*67e74705SXin Li   __assume(a);
64*67e74705SXin Li   __debugbreak();
65*67e74705SXin Li }
66*67e74705SXin Li 
67*67e74705SXin Li struct __declspec(frobble) S1 {};	/* expected-warning {{__declspec attribute 'frobble' is not supported}} */
68*67e74705SXin Li struct __declspec(12) S2 {};	/* expected-error {{__declspec attributes must be an identifier or string literal}} */
69*67e74705SXin Li struct __declspec("testing") S3 {}; /* expected-warning {{__declspec attribute '"testing"' is not supported}} */
70*67e74705SXin Li 
71*67e74705SXin Li /* declspecs with arguments cannot have an empty argument list, even if the
72*67e74705SXin Li    arguments are optional. */
73*67e74705SXin Li __declspec(deprecated()) void dep_func_test(void); /* expected-error {{parentheses must be omitted if 'deprecated' attribute's argument list is empty}} */
74*67e74705SXin Li __declspec(deprecated) void dep_func_test2(void);
75*67e74705SXin Li __declspec(deprecated("")) void dep_func_test3(void);
76*67e74705SXin Li 
77*67e74705SXin Li /* Ensure multiple declspec attributes are supported */
78*67e74705SXin Li struct __declspec(align(8) deprecated) S4 {};
79*67e74705SXin Li 
80*67e74705SXin Li /* But multiple declspecs must still be legal */
81*67e74705SXin Li struct __declspec(deprecated frobble "testing") S5 {};  /* expected-warning {{__declspec attribute 'frobble' is not supported}} expected-warning {{__declspec attribute '"testing"' is not supported}} */
82*67e74705SXin Li struct __declspec(unknown(12) deprecated) S6 {};	/* expected-warning {{__declspec attribute 'unknown' is not supported}}*/
83*67e74705SXin Li 
84*67e74705SXin Li int * __sptr psp;
85*67e74705SXin Li int * __uptr pup;
86*67e74705SXin Li /* Either ordering is acceptable */
87*67e74705SXin Li int * __ptr32 __sptr psp32;
88*67e74705SXin Li int * __ptr32 __uptr pup32;
89*67e74705SXin Li int * __sptr __ptr64 psp64;
90*67e74705SXin Li int * __uptr __ptr64 pup64;
91*67e74705SXin Li 
92*67e74705SXin Li /* Legal to have nested pointer attributes */
93*67e74705SXin Li int * __sptr * __ptr32 ppsp32;
94*67e74705SXin Li 
95*67e74705SXin Li // Ignored type qualifiers after comma in declarator lists
96*67e74705SXin Li typedef int ignored_quals_dummy1, const volatile __ptr32 __ptr64 __w64 __unaligned __sptr __uptr ignored_quals1; // expected-warning {{qualifiers after comma in declarator list are ignored}}
97*67e74705SXin Li typedef void(*ignored_quals_dummy2)(), __fastcall ignored_quals2; // expected-warning {{qualifiers after comma in declarator list are ignored}}
98*67e74705SXin Li typedef void(*ignored_quals_dummy3)(), __stdcall ignored_quals3; // expected-warning {{qualifiers after comma in declarator list are ignored}}
99*67e74705SXin Li typedef void(*ignored_quals_dummy4)(), __thiscall ignored_quals4; // expected-warning {{qualifiers after comma in declarator list are ignored}}
100*67e74705SXin Li typedef void(*ignored_quals_dummy5)(), __cdecl ignored_quals5; // expected-warning {{qualifiers after comma in declarator list are ignored}}
101*67e74705SXin Li typedef void(*ignored_quals_dummy6)(), __vectorcall ignored_quals6; // expected-warning {{qualifiers after comma in declarator list are ignored}}
102*67e74705SXin Li 
103*67e74705SXin Li __declspec(align(16)) struct align_before_key1 {};
104*67e74705SXin Li __declspec(align(16)) struct align_before_key2 {} align_before_key2_var;
105*67e74705SXin Li __declspec(align(16)) struct align_before_key3 {} *align_before_key3_var;
106*67e74705SXin Li _Static_assert(__alignof(struct align_before_key1) == 16, "");
107*67e74705SXin Li _Static_assert(__alignof(struct align_before_key2) == 16, "");
108*67e74705SXin Li _Static_assert(__alignof(struct align_before_key3) == 16, "");
109