Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 09 Oct 2004 14:15:23 +1000
From:      Sam Lawrance <boris@brooknet.com.au>
To:        freebsd-current@freebsd.org
Subject:   Re: Noticable Delays Since Beta 3 (possible cause)
Message-ID:  <1097295323.836.28.camel@dirk.no.domain>
In-Reply-To: <200410082346.16570.marc.ramirez@bluecirclesoft.com>
References:  <4164BFA4.80105@unisa.edu.au> <41657D63.1050605@FreeBSD.org> <1097290576.836.20.camel@dirk.no.domain> <200410082346.16570.marc.ramirez@bluecirclesoft.com>

next in thread | previous in thread | raw e-mail | index | archive | help
Apparently this was already known and identified (to an extent). Here's
the code and commit log:

src/sys/kern_synch.c:390
        if ((p->p_sflag & PS_INMEM) == 0) {
                if ((p->p_sflag & PS_SWAPPINGIN) == 0) {
                        p->p_sflag |= PS_SWAPINREQ;
#ifndef SMP
                        /*
                         * XXX: Disabled on SMP due to a LOR between
                         * sched_lock and the sleepqueue chain locks.
                         */
                        wakeup(&proc0);
#endif
                }


Revision 1.256 / (download) - annotate - [select for diffs], Wed Aug 4
20:24:40 2004 UTC (2 months ago) by jhb 
Branch: MAIN 
Changes since 1.255: +6 -0 lines
Diff to previous 1.255 (colored)

Workaround a possible deadlock on SMP due to a spin lock LOR by disabling
the immediate awakening of proc0 (scheduler kproc, controls swapping
processes in and out).  The scheduler process periodically awakens already,
so this will not result in processes not being swapped in, there will just
be more latency in between a thread being made runnable and the scheduler
waking up to swap the affected process back in.




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?1097295323.836.28.camel>