[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
- Date: Sun, 08 Jun 2008 21:57:32 -0700
- From: strauman at slac.stanford.edu (Till Straumann)
- Subject: FP contexts
Leon Pollak wrote:
> Hello, all.
> A small question:
> I have VERY small amount of FP calculations (which occur also rare) in my
> Is it safe not to create tasks with FP attribute, but to surround FP
> calculations with disable/enable interrupts?
If you only have one single task that uses the FPU
then you're OK without disabling/enabling interrupts.
If there is at least one other, FP-enabled task then
disabling/enabling interrupts may still result in corruption
(if your target does lazy FP-context switching).
In general, I consider this very bad practice. IMO, FP-disabled
tasks should execute with the FPU hardware disabled.
So should exception handlers and ISRs (unless they save-restore
Here's one lesson I learned:
I have seen gcc versions which would silently/implicitly
use the FPU so that making all tasks FP tasks was the only
solution. With this gcc version (don't remember which one it
was) I occasionally had problems with gcc implicitly generating
FP code in ISRs. Only my paranoia (I have the FPU *only* enabled
when FP tasks execute, disabled during exceptions, non-FP tasks
etc.) saved me (I got a trap/exception instead of mysterious
corruption and could then figure out a work-around)...
> Thanks ahead.
- FP contexts
- From: joel.sherrill at OARcorp.com (Joel Sherrill)