todo update
[lttv.git] / ltt / branches / poly / doc / developer / ltt-experimental-rewrite.html
index e1550bb9a9b3bba3a614985e29e914cb460ef24c..528b7b5a670fe17d7ddacfaac74ce61d5db04ad1 100644 (file)
@@ -1,31 +1,94 @@
 <html>
 <body>
-Here the status of the work in progress for LTT experimental<br>
+<big>LTTV Roadmap<small><br>
 <br>
 * TODO<br>
+migrate align to lttv parser.<br>
+create a event rate graphical view : Will be useful in conjonction with the
+  filter.<br>
+create an analysis of function time (like a precise gprof)<br>
+  -> with gcc -f inline-functions<br>
 <br>
 <br>
-
-
-
-
-* Need to be discussed<br>
+* Done<br>
+Buffer aligned on page boundary -> use valloc.<br>
+per struct (struct align=x) support added to genevent (partial).<br>
+Add offset align generation for structs to genevent.<br>
+make lttv aware of the per facility long, void* and size_t types.<br>
+Read current trace header and buffer header.<br>
 <br>
+<big>LTT Next Generation Roadmap<small><br>
+<br>
+* TODO<br>
+make LTT tracing code completely atomic (thus remove locks)<br>
+add efficient and secure user space tracing. (1 month)<br>
+integrate LTTng State Dump : missing irq and process state.<br>
+add genevent full functionnality : alignment, array, sequences, nested
+structures.<br>
+add gcc -finstrument-functions instrumentation<br>
+<br>
+<br>
+* Done<br>
+remove ltt-headers.h<br>
+remove ltt-log.h<br>
+Put trace->active later in _ltt_trace_start()<br>
+ltt_trace_create() remove sleep in spinlock use GFP_ATOMIC kmalloc<br>
+Fix the locking of module hooks.<br>
+Fix the traps -> disable nested logging for now.<br>
+Use per cpu spinlock on trace list.<br>
+Finish the control module, libltt and lttctl : netlink interface<br>
+Finish integrating lttctl with lttd.<br>
+fix lttctl signal waiting : use a flag.<br>
+Add ltt_write_commit_counter call to genevent.<br>
+Add information in the buffer header : buffer size, etc etc...<br>
+       -> this information is so small that we can repeat it. Makes flight recorder
+       easier to decode.<br>
+Add trace start structure to buffer start header.<br>
+fix genevent : take no lock if num traces active is 0.<br>
+Add type information per facility : it will help having a standard way
+to understand information coming from both kernel space and user space, and deal
+easily with 64 bits kernel with 64 and 32 bits processes (and with size_t know
+at compile time which can differ inside the same process from one library to
+another).<br>
+fix structures alignment, array and sequences too. -> trace dynamic.<br>
+add per facility alignment (inside structures).<br>
+add control of alignment.<br>
+add control for subbuffer size and number of subbuffers.<br>
+Add reserve - get TSC - alignment atomicity through the use of cmpxchg.<br>
+Add configurable alignment (LTT_ALIGNMENT).<br>
+<br>
+<br>
+<br>
+* TODO (low priority)<br>
+Integrate header generation (genevent) in kernel build system.<br>
+Multithreaded lttd.<br>
+Find a different way to printk from instrumentation : forbidden from schedule
+and wakeup (causes a deadlock).<br>
+<br>
+* Need to be discussed<br>
+Drop ltt-module-register and ltt-module-unregister, use exported variables.<br>
+RelayFS ioctl interface vs control through LTT netlink interface.<br>
+drop ltt_filter_control, use functions pointers instead.<br>
+Merge facilities headers into one big header.<br>
+Change the name of XML files from XML to something else.<br>
+Remove ltt-base.c.<br>
 <br>
-
-
-
-
-
 * Not planned for integration<br>
+Remove the callback struct from the trace struct.<br>
 <br>
 <br>
-
-
-
-
-
-Mathieu Desnoyers
+<br>
+* lttng patch division (0.4.2+) :<br>
+<br>
+ltt-instrumentation.diff<br>
+ltt-facilities-headers.diff<br>
+ltt-facilities-loader.diff<br>
+ltt-facilities.diff<br>
+ltt-relayfs.diff<br>
+ltt-core.diff<br>
+<br>
+<br>
+Mathieu Desnoyers<br>
 
 
 </body>
This page took 0.026691 seconds and 4 git commands to generate.