add softirq mode
[lttv.git] / ltt / branches / poly / doc / developer / lttng-lttv-roadmap.html
index 092f65262d3e9b225f417f9953feb3455d8cab51..61ff426d161e529c21aed3629ffaf28c2088e9ac 100644 (file)
@@ -9,116 +9,85 @@ for the TODO items :<br>
 (10): lowest priority<br>
 <br>
 <br>
-Dependencies are written between parenthesis ( ).<br>
+Dependencies are written between brackets [ ].<br>
 The # symbol marks who is currently working on the item.<br>
 The % symbol marks who is interested in the realisation of the item.<br>
 <br>
 <big>LTTV Roadmap<small><br>
 <br>
 * TODO<br>
-(4) create a event rate graphical view : Will be useful in conjonction with the
+(2) state.c : add Softirq execution mode.<br>
+(3) Make LTTV aware of type formats defined in the XML file.<br>
+(3) Use a per architecture enumeration for traps.<br>
+(3) Integrate Kernel State Dump information.<br>
+(4) create a event rate graphical view : Will be useful in conjunction with the
   filter.<br>
        # <A HREF="mailto:Parisa Heidari <parisa.heidari@polymtl.ca>">Parisa Heidari</A><br>
-(6) migrate align to lttv parser.<br>
-(7) create an analysis of function time (like a precise gprof)<br>
+(4) create a graphical per cpu activity view.<br>
+(5) Flight recorder : start lttd automatically upon GUI trace control stop.<br>
+(5) Event sequence detector (inspired from regular expressions).<br>
+(7) create an analysis of function time (like a precise gprof).<br>
   -> with gcc -f inline-functions<br>
+(7) Create a hardware counter viewer (low cost rate counters : L1 cache miss, page faults, interrupts...).<br>
 (10) Add cancel button to LTTV filter GUI window.
 <br>
 <br>
-* Done<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>
-redo lib tracefile : too much problems in there.<br>
-modify the rest of LTTV to match the API changes.<br>
-debian package<br>
-RPM package<br>
-<br>
 <big>LTT Next Generation Roadmap<small><br>
 <br>
 * TODO<br>
-(1) add genevent full functionnality : alignment, array, sequences, nested
-structures.<br>
-       # <A HREF="mailto:Mathieu Desnoyers <compudj@krystal.dyndns.org>>">Mathieu Desnoyers</A><br>
-(1) port LTTng to 2.6.14 kernel. (depends on genevent rewrite)<br>
 (2) add efficient and secure user space tracing. (1 month)<br>
 (3) integrate LTTng State Dump : missing irq and process state.<br>
        # <A HREF="mailto:Jean-Hugues Deschenes <jean-hugues.deschenes@polymtl.ca>">Jean-Hugues Deschenes</A><br>
+(4) efficient dynamic event filtering while recording trace.<br>
+       % Sensis Corp. <A HREF="mailto:Bish, Tim <Tim.Bish@Sensis.com>">Tim Bish</A><br>
+(4) Create the heartbeat timer LTTng module. Make sure that heartbeat events
+never hit the facility channel. Use the complete 64 bits TSC for the facility
+channel in every case. That's because this channel must never be overwritten
+even in "flight recorder" mode.<br>
+(5) Integrate LTTng and lttd with LKCD.<br>
 (7) add gcc -finstrument-functions instrumentation<br>
-(3) port LTTng to : (depends on 2.6.14 port)<br>
+(7) Integrate periodical dump of perfctr hardware counters.<br>
+(8) Integrate periodical dump of SystemTAP computed information.<br>
+(8) Integrate SystemTAP logging with LTTng.<br>
+(3) port LTTng to :<br>
 x86_64<BR>
 #Autodesk <A HREF="mailto:Francois L'Archeveque <fla@discreet.com>">Francois
-L'Archeveque</A> for 2.6.9 RedHat Enterprise<BR>
-%Wind River for 2.6.10<BR>
+L'Archeveque</A> for 2.6.9 RedHat Enterprise (patch available in contrib, still
+has to be ported to 2.6.14, thanks!)<BR>
+%Wind River for 2.6.14<BR>
 PPC<BR>
 PPC64<BR>
-%Wind River for 2.6.10<BR>
+%Wind River for 2.6.14<BR>
 alpha<BR>
 user-mode Linux<BR>
 Xen<BR>
 MIPS<BR>
 MIPS64<BR>
-%Wind River for 2.6.10<BR>
+%Wind River for 2.6.14<BR>
 ARM<BR>
 S/390<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>
-Get ultra-precise logging with use of TSC (only) : only one do_gettimeofday
-read, and then we don't want the time flow to be altered by ntp.<br>
-Debian kernel package<br>
-make LTT tracing code completely atomic (thus remove locks)<br>
-Buffer aligned on page boundary -> use valloc.<br>
-<br>
-<br>
 <br>
 * TODO (low priority)<br>
 enhance RPM packages for lttng kernel<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>
+and wakeup (causes a deadlock). -> Modify printk so it uses LTTng tracer!<br>
+Export channels via network sockets instead of writing them to disk.<br>
+Export buffers with time constraint for "live" visualisation. Use
+ltt_force_switch periodically from a timer to insure slow channels do not
+interfere with viewing.<br>
 <br>
 * Need to be discussed<br>
+Use 2.6.14 RelayFS control files.<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>
 <br>
 * lttng patch division (0.4.2+) :<br>
 <br>
This page took 0.024719 seconds and 4 git commands to generate.