Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 24 Mar 2000 16:24:33 -0800 (PST)
From:      Matthew Dillon <dillon@apollo.backplane.com>
To:        Alfred Perlstein <bright@wintelcom.net>
Cc:        freebsd-current@FreeBSD.ORG
Subject:   Re: Preliminary SMP/BGL patch
Message-ID:  <200003250024.QAA17399@apollo.backplane.com>
References:  <200003241759.JAA14699@apollo.backplane.com> <20000324155552.V21029@fw.wintelcom.net>

next in thread | previous in thread | raw e-mail | index | archive | help
:This sort of concerns me, but if I remeber correctly, unmasking
:spl will cause a soft intr if there are pending interupts, the only
:problem is that completely software initiated interupts wouldn't
:get processed, or would they?  Can you explain how they are being
:scheduled/run if you remove doreti()?  One alternative would be to
:call doreti() only in the syscalls with the MPunsafe flag set,
:although I'm probably missing something that makes doreti() totally
:unnessesary, it may be that clock interupts are covering your
:removal of doreti().

    Ditto on the concern.  I almost have the second version of the patch ready,
    which cleans up a huge number of accretions from things
    people were testing but never finished.  I've removed _cil and _cml,
    I've removed all the _LOCK macros that all devolve down into the mp_lock
    and simply have them call get_mplock.  I've removed the sti code in
    MPgetlock_edx which was there solely to deal with one case in swtch.s
    where interrupts weren't enabled at the time the MP lock was attempted
    (interrupts have to be enabled when spinning on the MP lock in order
    to be able to take IPI's, so things like cpu shutdowns work).  Actually,
    that's the one piece I still haven't fixed all the cases for that's 
    holding up the second patch.  'reboot' isn't working right due to IPI's
    not getting through :-).

    With all the cleanups and the weirder conditional code removed, it's 
    become a whole lot more readable and the doreti picture is becoming much
    clearer.  I think, at worst, I may be missing an AST check there.

    I have created a document outlining a 'new' SMP mechanism proposal,
    with emphasis on the interrupt handling (keep in mind that most 
    interrupts will be synchronously switched to or use the BSDI mechanism,
    so overhead is not as bad as it may seem to a layperson).  I haven't
    implemented the interrupt mechanism yet - doh!  That's a lot work :-),
    but I have removed all the weird interrupt optimizations that were in
    there before that don't make much sense with regards to the direction
    we appear to be heading for interrupt handling.

	http://www.backplane.com/FreeBSD4/smp-api.html

:FYI, I was tempted to commit this with "Submitted by: dillon" and
:watch the fur fly, it is 5.0 after all. :)
:
:As things progress I think multi-subsystem locks expressing intent
:for structure manipulation would be a very cool idea, although I
:need to think about it more.
:
:thanks,
:-Alfred

    Well, as implemented in the interrupt, trap, and syscall code this
    idea is a failure.  It doesn't help the critical path at all (it can't,
    since you are still causing L1 cache invalidations on every entry!).  
    It's all gone in the new patch.

    I think there is definitely a place for per-structure spinlocks,
    especially in non-blocking situations (think: the critical path in
    the signal mask code).  But it's too early to discuss that.

					-Matt
					Matthew Dillon 
					<dillon@backplane.com>


To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-current" in the body of the message




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