Re: #pragma STDC FENV_ACCESS ON
- In reply to: Steve Kargl : "Re: #pragma STDC FENV_ACCESS ON"
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Wed, 17 Jul 2024 20:47:01 UTC
On Wed, Jul 17, 2024 at 4:27 PM Steve Kargl <sgk@troutmask.apl.washington.edu> wrote: > > On Wed, Jul 17, 2024 at 04:16:33PM -0400, enh wrote: > > On Wed, Jul 17, 2024 at 4:01 PM Steve Kargl > > <sgk@troutmask.apl.washington.edu> wrote: > > > > > > On Wed, Jul 17, 2024 at 01:30:39PM -0400, enh wrote: > > > > i see lib/msun/src/e_sqrtl.c has `#pragma STDC FENV_ACCESS ON`, but > > > > s_fma.c, s_fmaf.c, s_fmal.c, and s_nearbyint.c all use fesetround() or > > > > fesetenv() too --- shouldn't they also have the pragma? > > > > > > > > (Android currently builds all of libm with that pragma, but (a) that > > > > seems like a big hammer and (b) afaict upstream [you] don't, so this > > > > is potentially causing problems^W^Wallowing the compiler to cause > > > > problems for you?) > > > > > > Some of the compilers, which that are used to compile FreeBSD, > > > do not support "#pragma STDC FENV_ACCESS ON". > > > > that's why you have a line in the Makefile to quiet the warning :-) > > > > (remember you _do_ have this #pragma in e_sqrtl.c already.) > > > > Then your original post is simply a rhetorical question? no. i said: 1. e_sqrtl.c has `#pragma STDC FENV_ACCESS ON` 2. s_fma.c, s_fmaf.c, s_fmal.c, and s_nearbyint.c all use fesetround() or fesetenv() but _don't_ have the pragma that is: #1 implies you think this is needed, but #2 shows that it's inconsistently applied in places where it's needed. > Consider it future-proofing for when all compilers supprt > the pragma. "future proofing" is exactly why i'm suggesting you should probably have the pragma in the other files that use the relevant functions :-) > -- > Steve >