OSDN Git Service

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