cvs commit: src/sys/i386/i386 src/sys/kern src/sys/sys src/sys/dev/crypto/rndtest

Matthew Dillon dillon at crater.dragonflybsd.org
Thu Sep 16 17:19:40 PDT 2004


dillon      2004/09/16 17:18:16 PDT

DragonFly src repository

  Modified files:
    sys/i386/i386        machdep.c 
    sys/kern             kern_clock.c kern_timeout.c 
    sys/sys              callout.h 
    sys/dev/crypto/rndtest rndtest.c 
  Log:
  Move all the softclock/callout initialization out of MD and into MI.  Get rid
  of the extremely low-level virtual address space allocation for the old
  timeout() API's data structures and simply malloc() them in the new MI code
  (they will soon be removed entirely when the old API is removed).  Replace
  the softclock swi with a non-preempting high priority helper thread (one
  per cpu).  The lack of preemption allows us to retain compatibility with
  splsoftclock() use elsewhere in the kernel until those uses can be cleaned up,
  then we *might* make softclock threads preempt-capable.
  
  Rewrite the callout_*() implementation to make all data structures per-cpu.
  Add an MP flag (similar to what FreeBSD did), but create a separate API
  function, callout_init_mp() instead of adding an additional badly defined
  argument to callout_init().   callout_reset() and callout_stop() will now
  complain if the supplied structure is uninitialized (zero'd, e.g.
  callout_init() was not called on it).
  
  It is our intention to obsolete the old timeout()/untimeout() APIs and work
  is ongoing in that regard, and Joerg will soon import the new OpenBSD
  timeout_{set,add,del}() API.  The callout*() API will be retained.
  
  In DragonFly these APIs will guarentee that the callback will occur on the
  same cpu that the timeout was added on, a feature that the TCP protocol stacks
  will soon be able to take advantage of.
  
  Idea and Brainstorming by: Jeffrey Hsu, Joerg Sonnenberger, and Matthew Dillon
  
  Revision  Changes    Path
  1.66      +0 -28     src/sys/i386/i386/machdep.c
  1.24      +8 -10     src/sys/kern/kern_clock.c
  1.12      +368 -112  src/sys/kern/kern_timeout.c
  1.4       +26 -13    src/sys/sys/callout.h
  1.7       +1 -5      src/sys/dev/crypto/rndtest/rndtest.c


http://www.dragonflybsd.org/cvsweb/src/sys/i386/i386/machdep.c.diff?r1=1.65&r2=1.66&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/kern/kern_clock.c.diff?r1=1.23&r2=1.24&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/kern/kern_timeout.c.diff?r1=1.11&r2=1.12&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/sys/callout.h.diff?r1=1.3&r2=1.4&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/dev/crypto/rndtest/rndtest.c.diff?r1=1.6&r2=1.7&f=u





More information about the Commits mailing list