/*
 * funder.c - manually provoke SP exceptions for mathlib
 *
 * Copyright (c) 2009-2018, Arm Limited.
 * SPDX-License-Identifier: MIT
 */

#include <fenv.h>
#include "math_private.h"

__inline float __mathlib_flt_infnan2(float x, float y)
{
  return x+y;
}

__inline float __mathlib_flt_infnan(float x)
{
  return x+x;
}

float __mathlib_flt_underflow(void)
{
#ifdef CLANG_EXCEPTIONS
  feraiseexcept(FE_UNDERFLOW);
#endif
  return 0x1p-95F * 0x1p-95F;
}

float __mathlib_flt_overflow(void)
{
#ifdef CLANG_EXCEPTIONS
  feraiseexcept(FE_OVERFLOW);
#endif
  return 0x1p+97F * 0x1p+97F;
}

float __mathlib_flt_invalid(void)
{
#ifdef CLANG_EXCEPTIONS
  feraiseexcept(FE_INVALID);
#endif
  return 0.0f / 0.0f;
}

float __mathlib_flt_divzero(void)
{
#ifdef CLANG_EXCEPTIONS
  feraiseexcept(FE_DIVBYZERO);
#endif
  return 1.0f / 0.0f;
}