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