
This patch corresponds to reviews: http://reviews.llvm.org/D15120 http://reviews.llvm.org/D19125 It adds support for the __float128 keyword, literals and target feature to enable it. Based on the latter of the two aforementioned reviews, this feature is enabled on Linux on i386/X86 as well as SystemZ. This is also the second attempt in commiting this feature. The first attempt did not enable it on required platforms which caused failures when compiling type_traits with -std=gnu++11. If you see failures with compiling this header on your platform after this commit, it is likely that your platform needs to have this feature enabled. llvm-svn: 268898
94 lines
4.4 KiB
C
94 lines
4.4 KiB
C
// RUN: %clang_cc1 -triple i686-pc-linux-gnu -DTEST_32BIT_X86 -fsyntax-only \
|
|
// RUN: -verify %s
|
|
// RUN: %clang_cc1 -triple x86_64-pc-linux-gnu -DTEST_64BIT_X86 -fsyntax-only \
|
|
// RUN: -verify %s
|
|
// RUN: %clang_cc1 -triple powerpc64-pc-linux-gnu -DTEST_64BIT_PPC64 -fsyntax-only \
|
|
// RUN: -verify %s
|
|
// RUN: %clang_cc1 -triple x86_64-pc-linux-gnux32 -DTEST_64BIT_X86 -fsyntax-only \
|
|
// RUN: -verify %s
|
|
|
|
typedef int i16_1 __attribute((mode(HI)));
|
|
int i16_1_test[sizeof(i16_1) == 2 ? 1 : -1];
|
|
typedef int i16_2 __attribute((__mode__(__HI__)));
|
|
int i16_2_test[sizeof(i16_1) == 2 ? 1 : -1];
|
|
|
|
typedef float f64 __attribute((mode(DF)));
|
|
int f64_test[sizeof(f64) == 8 ? 1 : -1];
|
|
|
|
typedef int invalid_1 __attribute((mode)); // expected-error{{'mode' attribute takes one argument}}
|
|
typedef int invalid_2 __attribute((mode())); // expected-error{{'mode' attribute takes one argument}}
|
|
typedef int invalid_3 __attribute((mode(II))); // expected-error{{unknown machine mode}}
|
|
typedef struct {int i,j,k;} invalid_4 __attribute((mode(SI))); // expected-error{{mode attribute only supported for integer and floating-point types}}
|
|
typedef float invalid_5 __attribute((mode(SI))); // expected-error{{type of machine mode does not match type of base type}}
|
|
typedef int invalid_6 __attribute__((mode(12))); // expected-error{{'mode' attribute requires an identifier}}
|
|
|
|
typedef unsigned unwind_word __attribute((mode(unwind_word)));
|
|
|
|
int **__attribute((mode(QI)))* i32; // expected-error{{mode attribute}}
|
|
|
|
__attribute__((mode(QI))) int invalid_func() { return 1; } // expected-error{{'mode' attribute only applies to variables, enums, fields and typedefs}}
|
|
enum invalid_enum { A1 __attribute__((mode(QI))) }; // expected-error{{'mode' attribute only applies to variables, enums, fields and typedefs}}
|
|
|
|
typedef _Complex double c32 __attribute((mode(SC)));
|
|
int c32_test[sizeof(c32) == 8 ? 1 : -1];
|
|
typedef _Complex float c64 __attribute((mode(DC)));
|
|
|
|
#ifndef TEST_64BIT_PPC64 // Note, 'XC' mode is illegal for PPC64 machines.
|
|
typedef _Complex float c80 __attribute((mode(XC)));
|
|
#endif
|
|
|
|
// PR6108: Correctly select 'long' built in type on 64-bit platforms for 64 bit
|
|
// modes. Also test other mode-based conversions.
|
|
typedef int i8_mode_t __attribute__ ((__mode__ (__QI__)));
|
|
typedef unsigned int ui8_mode_t __attribute__ ((__mode__ (__QI__)));
|
|
typedef int i16_mode_t __attribute__ ((__mode__ (__HI__)));
|
|
typedef unsigned int ui16_mode_t __attribute__ ((__mode__ (__HI__)));
|
|
typedef int i32_mode_t __attribute__ ((__mode__ (__SI__)));
|
|
typedef unsigned int ui32_mode_t __attribute__ ((__mode__ (__SI__)));
|
|
typedef int i64_mode_t __attribute__ ((__mode__ (__DI__)));
|
|
typedef unsigned int ui64_mode_t __attribute__ ((__mode__ (__DI__)));
|
|
void f_i8_arg(i8_mode_t* x) { (void)x; }
|
|
void f_ui8_arg(ui8_mode_t* x) { (void)x; }
|
|
void f_i16_arg(i16_mode_t* x) { (void)x; }
|
|
void f_ui16_arg(ui16_mode_t* x) { (void)x; }
|
|
void f_i32_arg(i32_mode_t* x) { (void)x; }
|
|
void f_ui32_arg(ui32_mode_t* x) { (void)x; }
|
|
void f_i64_arg(i64_mode_t* x) { (void)x; }
|
|
void f_ui64_arg(ui64_mode_t* x) { (void)x; }
|
|
void test_char_to_i8(signed char* y) { f_i8_arg(y); }
|
|
void test_char_to_ui8(unsigned char* y) { f_ui8_arg(y); }
|
|
void test_short_to_i16(short* y) { f_i16_arg(y); }
|
|
void test_short_to_ui16(unsigned short* y) { f_ui16_arg(y); }
|
|
void test_int_to_i32(int* y) { f_i32_arg(y); }
|
|
void test_int_to_ui32(unsigned int* y) { f_ui32_arg(y); }
|
|
#if TEST_32BIT_X86
|
|
void test_long_to_i64(long long* y) { f_i64_arg(y); }
|
|
void test_long_to_ui64(unsigned long long* y) { f_ui64_arg(y); }
|
|
#elif TEST_64BIT_X86
|
|
#ifdef __ILP32__
|
|
typedef unsigned int gcc_word __attribute__((mode(word)));
|
|
int foo[sizeof(gcc_word) == 8 ? 1 : -1];
|
|
typedef unsigned int gcc_unwind_word __attribute__((mode(unwind_word)));
|
|
int foo[sizeof(gcc_unwind_word) == 8 ? 1 : -1];
|
|
void test_long_to_i64(long long* y) { f_i64_arg(y); }
|
|
void test_long_to_ui64(unsigned long long* y) { f_ui64_arg(y); }
|
|
#else
|
|
void test_long_to_i64(long* y) { f_i64_arg(y); }
|
|
void test_long_to_ui64(unsigned long* y) { f_ui64_arg(y); }
|
|
#endif
|
|
typedef float f128ibm __attribute__ ((mode (TF)));
|
|
#elif TEST_64BIT_PPC64
|
|
typedef float f128ibm __attribute__ ((mode (TF)));
|
|
typedef _Complex float c128ibm __attribute__ ((mode (TC)));
|
|
void f_ft128_arg(long double *x);
|
|
void f_ft128_complex_arg(_Complex long double *x);
|
|
void test_TFtype(f128ibm *a) { f_ft128_arg (a); }
|
|
void test_TCtype(c128ibm *a) { f_ft128_complex_arg (a); }
|
|
#else
|
|
#error Unknown test architecture.
|
|
#endif
|
|
|
|
struct S {
|
|
int n __attribute((mode(HI)));
|
|
};
|