If parent thread never used FPU, the only work is to clear flag
PCB_NPXINITDONE for new thread and let trap code initialize it.
This commit is contained in:
parent
bf6b4844d3
commit
03c7322bae
@ -952,9 +952,14 @@ npx_fork_thread(struct thread *td, struct thread *newtd)
|
||||
u_int32_t mxcsr;
|
||||
u_int32_t cw;
|
||||
|
||||
if (!(td->td_pcb->pcb_flags & PCB_NPXINITDONE)) {
|
||||
newtd->td_pcb->pcb_flags &= ~PCB_NPXINITDONE;
|
||||
return;
|
||||
}
|
||||
|
||||
state = &newtd->td_pcb->pcb_save;
|
||||
/* get control word */
|
||||
if (npxgetregs(td, &newtd->td_pcb->pcb_save))
|
||||
if (npxgetregs(td, state))
|
||||
return;
|
||||
if (cpu_fxsr) {
|
||||
mxcsr = state->sv_xmm.sv_env.en_mxcsr;
|
||||
|
Loading…
x
Reference in New Issue
Block a user