cvs commit: src/sys/ia64/ia64 syscall.s
Marcel Moolenaar
marcel at FreeBSD.org
Sat May 31 13:57:28 PDT 2003
marcel 2003/05/31 13:57:27 PDT
FreeBSD src repository
Modified files:
sys/ia64/ia64 syscall.s
Log:
Some ia32 related finetuning for the EPC syscall path:
o The SDM states that flushing the RSE in the cycle prior to the
call to ia32 code yields the best performance. We don't really
care to much about performance here, but we do the same anyway.
I'm being paranoia and conservative here.
o Only initialize the ia32 state registers, not the registers used
as scratch by the ia32 engine. This saves a couple of loads from
the trapframe, but also helps debugging: we don't clobber useful
debugging data (engineering hints :-)
o Make sure all general registers constituting ia32 state have been
initialized. If there's no useful to be loaded from the trapframe,
clear the register. This avoids accidentally leaking NaT bits.
o Make sure we set ar.k6 prior to clobbering ar.bspstore and also
set ar.k7 prior to setting sp. This fixes a race seen for ia64
native code as well (and previously fixed too).
Revision Changes Path
1.3 +32 -25 src/sys/ia64/ia64/syscall.s
More information about the cvs-all
mailing list