OSDN Git Service

Add split up multi sources,IMA compiling,build dependencies
[uclinux-h8/uClibc.git] / TODO
1 TODO list for the uClibc 0.9.29 release:
2 -------------------------------------------------
3     *) cleanup fallout from hidden_proto() updates
4     *) misc stdio bugs:
5         http://bugs.uclibc.org/view.php?id=420
6         http://bugs.uclibc.org/view.php?id=539
7     *) bug in getopt handling:
8         http://bugs.uclibc.org/view.php?id=61
9         http://www.uclibc.org/lists/uclibc/2006-January/013851.html
10     *) Audit header files.  Remove prototypes for all functions that
11         are not supported -- especially needed for the libm headers.
12     *) Audit header files.  When options are disabled, also disable
13         them in the include files as well by checking for the proper
14         define from include/bits/uClibc_config.h (pulled in from features.h)
15     *) Test cris, i386, mips, mipsel, sh, x86_64, arm, armeb, and powerpc
16         with the latest LTP testsuite.  Fix any regressions and post LTP
17         testsuite results for each architecture on uclibc.org.
18     *)  Fix it so valgrind 2.4.0 no longer complains about the memory mmaped
19         and used by ldso.  Currently it whines on basically about virtually
20         every function call when doing default lazy binding, which makes its
21         output virtually useless due to the excess noise.
22     *)  Change all references to the older "Library GPL" to the "Lesser GPL"
23         and update COPYING.LIB to LGPL version 2.1.
24     *)  vapier todo: finish new linuxthreads import
25     *)  Split up all conflicting MSRC files to allow IMA compiling
26     *)  Correct the dependencies in the build system
27
28
29
30
31 TODO list for the uClibc 1.0.0 release:
32 -------------------------------------------------
33
34     *) Hide uClibc internal symbols from our exported namespace.
35     *) Explicity add some sortof CONFIG_LINUX_2_2_ABI, CONFIG_LINUX_2_4_ABI
36         and CONFIG_LINUX_2_6_ABI type options, rather than having the abi
37         depend on the selected set of kernel headers.  This will likely also
38         require that we provide a set of kernel headers (probably a derivitive
39         of Mazur's linux-libc-headers) that can supplies the 2.2, 2.4, and 2.6
40         kernel abi.
41     *) Documentation updates:
42             *) Write a uClibc HOWTO document
43             *) Update README document
44             *) Update INSTALL document
45             *) Update docs/Glibc_vs_uClibc_Differences.txt document
46                 and fully document all differences between the feature
47                 set of uClibc and glibc.
48             *) Update docs/uClibc_vs_SuSv3.txt document
49             *) Update docs/threads.txt document
50             *) Write man pages for ldd and ldconfig utility binaries
51     *) Implement some mechanism (perhaps encoded in the .so name,
52         perhaps using an abi tag magically embedded into each object)
53         for flagging config options that break the ABI.  Options
54         such as UCLIBC_HAS_SOFT_FLOAT, UCLIBC_HAS_THREADS, UCLIBC_HAS_LOCALE,
55         and perhaps others (finalize list) produce a lib with a differing
56         ABI.  Make it so apps cannot use an ABI mis-matched uClibc.
57         This is most easily done using symbol versioning...
58     *) Implement the long double versions of math funcs
59         using wrappers on top of the double versions (size / precision
60         trade off where size clearly wins).
61     *) Make all small objects (>~50 bytes) into either inlines or
62         into a static library
63     *) Cleanup / rewrite sysconf.c.  It should get some information
64         from ldso (such as HZ).  Other stuff it currently just makes
65         up, which is obviously wrong.  Also bits/uClibc_clk_tck.h
66         needs to be updated at the same time to get proper HZ values.
67     *) poll emulation using select() for old 2.0.x uClinux kernels
68         in libc/sysdeps/linux/common/poll.c fails some python self-tests.
69         Of course, modern systems using the actuall poll() syscall work fine.
70     *) Rework the build system Makefile to eliminate recursive make.
71     *) Build both pic and non-pic objects where appropriate, so that
72         static libs need not pay the pic size penalty.
73     *) Cleanup/scrub all the Makefile copyright junk
74     *) Fix dlopen, for both static and dynamic cases, and make it
75         fully comply with SuSv3
76     *) From the the ELF spec "...All shared object initializations happen
77         before the executable file gains control.  ...  Before the initialization
78         code for any object A is called, the initialization code for any other
79         objects that object A depends on are called.  For these purposes, an object
80         A depends on another object B, if B appears in Ads list of needed objects
81         (recorded in the DT_NEEDED entries of the dynamic structure). The order of
82         initialization for circular dependencies is undefined."  uClibc's shared
83         lib loader should be fixed to run ctors in the specified order.
84
85
86 TODO list for AFTER the uClibc 1.0.0 release:
87 -------------------------------------------------
88     *) Add support for Linux 2.6.x NPTL pthreads, futexes, etc
89     *) Add support for Linux 2.6.x fast vsyscalls
90     *) Enable pristine source tree builds
91     *) Fix regex so it isn't so stinking big
92     *) Fix glob so it isn't so stinking big
93     *) run 'nm -D --size-sort -t d libuClibc-0.9.26.so' and work on the
94         biggest things (i.e. stuff at the end of the list) to make
95         them smaller.
96     <more wishlist items here>
97
98
99 Arch specific TODO:
100 -------------------------------------------------
101   alpha:
102     _init/_fini hangs signal-ed (assert test)
103     output from cloned children seems funky (unistd/clone test)
104     ldso is not implemented
105   arm:
106     update crt1 code again for nommu (http://bugs.uclibc.org/view.php?id=538)
107     recruit jbowler and integrate thumb support
108   m68k:
109     ldso lazy relocation doesnt work
110   mips:
111     brk/pipe fixes: http://www.uclibc.org/lists/uclibc/2006-January/013824.html
112                     http://bugs.uclibc.org/view.php?id=469
113   sparc:
114     need a sigaction.c since common one doesnt work (signal tests)
115     ldso needs to be updated since it's totally broken atm
116   x86_64:
117     pthread isn't working really at all (pthreads tests)
118   vax:
119     pthread support, linktime warning support (implies GAS patches),
120     general touchups, testing, ldso.
121   bfin cris rfv sh64:
122     need to be updated to new ldso changes and unification of the 
123      two uClibc_main funcs (__uClibc_start_main doesnt exist anymore)
124
125
126
127 -----------------------------------------------------------------------------
128 Manuel's todo:
129
130   1) Little things that need fixing:
131   ----------------------------------
132   a) Fix bug in *printf: outdigit precison bug
133   b) Check that gnu/bsd extension members tm_gmtoff and tm_zone in struct tm
134      are respected where they should be.
135   c) Implement the obstack printf funcs for glibc compat.
136   d) Implement glibc 'a' flag for scanf string conversions.
137   e) Allow use of the older non-table-based ctype functions when using
138      stub locale support. (smaller)
139
140   2) Additional str{f|p}time issues.
141   ----------------------------------
142   a) Spacing issue wrt strptime.
143   b) Support locale specific alternate digits.  (data is in place)
144   c) Support locale era in year designations.   (data is in place)
145   d) Deal with mb format string issues in strftime.
146   e) Implement wcsftime.
147
148   3) Other locale issues (my implementation):
149   -------------------------------------------
150   a) Do a little more clean up of ctype and wctype.
151   b) Rework of the locale data organization to make using locales reasonable
152      when staticly linking.  (mmap)
153   c) Rewrite the locale data generation tools to process the text specifications
154      rather than relying on glibc.
155   d) Adapt regex lib to use my collation data and add the necessary collating
156      item tables to support SUSv3 required features.
157   e) transliteration of unsupported wchars in 8-bit locales (like glibc).
158   f) Support ISO/IEC 14652 draft locale extensions (LC_PAPER, etc).
159   g) Implement strfrom.
160   h) Shift-state codeset locale support?
161
162   4) Misc:
163   --------
164   a) Port uClibc to other OSs (including elks), or even bare metal (libgloss).
165   b) Write a space-efficient gettext substitute, to avoid storing large amounts
166      of redundant data.
167