mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-12 09:41:26 +00:00
e6171e87e1
The -fallow-half-arguments-and-returns option was removed in 59528e4bdb27ed4ab3, replaced with an always-on target option under AArch64/Arm. There are two tests - fp16-sema.c and renderscripts.rs that test that an error is produced for __fp16 function args/returns, which are now expected to pass for Arm/AArch64. i.e they no longer give the same error as before on native Arm/AArch64 machines. Alter the targets of those tests to compensate.
38 lines
1.4 KiB
C
38 lines
1.4 KiB
C
// RUN: %clang_cc1 -fsyntax-only -triple x86_64-pc-linux-gnu -Wno-strict-prototypes -verify %s
|
|
// // REQUIRES: x86-registered-target
|
|
|
|
// Functions cannot have parameters of type __fp16.
|
|
extern void f (__fp16); // expected-error {{parameters cannot have __fp16 type; did you forget * ?}}
|
|
extern void g (__fp16 *);
|
|
|
|
extern void (*pf) (__fp16); // expected-error {{parameters cannot have __fp16 type; did you forget * ?}}
|
|
extern void (*pg) (__fp16*);
|
|
|
|
typedef void(*tf) (__fp16); // expected-error {{parameters cannot have __fp16 type; did you forget * ?}}
|
|
typedef void(*tg) (__fp16*);
|
|
|
|
void kf(a)
|
|
__fp16 a; { // expected-error {{parameters cannot have __fp16 type; did you forget * ?}}
|
|
}
|
|
|
|
void kg(a)
|
|
__fp16 *a; {
|
|
}
|
|
|
|
// Functions cannot return type __fp16.
|
|
extern __fp16 f1 (void); // expected-error {{function return value cannot have __fp16 type; did you forget * ?}}
|
|
extern __fp16 *g1 (void);
|
|
|
|
extern __fp16 (*pf1) (void); // expected-error {{function return value cannot have __fp16 type; did you forget * ?}}
|
|
extern __fp16 *(*gf1) (void);
|
|
|
|
typedef __fp16 (*tf1) (void); // expected-error {{function return value cannot have __fp16 type; did you forget * ?}}
|
|
typedef __fp16 *(*tg1) (void);
|
|
|
|
void testComplex() {
|
|
// FIXME: Should these be valid?
|
|
_Complex __fp16 a; // expected-error {{'_Complex half' is invalid}}
|
|
__fp16 b;
|
|
a = __builtin_complex(b, b); // expected-error {{'_Complex half' is invalid}}
|
|
}
|