mirror of
https://git.FreeBSD.org/src.git
synced 2024-12-15 10:17:20 +00:00
The FP status register allows for 6 traps to be masked. One of them,
the denormal/unnormal trap, is not a standard IEEE trap. We did not exclude it from being returned by fpgetmask(), nor did we make sure that fpsetmask() didn't clobber it. Since the non-IEEE trap is not part of fp_except_t, users of ifpgetmask()/fpsetmask() would be confronted with unexpected behaviour, one of which is a SIGFPE for denormal/unnormal FP results. This commit makes sure that we don't leak the denormal/unnormal mask bit in fp_except_t and also that we don't clobber it.
This commit is contained in:
parent
552b83803a
commit
b32428bbc5
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=121332
@ -36,5 +36,5 @@ fpgetmask(void)
|
|||||||
u_int64_t fpsr;
|
u_int64_t fpsr;
|
||||||
|
|
||||||
__asm __volatile("mov %0=ar.fpsr" : "=r" (fpsr));
|
__asm __volatile("mov %0=ar.fpsr" : "=r" (fpsr));
|
||||||
return (~fpsr & 0x3f);
|
return (~fpsr & 0x3d);
|
||||||
}
|
}
|
||||||
|
@ -37,8 +37,8 @@ fpsetmask(fp_except_t mask)
|
|||||||
u_int64_t oldmask;
|
u_int64_t oldmask;
|
||||||
|
|
||||||
__asm __volatile("mov %0=ar.fpsr" : "=r" (fpsr));
|
__asm __volatile("mov %0=ar.fpsr" : "=r" (fpsr));
|
||||||
oldmask = ~fpsr & 0x3f;
|
oldmask = ~fpsr & 0x3d;
|
||||||
fpsr = (fpsr & ~0x3f) | (~mask & 0x3f);
|
fpsr = (fpsr & ~0x3d) | (~mask & 0x3d);
|
||||||
__asm __volatile("mov ar.fpsr=%0" :: "r" (fpsr));
|
__asm __volatile("mov ar.fpsr=%0" :: "r" (fpsr));
|
||||||
return (oldmask);
|
return (oldmask);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user