cvs commit: src/sys/dev/acpica5 src/sys/i386/i386 src/sys/i386/include

Matthew Dillon dillon at crater.dragonflybsd.org
Sat Nov 20 12:51:00 PST 2004


dillon      2004/11/20 12:50:36 PST

DragonFly src repository

  Modified files:
    sys/dev/acpica5      acpi_cpu.c 
    sys/i386/i386        machdep.c mplock.s 
    sys/i386/include     lock.h 
  Log:
  Fix a number of SMP issues.
  
  * Add required pause instructions in code paths that skip running "HLT".  This
    occurs when e.g. cpu #1 is running code with the BGL while cpu #2's only
    runnable thread requires the BGL.  cpu #2's LWKT scheduler spins in that
    case.  Similar situations can occur when the only runnable threads on a
    cpu are waiting for a token.
  
  * Add required pause instructions to spin loops.  DragonFly has very few spin
    locks (e.g. things like com_lock()) but its a good idea anyway to avoid
    known livelock issues on Intel cpus.
  
  * Fix a pending interrupt / HLT race.  We were not atomically retiring
    pending interrupts prior to potentially HLTing the cpu.  This could
    result in an SMP machine's network locking up until a key is hit on
    the console, then magically resuming.
  
  Lockups-reported-by: Peter Avalos <pavalos at xxxxxxxxxxxx>
  
  Revision  Changes    Path
  1.7       +12 -1     src/sys/dev/acpica5/acpi_cpu.c
  1.68      +10 -1     src/sys/i386/i386/machdep.c
  1.15      +1 -0      src/sys/i386/i386/mplock.s
  1.10      +1 -0      src/sys/i386/include/lock.h


http://www.dragonflybsd.org/cvsweb/src/sys/dev/acpica5/acpi_cpu.c.diff?r1=1.6&r2=1.7&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/i386/i386/machdep.c.diff?r1=1.67&r2=1.68&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/i386/i386/mplock.s.diff?r1=1.14&r2=1.15&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/i386/include/lock.h.diff?r1=1.9&r2=1.10&f=u





More information about the Commits mailing list