blob: 0eab8791c92ae43bb915854893980f2d9a3000e9 [file] [log] [blame]
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -08001Bionic ChangeLog:
2-----------------
3
David 'Digit' Turner8a1d2cf2010-05-11 16:39:22 -07004Differences between current and Android 2.2:
5
David 'Digit' Turnera02b93b2010-06-28 14:20:22 -07006- <pthread.h>: Add reader/writer locks implementation. Add sanity
7 checking to pthread_mutex_destroy() (e.g. a locked mutex will return
8 EBUSY).
David 'Digit' Turner8a1d2cf2010-05-11 16:39:22 -07009
David 'Digit' Turner6304d8b2010-06-02 18:12:12 -070010- <semaphore.h>: Use private futexes for semaphore implementation,
11 unless your set 'pshared' to non-0 when calling sem_init().
12
David 'Digit' Turner51976322010-06-28 14:10:14 -070013 Also fixed a bug in sem_post() to make it wake up all waiting
14 threads, instead of one. As a consequence, the maximum semaphore
15 value is now reduced to 0x3fffffff.
16
David 'Digit' Turner410b2ae2010-06-09 14:35:29 -070017- <math.h>: Added sincos(), sincosf() and sincosl() (GLibc compatibility).
18
David 'Digit' Turneraa4b1d02010-05-20 10:55:45 -070019- <sys/sysinfo.h>: Added missing sysinfo() system call implementation
20 (the function was already declared in the header though).
21
David 'Digit' Turner038fbae2010-06-09 18:15:57 -070022- sysconf() didn't work for some arguments due to a small bug in the
23 /proc line parser.
24
David 'Digit' Turnerecb6d412010-06-11 13:30:25 -070025- <termio.h>: added missing header (just includes <termios.h>)
26
David 'Digit' Turnerda3019b2010-06-11 14:37:34 -070027- <unistd.h>: add missing declaration for truncate(). The implementation
28 was already here since Android 1.5.
29
David 'Digit' Turnercb7e8c52010-07-08 17:19:07 -070030 modify implementation of alarm() to return 0 in case of error (i.e.
31 if a value larger than 0x7fffffff seconds is passed to it). This
32 makes the implementation compliant with the GLibc behaviour.
33
David 'Digit' Turner3527fd62010-06-14 17:18:35 -070034- <wchar.h>: small fixes to really support wchar_t in Bionic (not there yet).
35
36 the size of wchar_t is still 32-bit (decided by the compiler)
37
38 WCHAR_MIN: changed from 0 to INT_MIN
39 WCHAR_MAX: changed from 255 to INT_MAX
40
41 wcpcpy(), wcpncpy(), wcscat(), wcschr(), wcscmp(),
42 wcscpy(), wcscspn(), wcsdup(), wcslcat(), wcslcpy(),
43 wcslen(), wcsncat(), wcsncmp(), wcsncpy(), wcsnlen(),
44 wcspbrk(), wcsrchr(), wcsrchr(), wcsspn(), wcsstr(),
45 wcstok(), wcswidth(), wmemchr(), wmemcmp(), wmemcpy(),
46 wmemmove(), wmemset(): Added proper implementations.
47
48 wcscasecmp(), wcsncasecmp(): Added implementation limited
49 to ASCII codes for lower/upper.
50
51 wcscoll(): added dummy implementation that calls wcscmp()
52 wcsxfrm(): added dummy implementation that calls wcsncpy()
53
54 NOTE: Technically, this breaks the ABI, but we never claimed to support
55 wchar_t anyway. The wchar_t support is still *NOT* official at this
56 point. We need better multi-byte support code, and wprintf/wscanf
57 stuff too.
58
David 'Digit' Turner50ace4f2010-06-16 16:36:41 -070059- <inttypes.h>: add missing declarations for strntoimax abd strntoumax.
60
61- <stdlib.h>: add missing declarations for drand48() and erand48().
62
63- clearerr(): fix broken implementation.
64
65- Feature test macros like _POSIX_C_SOURCE / _XOPEN_SOURCE / _C99_SOURCE
66 are now handled correctly by our C library headers (see <sys/cdefs.h>)
67
68- <sys/select.h>: add missing declaration for pselect()
69
David 'Digit' Turnerab8b5412010-07-08 16:52:27 -070070- <sys/vfs.h>: fixed implementation of fstatfs() (also fixes fpathconf()
71 which uses it).
David 'Digit' Turner50ace4f2010-06-16 16:36:41 -070072
Matt Fischer4f086ae2010-06-25 14:36:39 -050073- Added an implementation of pthread_atfork()
74
David 'Digit' Turner67748092010-07-21 16:18:21 -070075- <dlfcn.h>: fixed dlopen() implementation to support dlopen(NULL, ...).
76 This allows one to look at the dynamic symbols exported by an executable.
David 'Digit' Turnercb7e8c52010-07-08 17:19:07 -070077
David 'Digit' Turner6a51def2010-08-27 08:19:19 -070078- <private/bionic_tls.h>: use kernel helper functions for static versions
79 of the C library. This is necessary because we don't know where the corresponding
80 machine code is going to run, and the optimization for __get_tls() might
81 not match the features of the target device where we run a static executable
82 linked to the C library. This fixes one of the bug that explains why gdbserver
83 didn't work well with threads.
84
David 'Digit' Turner8a1d2cf2010-05-11 16:39:22 -070085-------------------------------------------------------------------------------
86Differences between Android 2.2. and Android 2.1:
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -080087
David 'Digit' Turnerb8e6c502010-03-25 09:54:33 -070088- Support FP register save/load in setjmp()/longjmp() on ARMv7 builds.
89
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -080090- Add support for SH-4 CPU architecture !
91
92- __atomic_swap(): use LDREX/STREX CPU instructions on ARMv6 and higher.
93
94- <arpa/telnet.h>: New header (declarations only, no implementation).
95
96- <err.h>: New header + implementation. GLibc compatibility.
97
98- <warn.h>: New header + implementation. GLibc compatibility.
99
100- <fts.h>: New header + implementation.
101
102- <mntent.h>: Add missing <stdio.h> include.
103
104- <regex.h>: New header + implementation.
105
106- <signal.h>: Added killpg()
107
108- <stdint.h>: Allow 64-bit type declarations on C99 builds.
109
110- <stdio.h>: Add fdprintf() and vfdprintf(). Note that GLibc provides
111 the confusing 'dprintf' and 'vdprintf()' functions instead.
112
113- <stdlib.h>: Fix ptsname_r(): the return type is int instead of char*.
114 The mistake comes from a GLibc man page bug (the man page listed a return
115 type of char*, while the implementation used int. Fixed in late 2009 only).
116 The Bionic implementation was incorrect. Technically, this is an ABI
117 breakage, but code that used this function probably never worked or
118 compiled properly anyway.
119
120- <strings.h>: Add missing <sys/types.h> include.
121
122- <sys/queue.h>: Added new header (no implementation - macro templates).
123
124- <sys/resource.h>: Add rlim_t proper definition.
125
126- <time64.h>: Add missing C++ header inclusion guards.
127
128- <unistd.h>: Add getusershell(), setusershell() and endusershell(), though
129 implementation are bogus. GLibc compatibility.
130
131- <wchar.h>: Add mbstowcs() and wcstombs()
132
David 'Digit' Turner294dd0b2010-02-12 12:18:37 -0800133- add clone() implementation for ARM (x86 and SH-4 not working yet).
134
135- <sys/epoll.h>: <sys/system_properties.h>: Add missing C++ inclusion guards
136
137- fix getpwnam() and getpwgrp() to accept "app_0" as a valid user name.
138
139- fix sem_trywait() to return -1 and set errno to EAGAIN, instead of
140 returning EAGAIN directly.
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -0800141
David 'Digit' Turner4f920f62010-02-12 12:50:32 -0800142- fix sem_post() to wake up multiple threads when called rapidly in
143 succession.
144
Steinar H. Gunderson9ab75d42010-02-11 15:44:55 +0100145- DNS: partial implementation of RFC3484 (rule 1, 2, 5, 6, 8, 10 and
146 modified rule 9), for better address selection/sorting.
147 In the process, removed code that was previously used for "sortlist"
148 in /etc/resolv.conf. (resolv.conf is already ignored, so the latter
149 is a no-op for actual functionality.)
150
David 'Digit' Turner8f8b5312010-03-01 11:30:40 -0800151- fix pthread_sigmask() to properly return an error code without touching
152 errno. Previous implementation returned -1 on error, setting errno, which
153 is not Posix compliant.
154
Andrei Popescueb9d5ed2010-02-25 13:27:46 +0000155- add sigaltstack() implementation for ARM.
156
David 'Digit' Turnerd7ed1ae2010-03-05 14:17:35 -0800157- <time.h>: Properly implement the 'timezone' and 'daylight' global variables
158 (they were not defined previously, though declared in the header).
159
160- <time.h>: Fix timezone management implementation to properly update
161 'tm_gmtoff' field in 'struct tm' structure.
162
David 'Digit' Turnerd378c682010-03-08 15:13:04 -0800163- DNS: get rid of spurious random DNS queries when trying to resolve
164 an unknown domain name. Due to an initialization bug, a random DNS search
David 'Digit' Turneree7b0772010-03-18 14:07:42 -0700165 list was generated for each thread if net.dns.search is not defined.
166
167- <pthread.h>: Add pthread_condattr_init/destroy/setpshared/getpshared functions
168 to enable proper shared conditional variable initialization.
169
David 'Digit' Turnerb5e4a412010-03-19 17:59:23 -0700170 Modify the pthread_mutex_t and pthread_cond_t implementation to use private
171 futexes for performance reasons. Mutexes and Condvars are no longer shareable
172 between processes by default anymore, unless you use PTHREAD_PROCESS_SHARED
173 with pthread_mutexattr_setpshared() and/or pthread_condattr_setpshared().
David 'Digit' Turnerd378c682010-03-08 15:13:04 -0800174
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -0800175-------------------------------------------------------------------------------
176Differences between Android 2.1 and 2.0.1:
177
178- zoneinfo: updated data tables to version 2009s
179
180
181-------------------------------------------------------------------------------
182Differences between Android 2.0.1 and 2.0:
183
184- abort(): ARM-specific hack to preserve the 'lr' register when abort()
185 is called (GCC does not preserve it by default since it thinks that
186 abort() never returns). This improves stack traces considerably.
187
188
189-------------------------------------------------------------------------------
190Differences between Android 2.0 and 1.6:
191
192- memcmp(), memcpy(): ARMv7 optimized versions.
193
194- pthread_mutexattr_setpshared(): implementation will not return ENOTSUP
195 if PTHREAD_PROCESS_SHARED is used, because our Mutex implementation can
196 work across multiple processes.
197
198 *HOWEVER* it does not use "robust futexes" which means that held mutexes
199 *are not* automatically released by the kernel when the owner process
200 crashes or exits. This is only done to simplify communication between
201 two always-live system processes, DO NOT USE THIS IN APPLICATIONS !
202
203- pthread_mutex_lock_timeout_np(): New Android-specific function to
204 perform a timed lock (). In case of timeout, it returns EBUSY.
205
206- pthread_cond_timedwait_monotonic_np(): Same as pthread_cond_timedwait()
207 but uses the monotonic clock(). Android-specific.
208
209- pthread_cond_timedwait_relative_np(): Same as pthread_cond_timedwait()
210 but uses a relative timeout instead. Android-specific.
211
212- <netinet/in.h>: Now includes <netinet/in6.h>.
213
214- <netinet/in6.h>: Added IPV6_JOIN_GROUP, IPV6_LEAVE_GROUP, IN6ADDR_ANY_INIT
215 and ipv6mr_interface definitions.
216
217- <time.h>:
218 * Add missing tzset() declaration.
219 * Add Android-specific strftime_tz().
220
221- getaddrinfo():
222 Only perform IPv6 lookup for AF_UNSPEC if we have IPv6 connectivity.
223 This saves one DNS query per lookup on non-IPv6 systems.
224
225- mktime(): Fix an infinite loop problen that appeared when switching to
226 GCC 4.4.0.
227
228- strftime(): fix incorrect handling of dates > 2038 due to 64-bit issue
229 in original code.
230
231-------------------------------------------------------------------------------
232Differences between Android 1.6 and 1.5:
233
234- C runtime: Fix runtime initialization to be called before any static C++
235 constructors. This allows these to use pthread functions properly.
236
237- __aeabi_atexit(): Fix implementation to properly call C++ static destructors
238 when the program exits (or when a shared library is unloaded).
239
240- <sys/stat.h>: added GLibc compatibility macros definitions:
241
242 #define st_atimensec st_atime_nsec
243 #define st_mtimensec st_mtime_nsec
244 #define st_ctimensec st_ctime_nsec
245
246- getaddrinfo(): implementation will now allow numeric ports if ai_socktype is
247 set to ANY. This is to match the GLibc behaviour.
248
249- getservent(): and getservent_r() incorrectly returned the port in host-endian
250 order in the s_port field. It now returns it in big-endian order.
251
252- DNS: Allow underscore in the middle of DNS labels. While not really
253 standard, this extension is needed for some VPN configurations and is
254 supported by other operating systems.
255
256- DNS: Support for DNS domain search lists through the new net.dns.search
257 system property. The corresponding value must be a space-separated list of
258 domain suffixes.