blob: ee4c34c7cbb972733dee1b43036adfb404157ddc [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' Turneraa4b1d02010-05-20 10:55:45 -070011- <sys/sysinfo.h>: Added missing sysinfo() system call implementation
12 (the function was already declared in the header though).
13
David 'Digit' Turner8a1d2cf2010-05-11 16:39:22 -070014-------------------------------------------------------------------------------
15Differences between Android 2.2. and Android 2.1:
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -080016
David 'Digit' Turnerb8e6c502010-03-25 09:54:33 -070017- Support FP register save/load in setjmp()/longjmp() on ARMv7 builds.
18
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -080019- Add support for SH-4 CPU architecture !
20
21- __atomic_swap(): use LDREX/STREX CPU instructions on ARMv6 and higher.
22
23- <arpa/telnet.h>: New header (declarations only, no implementation).
24
25- <err.h>: New header + implementation. GLibc compatibility.
26
27- <warn.h>: New header + implementation. GLibc compatibility.
28
29- <fts.h>: New header + implementation.
30
31- <mntent.h>: Add missing <stdio.h> include.
32
33- <regex.h>: New header + implementation.
34
35- <signal.h>: Added killpg()
36
37- <stdint.h>: Allow 64-bit type declarations on C99 builds.
38
39- <stdio.h>: Add fdprintf() and vfdprintf(). Note that GLibc provides
40 the confusing 'dprintf' and 'vdprintf()' functions instead.
41
42- <stdlib.h>: Fix ptsname_r(): the return type is int instead of char*.
43 The mistake comes from a GLibc man page bug (the man page listed a return
44 type of char*, while the implementation used int. Fixed in late 2009 only).
45 The Bionic implementation was incorrect. Technically, this is an ABI
46 breakage, but code that used this function probably never worked or
47 compiled properly anyway.
48
49- <strings.h>: Add missing <sys/types.h> include.
50
51- <sys/queue.h>: Added new header (no implementation - macro templates).
52
53- <sys/resource.h>: Add rlim_t proper definition.
54
55- <time64.h>: Add missing C++ header inclusion guards.
56
57- <unistd.h>: Add getusershell(), setusershell() and endusershell(), though
58 implementation are bogus. GLibc compatibility.
59
60- <wchar.h>: Add mbstowcs() and wcstombs()
61
David 'Digit' Turner294dd0b2010-02-12 12:18:37 -080062- add clone() implementation for ARM (x86 and SH-4 not working yet).
63
64- <sys/epoll.h>: <sys/system_properties.h>: Add missing C++ inclusion guards
65
66- fix getpwnam() and getpwgrp() to accept "app_0" as a valid user name.
67
68- fix sem_trywait() to return -1 and set errno to EAGAIN, instead of
69 returning EAGAIN directly.
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -080070
David 'Digit' Turner4f920f62010-02-12 12:50:32 -080071- fix sem_post() to wake up multiple threads when called rapidly in
72 succession.
73
Steinar H. Gunderson9ab75d42010-02-11 15:44:55 +010074- DNS: partial implementation of RFC3484 (rule 1, 2, 5, 6, 8, 10 and
75 modified rule 9), for better address selection/sorting.
76 In the process, removed code that was previously used for "sortlist"
77 in /etc/resolv.conf. (resolv.conf is already ignored, so the latter
78 is a no-op for actual functionality.)
79
David 'Digit' Turner8f8b5312010-03-01 11:30:40 -080080- fix pthread_sigmask() to properly return an error code without touching
81 errno. Previous implementation returned -1 on error, setting errno, which
82 is not Posix compliant.
83
Andrei Popescueb9d5ed2010-02-25 13:27:46 +000084- add sigaltstack() implementation for ARM.
85
David 'Digit' Turnerd7ed1ae2010-03-05 14:17:35 -080086- <time.h>: Properly implement the 'timezone' and 'daylight' global variables
87 (they were not defined previously, though declared in the header).
88
89- <time.h>: Fix timezone management implementation to properly update
90 'tm_gmtoff' field in 'struct tm' structure.
91
David 'Digit' Turnerd378c682010-03-08 15:13:04 -080092- DNS: get rid of spurious random DNS queries when trying to resolve
93 an unknown domain name. Due to an initialization bug, a random DNS search
David 'Digit' Turneree7b0772010-03-18 14:07:42 -070094 list was generated for each thread if net.dns.search is not defined.
95
96- <pthread.h>: Add pthread_condattr_init/destroy/setpshared/getpshared functions
97 to enable proper shared conditional variable initialization.
98
David 'Digit' Turnerb5e4a412010-03-19 17:59:23 -070099 Modify the pthread_mutex_t and pthread_cond_t implementation to use private
100 futexes for performance reasons. Mutexes and Condvars are no longer shareable
101 between processes by default anymore, unless you use PTHREAD_PROCESS_SHARED
102 with pthread_mutexattr_setpshared() and/or pthread_condattr_setpshared().
David 'Digit' Turnerd378c682010-03-08 15:13:04 -0800103
David 'Digit' Turnerd6bf8f92010-01-21 15:03:26 -0800104-------------------------------------------------------------------------------
105Differences between Android 2.1 and 2.0.1:
106
107- zoneinfo: updated data tables to version 2009s
108
109
110-------------------------------------------------------------------------------
111Differences between Android 2.0.1 and 2.0:
112
113- abort(): ARM-specific hack to preserve the 'lr' register when abort()
114 is called (GCC does not preserve it by default since it thinks that
115 abort() never returns). This improves stack traces considerably.
116
117
118-------------------------------------------------------------------------------
119Differences between Android 2.0 and 1.6:
120
121- memcmp(), memcpy(): ARMv7 optimized versions.
122
123- pthread_mutexattr_setpshared(): implementation will not return ENOTSUP
124 if PTHREAD_PROCESS_SHARED is used, because our Mutex implementation can
125 work across multiple processes.
126
127 *HOWEVER* it does not use "robust futexes" which means that held mutexes
128 *are not* automatically released by the kernel when the owner process
129 crashes or exits. This is only done to simplify communication between
130 two always-live system processes, DO NOT USE THIS IN APPLICATIONS !
131
132- pthread_mutex_lock_timeout_np(): New Android-specific function to
133 perform a timed lock (). In case of timeout, it returns EBUSY.
134
135- pthread_cond_timedwait_monotonic_np(): Same as pthread_cond_timedwait()
136 but uses the monotonic clock(). Android-specific.
137
138- pthread_cond_timedwait_relative_np(): Same as pthread_cond_timedwait()
139 but uses a relative timeout instead. Android-specific.
140
141- <netinet/in.h>: Now includes <netinet/in6.h>.
142
143- <netinet/in6.h>: Added IPV6_JOIN_GROUP, IPV6_LEAVE_GROUP, IN6ADDR_ANY_INIT
144 and ipv6mr_interface definitions.
145
146- <time.h>:
147 * Add missing tzset() declaration.
148 * Add Android-specific strftime_tz().
149
150- getaddrinfo():
151 Only perform IPv6 lookup for AF_UNSPEC if we have IPv6 connectivity.
152 This saves one DNS query per lookup on non-IPv6 systems.
153
154- mktime(): Fix an infinite loop problen that appeared when switching to
155 GCC 4.4.0.
156
157- strftime(): fix incorrect handling of dates > 2038 due to 64-bit issue
158 in original code.
159
160-------------------------------------------------------------------------------
161Differences between Android 1.6 and 1.5:
162
163- C runtime: Fix runtime initialization to be called before any static C++
164 constructors. This allows these to use pthread functions properly.
165
166- __aeabi_atexit(): Fix implementation to properly call C++ static destructors
167 when the program exits (or when a shared library is unloaded).
168
169- <sys/stat.h>: added GLibc compatibility macros definitions:
170
171 #define st_atimensec st_atime_nsec
172 #define st_mtimensec st_mtime_nsec
173 #define st_ctimensec st_ctime_nsec
174
175- getaddrinfo(): implementation will now allow numeric ports if ai_socktype is
176 set to ANY. This is to match the GLibc behaviour.
177
178- getservent(): and getservent_r() incorrectly returned the port in host-endian
179 order in the s_port field. It now returns it in big-endian order.
180
181- DNS: Allow underscore in the middle of DNS labels. While not really
182 standard, this extension is needed for some VPN configurations and is
183 supported by other operating systems.
184
185- DNS: Support for DNS domain search lists through the new net.dns.search
186 system property. The corresponding value must be a space-separated list of
187 domain suffixes.