Daniel Jacobowitz wrote: > > On Thu, Aug 16, 2001 at 02:34:45PM -0700, Jun Sun wrote: > > Yes, that is somewhat the purpose. Essentially we want to see, at the > > beginning of a signal handler execution, the process appears to have not used > > FPU at all. > > Why? > > > This requirement might be a must, because whether clearing current->used_math > > bit determine which patch we will take in the do_cpu(), when signal handler > > uses FPU for the first time. See the code below. > > > > if (current->used_math) { /* Using the FPU again. */ > > lazy_fpu_switch(last_task_used_math); > > } else { /* First time FPU user. */ > > init_fpu(); > > current->used_math = 1; > > } > > last_task_used_math = current; > > > > Clearly the second path is logically the correct one. > > Not really. Why should it get a clean set of FP registers? I think > the CORRECT thing would actually be for it to have the app's FP > registers. Changes should not propogate back to the app, that's all. > Ah, it seems I need to defend an "obvious" point. :-) I am from the school which view signal handler as an interrupt context to a normal process. (In fact, some OSes implement signal handling by using a separate thread/process). Under this view, it is natural to provide a fresh new context when a signal handler starts. In other words, I am thinking in the following semantics: a signal handler starting execution is equivalent to another process starting execution with the same address space, except that the original process won't resume until the "signal handler process" exits. Thinking from that, I feel we should clear the current->used_math bit. I think it is not correct for signal handler to inherit the FPU registers. If it wants to check the register values when the signal happens, it should do so by examing the signal context. Apparently a well code signal handler does not depend on whether we clear current->used_math bit or not, because it should always set a FPU register before it uses it. Jun > > BTW, do I see another bug here in do_cpu()? It seems that before we call > > init_fpu(), we should check last_task_used_math. If it is not NULL, we should > > save the FP state to the last_task_used_math. Hmm, strange ... > > I thought I got all of these... <sigh> > > -- > Daniel Jacobowitz Carnegie Mellon University > MontaVista Software Debian GNU/Linux Developer