Added dfly config walkthrough, removed deprecated walkthrough
[ikiwiki.git] / docs / developer / researchprojectspage / index.mdwn
index 8841475..5e87abe 100644 (file)
@@ -40,10 +40,23 @@ Please feel free to add projects to this page, or annotate existing project idea
 * Dispatch to the most efficient allocator implementation on future execution.
 * Perhaps allocators can export their size range and a series of flags indicating what they are suited for, and the profiling could build a set of flags based on application behavior.
 * This could be done per-thread in a lockless fashion and coalesced with weights atexit().
-* The scope of this work might be appropriate for a PhD or Masters thesis.
+* The scope of this work might be appropriate for a thesis.
 * Such a framework likely would not replace the base system allocator but if it were lightweight enough could possibly augment (and/or incorporate) it.
 * For applications definitely known to work better under some configuration, flags could be seeded and pkgsrc could link those apps against the best alternative meta-allocator.
 
 ### Opt-in userland thread scheduler
 * A great deal of research has been done on this topic, implementations exist for other operating systems.
 * References: [1](http://leaf.dragonflybsd.org/mailarchive/kernel/2007-03/msg00038.html)
+
+### Make the use of XIO pervasive
+* XIO could be applied liberally to the I/O stack
+* Determine the best use cases for XIO and create a list of paths to target.
+* Slog through the identified kernel paths converting existing I/O magic to XIO.
+* References: [1](http://www.shiningsilence.com/dbsdlog/2004/03/30/331.html#more-331)
+
+### Evaluate/Improve Context Switching Performance
+* When a context switch happens, both the virtually tagged L1
+  cache and non-tagged TLB have to be flushed.
+* How expensive is this flushing of those caches, taking into
+  account how many cycles are spent in reloading the cache.
+* Small-Address Spaces [1](http://www.l4ka.org/publications/2002/smallspaces.pdf) could overcome this context switch cost by multiplexing the virtual address space using segmentation.