1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-17 15:27:36 +00:00

Spell ta 1 correctly as ta %xcc, 1. Use %pil for critical enter/exit

instead of pstate.ie.  Note that popc is not implemented in hardware
on certain ultras, so we can't use it for inline ffs (suck).
This commit is contained in:
Jake Burkholder 2001-08-18 18:07:37 +00:00
parent cae71da765
commit f70bfa97c0
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=81894

View File

@ -117,31 +117,28 @@
static __inline void
breakpoint(void)
{
__asm __volatile("ta 1");
__asm __volatile("ta %%xcc, 1" : :);
}
/*
* XXX use %pil for these.
*/
static __inline critical_t
critical_enter(void)
{
critical_t ie;
critical_t pil;
ie = rdpr(pstate);
if (ie & PSTATE_IE)
wrpr(pstate, ie, PSTATE_IE);
return (ie);
pil = rdpr(pil);
wrpr(pil, 0, 14);
return (pil);
}
static __inline void
critical_exit(critical_t ie)
critical_exit(critical_t pil)
{
if (ie & PSTATE_IE)
wrpr(pstate, ie, 0);
wrpr(pil, pil, 0);
}
/*
* Ultrasparc II doesn't implement popc in hardware. Suck.
*/
#if 0
#define HAVE_INLINE_FFS
/*