.. erm, sys/mips/mips/machdep.c:

/*
 * call platform specific code to halt (until next interrupt) for the idle loop
 */
void
cpu_idle(int busy)
{
        KASSERT((mips_rd_status() & MIPS_SR_INT_IE) != 0,
                ("interrupts disabled in idle process."));
        KASSERT((mips_rd_status() & MIPS_INT_MASK) != 0,
                ("all interrupts masked in idle process."));

        if (!busy) {
                critical_enter();
                cpu_idleclock();
        }
        __asm __volatile ("wait");
        if (!busy) {
                cpu_activeclock();
                critical_exit();
        }
}

.. does that look right?


Adrian
_______________________________________________
freebsd-current@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-current
To unsubscribe, send any mail to "freebsd-current-unsubscr...@freebsd.org"

Reply via email to