David 'Digit' Turner | d6bf8f9 | 2010-01-21 15:03:26 -0800 | [diff] [blame] | 1 | Bionic ChangeLog: |
| 2 | ----------------- |
| 3 | |
David 'Digit' Turner | 8a1d2cf | 2010-05-11 16:39:22 -0700 | [diff] [blame] | 4 | Differences between current and Android 2.2: |
| 5 | |
| 6 | - <pthread.h>: Add reader/writer locks implementation. |
| 7 | |
David 'Digit' Turner | 6304d8b | 2010-06-02 18:12:12 -0700 | [diff] [blame] | 8 | - <semaphore.h>: Use private futexes for semaphore implementation, |
| 9 | unless your set 'pshared' to non-0 when calling sem_init(). |
| 10 | |
David 'Digit' Turner | 410b2ae | 2010-06-09 14:35:29 -0700 | [diff] [blame] | 11 | - <math.h>: Added sincos(), sincosf() and sincosl() (GLibc compatibility). |
| 12 | |
David 'Digit' Turner | aa4b1d0 | 2010-05-20 10:55:45 -0700 | [diff] [blame] | 13 | - <sys/sysinfo.h>: Added missing sysinfo() system call implementation |
| 14 | (the function was already declared in the header though). |
| 15 | |
David 'Digit' Turner | 038fbae | 2010-06-09 18:15:57 -0700 | [diff] [blame] | 16 | - sysconf() didn't work for some arguments due to a small bug in the |
| 17 | /proc line parser. |
| 18 | |
David 'Digit' Turner | ecb6d41 | 2010-06-11 13:30:25 -0700 | [diff] [blame] | 19 | - <termio.h>: added missing header (just includes <termios.h>) |
| 20 | |
David 'Digit' Turner | da3019b | 2010-06-11 14:37:34 -0700 | [diff] [blame] | 21 | - <unistd.h>: add missing declaration for truncate(). The implementation |
| 22 | was already here since Android 1.5. |
| 23 | |
David 'Digit' Turner | 3527fd6 | 2010-06-14 17:18:35 -0700 | [diff] [blame] | 24 | - <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' Turner | 8a1d2cf | 2010-05-11 16:39:22 -0700 | [diff] [blame] | 49 | ------------------------------------------------------------------------------- |
| 50 | Differences between Android 2.2. and Android 2.1: |
David 'Digit' Turner | d6bf8f9 | 2010-01-21 15:03:26 -0800 | [diff] [blame] | 51 | |
David 'Digit' Turner | b8e6c50 | 2010-03-25 09:54:33 -0700 | [diff] [blame] | 52 | - Support FP register save/load in setjmp()/longjmp() on ARMv7 builds. |
| 53 | |
David 'Digit' Turner | d6bf8f9 | 2010-01-21 15:03:26 -0800 | [diff] [blame] | 54 | - 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' Turner | 294dd0b | 2010-02-12 12:18:37 -0800 | [diff] [blame] | 97 | - 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' Turner | d6bf8f9 | 2010-01-21 15:03:26 -0800 | [diff] [blame] | 105 | |
David 'Digit' Turner | 4f920f6 | 2010-02-12 12:50:32 -0800 | [diff] [blame] | 106 | - fix sem_post() to wake up multiple threads when called rapidly in |
| 107 | succession. |
| 108 | |
Steinar H. Gunderson | 9ab75d4 | 2010-02-11 15:44:55 +0100 | [diff] [blame] | 109 | - 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' Turner | 8f8b531 | 2010-03-01 11:30:40 -0800 | [diff] [blame] | 115 | - 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 Popescu | eb9d5ed | 2010-02-25 13:27:46 +0000 | [diff] [blame] | 119 | - add sigaltstack() implementation for ARM. |
| 120 | |
David 'Digit' Turner | d7ed1ae | 2010-03-05 14:17:35 -0800 | [diff] [blame] | 121 | - <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' Turner | d378c68 | 2010-03-08 15:13:04 -0800 | [diff] [blame] | 127 | - 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' Turner | ee7b077 | 2010-03-18 14:07:42 -0700 | [diff] [blame] | 129 | 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' Turner | b5e4a41 | 2010-03-19 17:59:23 -0700 | [diff] [blame] | 134 | 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' Turner | d378c68 | 2010-03-08 15:13:04 -0800 | [diff] [blame] | 138 | |
David 'Digit' Turner | d6bf8f9 | 2010-01-21 15:03:26 -0800 | [diff] [blame] | 139 | ------------------------------------------------------------------------------- |
| 140 | Differences between Android 2.1 and 2.0.1: |
| 141 | |
| 142 | - zoneinfo: updated data tables to version 2009s |
| 143 | |
| 144 | |
| 145 | ------------------------------------------------------------------------------- |
| 146 | Differences 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 | ------------------------------------------------------------------------------- |
| 154 | Differences 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 | ------------------------------------------------------------------------------- |
| 196 | Differences 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. |