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