| 123456789101112131415161718192021222324 | /*  (C) Copyright 2019 Kalray S.A.  This file provides feupdateenv for the Coolidge processor.*/#include <fenv.h>int feupdateenv(const fenv_t *envp){  /* Mask *envp to be sure only valid bits are set */  fenv_t fe = *envp;  fe &= (FE_ALL_EXCEPT|FE_RND_MASK);  /* Update exception flags and rounding mode bit-fields of $cs, with     'fe' as a set mask and FE_RND_MASK as a clear mask. FE_ALL_EXCEPT     is not cleared: restores rounding mode and updates exception     flags. */  __builtin_kvx_wfxl(KVX_SFR_CS, ((long long)fe << 32) | FE_RND_MASK);  /* The above insn cannot fail (while the OS allows access to the     floating-point exception flags of the $cs register). Return     success. */  return 0;}
 |