Date: Thu, 4 Jan 2007 04:16:28 -0800 (PST) From: Jeff Roberson <jroberson@chesapeake.net> To: current@freebsd.org Subject: Re: ULE 2.0 Message-ID: <20070104041530.O613@10.0.0.1> In-Reply-To: <20070104005625.D1508@10.0.0.1> References: <20070104005625.D1508@10.0.0.1>
next in thread | previous in thread | raw e-mail | index | archive | help
Some last minute inspiration has the nice response looking much more favorable. This will be the last of my changes until I have some feedback. Thanks, Jeff On Thu, 4 Jan 2007, Jeff Roberson wrote: > Hello everyone, > > After a considerable vacation from ULE I have come back to address some long > standing concerns. I felt that the old double-queue mechanism caused very > unnatural behavior and have finally come up with something I'm happy to > replace it with. I've been working on this off and on for several months > now. Some details are below. More are at: > http://jeffr-tech.livejournal.com/3729.html > > The version now in CVS(1.172) should restore ULE's earlier interactive > performance under load. I have tested with a make -j128 kernel while using > mozilla and while playing a dvd. Neither ever skip for me. nice now has a > more gradual effect than before. It no longer allows the total starvation of > processes. ULE should also be very slightly faster on UP as compared to > before. SMP behavior should have changed very little although I did simplify > some small parts of these algorithms. In general, non-interactive tasks are > scheduled much more intelligently although this may not be apparent under > most workloads. > > I'm hoping for the following types of feedback from anyone interested in > testing: > > 1) Is the response to nice levels as you would hope? I think nice +20 may > not inhibit the nice'd thread enough at the moment. > 2) Is the interactive performance satisfactory? > 3) Is there any performance degredation for your common tasks? > 4) Does the cpu estimator give reasonable results? See %cpu in top. It is > expected that there will be periods where summing up all threads will yield > slightly over 100% cpu. > > Any and all feedback is welcome. Please make sure any problem reports are > sent to jroberson@chesapeake.net in the to line so I see them more quickly. > > Thanks, > Jeff > > ---------- Forwarded message ---------- > Date: Thu, 4 Jan 2007 08:56:25 +0000 (UTC) > From: Jeff Roberson <jeff@FreeBSD.org> > To: src-committers@FreeBSD.org, cvs-src@FreeBSD.org, cvs-all@FreeBSD.org > Subject: cvs commit: src/sys/kern sched_ule.c > > jeff 2007-01-04 08:56:25 UTC > > FreeBSD src repository > > Modified files: > sys/kern sched_ule.c > Log: > ULE 2.0: > - Remove the double queue mechanism for timeshare threads. It was slow > due to excess cache lines in play, caused suboptimal scheduling behavior > with niced and other non-interactive processes, complicated priority > lending, etc. > - Use a circular queue with a floating starting index for timeshare > threads. > Enforces fairness by moving the insertion point closer to threads with > worse priorities over time. > - Give interactive timeshare threads real-time user-space priorities and > place them on the realtime/ithd queue. > - Select non-interactive timeshare thread priorities based on their cpu > utilization over the last 10 seconds combined with the nice value. This > gives us more sane priorities and behavior in a loaded system as > compared to the old method of using the interactivity score. The > interactive score quickly hit a ceiling if threads were non-interactive > and penalized new hog threads. > - Use one slice size for all threads. The slice is not currently > dynamically set to adjust scheduling behavior of different threads. > - Add some new sysctls for scheduling parameters. > > Bug fixes/Clean up: > - Fix zeroing of td_sched after initialization in sched_fork_thread() > caused > by recent ksegrp removal. > - Fix KSE interactivity issues related to frequent forking and exiting of > kse threads. We simply disable the penalty for thread creation and exit > for kse threads. > - Cleanup the cpu estimator by using tickincr here as well. Keep ticks > and > ltick/ftick in the same frequency. Previously ticks were stathz and > others were hz. > - Lots of new and updated comments. > - Many many others. > > Tested on: up x86/amd64, 8way amd64. > > Revision Changes Path > 1.172 +332 -412 src/sys/kern/sched_ule.c > _______________________________________________ > freebsd-current@freebsd.org mailing list > http://lists.freebsd.org/mailman/listinfo/freebsd-current > To unsubscribe, send any mail to "freebsd-current-unsubscribe@freebsd.org" >
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070104041530.O613>