float16.c 1.94 KB
// RUN: %clang_cc1 -triple=aarch64-none-none -fsyntax-only -verify -std=c89 \
// RUN:   -ffreestanding %s
// RUN: %clang_cc1 -triple=aarch64-none-none -fsyntax-only -verify \
// RUN:   -std=c99 -ffreestanding %s
// RUN: %clang_cc1 -triple=aarch64-none-none -fsyntax-only -verify -std=c11 \
// RUN:   -ffreestanding %s
// RUN: %clang_cc1 -triple=aarch64-none-none -fsyntax-only -verify \
// RUN:   -std=c++11 -x c++ -ffreestanding %s
// expected-no-diagnostics

#define __STDC_WANT_IEC_60559_TYPES_EXT__
#include <float.h>

#ifndef FLT16_MIN_10_EXP
    #error "Macro FLT16_MIN_10_EXP is missing."
#elif   FLT16_MIN_10_EXP > -4
    #error "Macro FLT16_MIN_10_EXP is invalid."
#endif

_Static_assert(FLT16_MIN_10_EXP == __FLT16_MIN_10_EXP__, "");

#ifndef FLT16_MIN_EXP
    #error "Macro FLT16_MIN_EXP is missing."
#elif   FLT16_MIN_EXP > -13
    #error "Macro FLT16_MIN_EXP is invalid."
#endif

_Static_assert(FLT16_MIN_EXP == __FLT16_MIN_EXP__, "");

#ifndef FLT16_MAX_10_EXP
    #error "Macro FLT16_MAX_10_EXP is missing."
#elif   FLT16_MAX_10_EXP < 4
    #error "Macro FLT16_MAX_10_EXP is invalid."
#endif

_Static_assert(FLT16_MAX_10_EXP == __FLT16_MAX_10_EXP__, "");

#ifndef FLT16_MAX_EXP
    #error "Macro FLT16_MAX_EXP is missing."
#elif   FLT16_MAX_EXP < 16
    #error "Macro FLT16_MAX_EXP is invalid."
#endif

_Static_assert(FLT16_MAX_EXP == __FLT16_MAX_EXP__, "");

#ifndef FLT16_DECIMAL_DIG
    #error "Macro FLT16_DECIMAL_DIG is missing."
#elif   FLT16_DECIMAL_DIG < 5
    #error "Macro FLT16_DECIMAL_DIG is invalid."
#endif

_Static_assert(FLT16_DECIMAL_DIG == __FLT16_DECIMAL_DIG__, "");

#ifndef FLT16_DIG
    #error "Macro FLT16_DIG is missing."
#elif   FLT16_DIG < 3
    #error "Macro FLT16_DIG is invalid."
#endif

_Static_assert(FLT16_DIG == __FLT16_DIG__, "");

#ifndef FLT16_MANT_DIG
    #error "Macro FLT16_MANT_DIG is missing."
#elif   FLT16_MANT_DIG < 11
    #error "Macro FLT16_MANT_DIG is invalid."
#endif

_Static_assert(FLT16_MANT_DIG == __FLT16_MANT_DIG__, "");