svn commit: r288492 - head/sys/arm/arm
Konstantin Belousov
kib at FreeBSD.org
Fri Oct 2 13:26:00 UTC 2015
Author: kib
Date: Fri Oct 2 13:25:59 2015
New Revision: 288492
URL: https://svnweb.freebsd.org/changeset/base/288492
Log:
Do not set 'flush to zero' VFPSCR_FZ bit by default. The correct
implementation of IEEE 754 arithmetic depends on denormals operating
correctly. Both perl test suite and paranoia tripped over the
setting.
Reported by: Stefan Parvu <sparvu at kronometrix.org>
Discussed with: andrew
Sponsored by: The FreeBSD Foundation
MFC after: 1 week
Modified:
head/sys/arm/arm/machdep.c
head/sys/arm/arm/vm_machdep.c
Modified: head/sys/arm/arm/machdep.c
==============================================================================
--- head/sys/arm/arm/machdep.c Fri Oct 2 13:21:08 2015 (r288491)
+++ head/sys/arm/arm/machdep.c Fri Oct 2 13:25:59 2015 (r288492)
@@ -1069,7 +1069,7 @@ init_proc0(vm_offset_t kstack)
(thread0.td_kstack + kstack_pages * PAGE_SIZE) - 1;
thread0.td_pcb->pcb_flags = 0;
thread0.td_pcb->pcb_vfpcpu = -1;
- thread0.td_pcb->pcb_vfpstate.fpscr = VFPSCR_DN | VFPSCR_FZ;
+ thread0.td_pcb->pcb_vfpstate.fpscr = VFPSCR_DN;
thread0.td_frame = &proc0_tf;
pcpup->pc_curpcb = thread0.td_pcb;
}
Modified: head/sys/arm/arm/vm_machdep.c
==============================================================================
--- head/sys/arm/arm/vm_machdep.c Fri Oct 2 13:21:08 2015 (r288491)
+++ head/sys/arm/arm/vm_machdep.c Fri Oct 2 13:25:59 2015 (r288492)
@@ -134,7 +134,7 @@ cpu_fork(register struct thread *td1, re
pcb2->pcb_regs.sf_sp = STACKALIGN(td2->td_frame);
pcb2->pcb_vfpcpu = -1;
- pcb2->pcb_vfpstate.fpscr = VFPSCR_DN | VFPSCR_FZ;
+ pcb2->pcb_vfpstate.fpscr = VFPSCR_DN;
tf = td2->td_frame;
tf->tf_spsr &= ~PSR_C;
More information about the svn-src-all
mailing list