blob: 156bf66cfc3100fdde1f9889f6f2980779beede3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
/*
(C) Copyright 2019 Kalray S.A.
This file provides feraiseexcept for the Coolidge processor.
*/
#include <fenv.h>
int feraiseexcept(int excepts)
{
/* Mask excepts to be sure only supported flag bits are set */
excepts &= FE_ALL_EXCEPT;
/* Set $cs with 'excepts' as a set mask. */
__builtin_kvx_wfxl(KVX_SFR_CS, (long long)excepts << 32);
/* C99 requirements are met. The flags are raised at the same time
so order is preserved. FE_INEXACT is not raised if one of the
exceptions is FE_OVERFLOW or FE_UNDERFLOW. */
/* The above insn cannot fail (while the OS allows access to the
floating-point exception flags of the $cs register). Return
success. */
return 0;
}
|