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