interests
[lttv.git] / ltt / branches / poly / doc / developer / lttng-lttv-roadmap.html
CommitLineData
1f2c88b1 1<html>
2<body>
e3a30a9e 3<center><big><big>LTTV & LTTng roadmap<small><small></center>
674fa3b3 4<br>
5<br>
5e11a375 6Here are the roadmaps for the LTTV and LTTng development. I use a priority indice
fc5993d2 7for the TODO items :<br>
90d65afc 8(1) : very high priority<br>
9(10): lowest priority<br>
fc5993d2 10<br>
11<br>
59656e3f 12Dependencies are written between parenthesis ( ).<br>
13The # symbol marks who is currently working on the item.<br>
e565223b 14The % symbol marks who is interested in the realisation of the item.<br>
59656e3f 15<br>
c8a111eb 16<big>LTTV Roadmap<small><br>
17<br>
18* TODO<br>
90d65afc 19(4) create a event rate graphical view : Will be useful in conjonction with the
c8a111eb 20 filter.<br>
4a2e16b7 21 # <A HREF="mailto:Parisa Heidari <parisa.heidari@polymtl.ca>">Parisa Heidari</A><br>
90d65afc 22(6) migrate align to lttv parser.<br>
23(7) create an analysis of function time (like a precise gprof)<br>
c8a111eb 24 -> with gcc -f inline-functions<br>
16383052 25(10) Add cancel button to LTTV filter GUI window.
c8a111eb 26<br>
27<br>
0c4b3d55 28* Done<br>
d6533ec7 29per struct (struct align=x) support added to genevent (partial).<br>
b8b5f119 30Add offset align generation for structs to genevent.<br>
81d2643e 31make lttv aware of the per facility long, void* and size_t types.<br>
32Read current trace header and buffer header.<br>
6da6b02c 33redo lib tracefile : too much problems in there.<br>
34modify the rest of LTTV to match the API changes.<br>
35debian package<br>
36RPM package<br>
0c4b3d55 37<br>
c8a111eb 38<big>LTT Next Generation Roadmap<small><br>
0c4b3d55 39<br>
c8a111eb 40* TODO<br>
145c9c57 41(1) add genevent full functionnality : alignment, array, sequences, nested
42structures.<br>
3bb20f01 43 # <A HREF="mailto:Mathieu Desnoyers <compudj@krystal.dyndns.org>>">Mathieu Desnoyers</A><br>
145c9c57 44(1) port LTTng to 2.6.14 kernel. (depends on genevent rewrite)<br>
90d65afc 45(2) add efficient and secure user space tracing. (1 month)<br>
46(3) integrate LTTng State Dump : missing irq and process state.<br>
4a2e16b7 47 # <A HREF="mailto:Jean-Hugues Deschenes <jean-hugues.deschenes@polymtl.ca>">Jean-Hugues Deschenes</A><br>
90d65afc 48(7) add gcc -finstrument-functions instrumentation<br>
e565223b 49(3) port LTTng to : (depends on 2.6.14 port)<br>
50x86_64<BR>
e4d84ff4 51#Autodesk <A HREF="mailto:Francois L'Archeveque <fla@discreet.com>">Francois
52L'Archeveque</A> for 2.6.9 RedHat Enterprise<BR>
e565223b 53%Wind River for 2.6.10<BR>
54PPC<BR>
55PPC64<BR>
56%Wind River for 2.6.10<BR>
57alpha<BR>
58user-mode Linux<BR>
59Xen<BR>
60MIPS<BR>
61MIPS64<BR>
62%Wind River for 2.6.10<BR>
63ARM<BR>
64S/390<BR>
0c4b3d55 65<br>
15e89ad6 66<br>
b720b182 67* Done<br>
b720b182 68remove ltt-headers.h<br>
69remove ltt-log.h<br>
c9eaf4ed 70Put trace->active later in _ltt_trace_start()<br>
71ltt_trace_create() remove sleep in spinlock use GFP_ATOMIC kmalloc<br>
1502fa62 72Fix the locking of module hooks.<br>
73Fix the traps -> disable nested logging for now.<br>
74Use per cpu spinlock on trace list.<br>
24c78300 75Finish the control module, libltt and lttctl : netlink interface<br>
baffa645 76Finish integrating lttctl with lttd.<br>
ada84671 77fix lttctl signal waiting : use a flag.<br>
4e4d11b3 78Add ltt_write_commit_counter call to genevent.<br>
24c78300 79Add information in the buffer header : buffer size, etc etc...<br>
80 -> this information is so small that we can repeat it. Makes flight recorder
81 easier to decode.<br>
4e4d11b3 82Add trace start structure to buffer start header.<br>
ada84671 83fix genevent : take no lock if num traces active is 0.<br>
4e4d11b3 84Add type information per facility : it will help having a standard way
85to understand information coming from both kernel space and user space, and deal
86easily with 64 bits kernel with 64 and 32 bits processes (and with size_t know
87at compile time which can differ inside the same process from one library to
88another).<br>
89fix structures alignment, array and sequences too. -> trace dynamic.<br>
90add per facility alignment (inside structures).<br>
91add control of alignment.<br>
0c4b3d55 92add control for subbuffer size and number of subbuffers.<br>
b6dfdc9c 93Add reserve - get TSC - alignment atomicity through the use of cmpxchg.<br>
94Add configurable alignment (LTT_ALIGNMENT).<br>
6da6b02c 95Get ultra-precise logging with use of TSC (only) : only one do_gettimeofday
96read, and then we don't want the time flow to be altered by ntp.<br>
97Debian kernel package<br>
145c9c57 98make LTT tracing code completely atomic (thus remove locks)<br>
99Buffer aligned on page boundary -> use valloc.<br>
0c4b3d55 100<br>
101<br>
b720b182 102<br>
103* TODO (low priority)<br>
cbe85414 104enhance RPM packages for lttng kernel<br>
b720b182 105Integrate header generation (genevent) in kernel build system.<br>
c9eaf4ed 106Multithreaded lttd.<br>
baffa645 107Find a different way to printk from instrumentation : forbidden from schedule
108and wakeup (causes a deadlock).<br>
b720b182 109<br>
15e89ad6 110* Need to be discussed<br>
b720b182 111Drop ltt-module-register and ltt-module-unregister, use exported variables.<br>
112RelayFS ioctl interface vs control through LTT netlink interface.<br>
113drop ltt_filter_control, use functions pointers instead.<br>
b720b182 114Merge facilities headers into one big header.<br>
115Change the name of XML files from XML to something else.<br>
116Remove ltt-base.c.<br>
117<br>
15e89ad6 118* Not planned for integration<br>
4f782cda 119Remove the callback struct from the trace struct.<br>
15e89ad6 120<br>
121<br>
b720b182 122<br>
81d2643e 123* lttng patch division (0.4.2+) :<br>
b720b182 124<br>
125ltt-instrumentation.diff<br>
b720b182 126ltt-facilities-headers.diff<br>
127ltt-facilities-loader.diff<br>
128ltt-facilities.diff<br>
b720b182 129ltt-relayfs.diff<br>
b720b182 130ltt-core.diff<br>
131<br>
132<br>
133Mathieu Desnoyers<br>
1f2c88b1 134
135
136</body>
137</html>
This page took 0.033277 seconds and 4 git commands to generate.