blob: cbca6cb16620a08a48ad9431243e09e9603ddb37 [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' Turner3527fd62010-06-14 17:18:35 -070030- <wchar.h>: small fixes to really support wchar_t in Bionic (not there yet).
31
32 the size of wchar_t is still 32-bit (decided by the compiler)
33
34 WCHAR_MIN: changed from 0 to INT_MIN
35 WCHAR_MAX: changed from 255 to INT_MAX
36
37 wcpcpy(), wcpncpy(), wcscat(), wcschr(), wcscmp(),
38 wcscpy(), wcscspn(), wcsdup(), wcslcat(), wcslcpy(),
39 wcslen(), wcsncat(), wcsncmp(), wcsncpy(), wcsnlen(),
40 wcspbrk(), wcsrchr(), wcsrchr(), wcsspn(), wcsstr(),
41 wcstok(), wcswidth(), wmemchr(), wmemcmp(), wmemcpy(),
42 wmemmove(), wmemset(): Added proper implementations.
43
44 wcscasecmp(), wcsncasecmp(): Added implementation limited
45 to ASCII codes for lower/upper.
46
47 wcscoll(): added dummy implementation that calls wcscmp()
48 wcsxfrm(): added dummy implementation that calls wcsncpy()
49
50 NOTE: Technically, this breaks the ABI, but we never claimed to support
51 wchar_t anyway. The wchar_t support is still *NOT* official at this
52 point. We need better multi-byte support code, and wprintf/wscanf
53 stuff too.
54
David 'Digit' Turner50ace4f2010-06-16 16:36:41 -070055- <inttypes.h>: add missing declarations for strntoimax abd strntoumax.
56
57- <stdlib.h>: add missing declarations for drand48() and erand48().
58
59- clearerr(): fix broken implementation.
60
61- Feature test macros like _POSIX_C_SOURCE / _XOPEN_SOURCE / _C99_SOURCE
62 are now handled correctly by our C library headers (see <sys/cdefs.h>)
63
64- <sys/select.h>: add missing declaration for pselect()
65
David 'Digit' Turnerab8b5412010-07-08 16:52:27 -070066- <sys/vfs.h>: fixed implementation of fstatfs() (also fixes fpathconf()
67 which uses it).
David 'Digit' Turner50ace4f2010-06-16 16:36:41 -070068
David 'Digit' Turner8a1d2cf2010-05-11 16:39:22 -070069-------------------------------------------------------------------------------
70Differences between Android 2.2. and Android 2.1:
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -080071
David 'Digit' Turnerb8e6c502010-03-25 09:54:33 -070072- Support FP register save/load in setjmp()/longjmp() on ARMv7 builds.
73
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -080074- Add support for SH-4 CPU architecture !
75
76- __atomic_swap(): use LDREX/STREX CPU instructions on ARMv6 and higher.
77
78- <arpa/telnet.h>: New header (declarations only, no implementation).
79
80- <err.h>: New header + implementation. GLibc compatibility.
81
82- <warn.h>: New header + implementation. GLibc compatibility.
83
84- <fts.h>: New header + implementation.
85
86- <mntent.h>: Add missing <stdio.h> include.
87
88- <regex.h>: New header + implementation.
89
90- <signal.h>: Added killpg()
91
92- <stdint.h>: Allow 64-bit type declarations on C99 builds.
93
94- <stdio.h>: Add fdprintf() and vfdprintf(). Note that GLibc provides
95 the confusing 'dprintf' and 'vdprintf()' functions instead.
96
97- <stdlib.h>: Fix ptsname_r(): the return type is int instead of char*.
98 The mistake comes from a GLibc man page bug (the man page listed a return
99 type of char*, while the implementation used int. Fixed in late 2009 only).
100 The Bionic implementation was incorrect. Technically, this is an ABI
101 breakage, but code that used this function probably never worked or
102 compiled properly anyway.
103
104- <strings.h>: Add missing <sys/types.h> include.
105
106- <sys/queue.h>: Added new header (no implementation - macro templates).
107
108- <sys/resource.h>: Add rlim_t proper definition.
109
110- <time64.h>: Add missing C++ header inclusion guards.
111
112- <unistd.h>: Add getusershell(), setusershell() and endusershell(), though
113 implementation are bogus. GLibc compatibility.
114
115- <wchar.h>: Add mbstowcs() and wcstombs()
116
David 'Digit' Turner294dd0b2010-02-12 12:18:37 -0800117- add clone() implementation for ARM (x86 and SH-4 not working yet).
118
119- <sys/epoll.h>: <sys/system_properties.h>: Add missing C++ inclusion guards
120
121- fix getpwnam() and getpwgrp() to accept "app_0" as a valid user name.
122
123- fix sem_trywait() to return -1 and set errno to EAGAIN, instead of
124 returning EAGAIN directly.
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -0800125
David 'Digit' Turner4f920f62010-02-12 12:50:32 -0800126- fix sem_post() to wake up multiple threads when called rapidly in
127 succession.
128
Steinar H. Gunderson9ab75d42010-02-11 15:44:55 +0100129- DNS: partial implementation of RFC3484 (rule 1, 2, 5, 6, 8, 10 and
130 modified rule 9), for better address selection/sorting.
131 In the process, removed code that was previously used for "sortlist"
132 in /etc/resolv.conf. (resolv.conf is already ignored, so the latter
133 is a no-op for actual functionality.)
134
David 'Digit' Turner8f8b5312010-03-01 11:30:40 -0800135- fix pthread_sigmask() to properly return an error code without touching
136 errno. Previous implementation returned -1 on error, setting errno, which
137 is not Posix compliant.
138
Andrei Popescueb9d5ed2010-02-25 13:27:46 +0000139- add sigaltstack() implementation for ARM.
140
David 'Digit' Turnerd7ed1ae2010-03-05 14:17:35 -0800141- <time.h>: Properly implement the 'timezone' and 'daylight' global variables
142 (they were not defined previously, though declared in the header).
143
144- <time.h>: Fix timezone management implementation to properly update
145 'tm_gmtoff' field in 'struct tm' structure.
146
David 'Digit' Turnerd378c682010-03-08 15:13:04 -0800147- DNS: get rid of spurious random DNS queries when trying to resolve
148 an unknown domain name. Due to an initialization bug, a random DNS search
David 'Digit' Turneree7b0772010-03-18 14:07:42 -0700149 list was generated for each thread if net.dns.search is not defined.
150
151- <pthread.h>: Add pthread_condattr_init/destroy/setpshared/getpshared functions
152 to enable proper shared conditional variable initialization.
153
David 'Digit' Turnerb5e4a412010-03-19 17:59:23 -0700154 Modify the pthread_mutex_t and pthread_cond_t implementation to use private
155 futexes for performance reasons. Mutexes and Condvars are no longer shareable
156 between processes by default anymore, unless you use PTHREAD_PROCESS_SHARED
157 with pthread_mutexattr_setpshared() and/or pthread_condattr_setpshared().
David 'Digit' Turnerd378c682010-03-08 15:13:04 -0800158
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -0800159-------------------------------------------------------------------------------
160Differences between Android 2.1 and 2.0.1:
161
162- zoneinfo: updated data tables to version 2009s
163
164
165-------------------------------------------------------------------------------
166Differences between Android 2.0.1 and 2.0:
167
168- abort(): ARM-specific hack to preserve the 'lr' register when abort()
169 is called (GCC does not preserve it by default since it thinks that
170 abort() never returns). This improves stack traces considerably.
171
172
173-------------------------------------------------------------------------------
174Differences between Android 2.0 and 1.6:
175
176- memcmp(), memcpy(): ARMv7 optimized versions.
177
178- pthread_mutexattr_setpshared(): implementation will not return ENOTSUP
179 if PTHREAD_PROCESS_SHARED is used, because our Mutex implementation can
180 work across multiple processes.
181
182 *HOWEVER* it does not use "robust futexes" which means that held mutexes
183 *are not* automatically released by the kernel when the owner process
184 crashes or exits. This is only done to simplify communication between
185 two always-live system processes, DO NOT USE THIS IN APPLICATIONS !
186
187- pthread_mutex_lock_timeout_np(): New Android-specific function to
188 perform a timed lock (). In case of timeout, it returns EBUSY.
189
190- pthread_cond_timedwait_monotonic_np(): Same as pthread_cond_timedwait()
191 but uses the monotonic clock(). Android-specific.
192
193- pthread_cond_timedwait_relative_np(): Same as pthread_cond_timedwait()
194 but uses a relative timeout instead. Android-specific.
195
196- <netinet/in.h>: Now includes <netinet/in6.h>.
197
198- <netinet/in6.h>: Added IPV6_JOIN_GROUP, IPV6_LEAVE_GROUP, IN6ADDR_ANY_INIT
199 and ipv6mr_interface definitions.
200
201- <time.h>:
202 * Add missing tzset() declaration.
203 * Add Android-specific strftime_tz().
204
205- getaddrinfo():
206 Only perform IPv6 lookup for AF_UNSPEC if we have IPv6 connectivity.
207 This saves one DNS query per lookup on non-IPv6 systems.
208
209- mktime(): Fix an infinite loop problen that appeared when switching to
210 GCC 4.4.0.
211
212- strftime(): fix incorrect handling of dates > 2038 due to 64-bit issue
213 in original code.
214
215-------------------------------------------------------------------------------
216Differences between Android 1.6 and 1.5:
217
218- C runtime: Fix runtime initialization to be called before any static C++
219 constructors. This allows these to use pthread functions properly.
220
221- __aeabi_atexit(): Fix implementation to properly call C++ static destructors
222 when the program exits (or when a shared library is unloaded).
223
224- <sys/stat.h>: added GLibc compatibility macros definitions:
225
226 #define st_atimensec st_atime_nsec
227 #define st_mtimensec st_mtime_nsec
228 #define st_ctimensec st_ctime_nsec
229
230- getaddrinfo(): implementation will now allow numeric ports if ai_socktype is
231 set to ANY. This is to match the GLibc behaviour.
232
233- getservent(): and getservent_r() incorrectly returned the port in host-endian
234 order in the s_port field. It now returns it in big-endian order.
235
236- DNS: Allow underscore in the middle of DNS labels. While not really
237 standard, this extension is needed for some VPN configurations and is
238 supported by other operating systems.
239
240- DNS: Support for DNS domain search lists through the new net.dns.search
241 system property. The corresponding value must be a space-separated list of
242 domain suffixes.