Remove --enable-obsolete-rpc configure flag
[platform/upstream/glibc.git] / NEWS
1 GNU C Library NEWS -- history of user-visible changes.
2 Copyright (C) 1992-2020 Free Software Foundation, Inc.
3 See the end for copying conditions.
4
5 Please send GNU C library bug reports via <https://sourceware.org/bugzilla/>
6 using `glibc' in the "product" field.
7 \f
8 Version 2.32
9
10 Major new features:
11
12 * Unicode 13.0.0 Support: Character encoding, character type info, and
13   transliteration tables are all updated to Unicode 13.0.0, using
14   generator scripts contributed by Mike FABIAN (Red Hat).
15
16 * New locale added: ckb_IQ (Kurdish/Sorani spoken in Iraq)
17
18 * Support for Synopsys ARC HS cores (ARCv2 ISA) running Linux has been
19   added. This port requires at least binutils-2.32, gcc-8.3 and Linux-5.1.
20   Three ABIs are supported:
21
22      - arc-linux-gnu
23      - arc-linux-gnuhf
24      - arceb-linux-gnu
25
26   The arc* ABI is little-endian while arceb is big-endian. All ABIs use
27   64-bit time (y2038 safe) and 64-bit file offsets (LFS default).
28
29 * The GNU C Library now loads audit modules listed in the DT_AUDIT and
30   DT_DEPAUDIT dynamic section entries of the main executable.
31
32 * powerpc64le supports IEEE128 long double libm/libc redirects when
33   using the -mabi=ieeelongdouble to compile C code on supported GCC
34   toolchains.  It is recommended to use GCC 8 or newer when testing
35   this option.
36
37 * To help detect buffer overflows and other out-of-bounds accesses
38   several APIs have been annotated with GCC 'access' attribute.  This
39   should help GCC 10 issue better warnings.
40
41 * On Linux, functions the pthread_attr_setsigmask_np and
42   pthread_attr_getsigmask_np have been added.  They allow applications
43   to specify the signal mask of a thread created with pthread_create.
44
45 * Support for automatically registering threads with the Linux rseq
46   system call has been added.  This system call is implemented starting
47   from Linux 4.18.  The Restartable Sequences ABI accelerates user-space
48   operations on per-cpu data.  It allows user-space to perform updates
49   on per-cpu data without requiring heavy-weight atomic operations.
50   Automatically registering threads allows all libraries, including libc,
51   to make immediate use of the rseq support by using the documented ABI.
52   The GNU C Library manual has details on integration of Restartable
53   Sequences.
54
55 * The GNU C Library now provides the header file <sys/single_threaded.h>
56   which declares the variable __libc_single_threaded.  Applications are
57   encouraged to use this variable for single-thread optimizations,
58   instead of weak references to symbols historically defined in
59   libpthread.
60
61 * The functions sigabbrev_np and sigdescr_np have been added.  The
62   sigabbrev_np returns the abbreviated signal name (e.g. "HUP" for SIGHUP)
63   while sigdescr_np returns a string describing the signal number (e.g
64   "Hangup" for SIGHUP).  Different than strsignal, sigdescr_np does not
65   attempt to translate the return description, both functions return
66   NULL for an invalid signal number.
67
68   They should be used instead of sys_siglist or sys_sigabbrev and they
69   are both thread and async-signal safe.  These functions are GNU extensions.
70
71 * The functions strerrorname_np and strerrordesc_np have been added.  The
72   strerroname_np returns error number name (e.g. "EINVAL" for EINVAL) while
73   strerrordesc_np returns string describing error number
74   (e.g "Invalid argument" for EINVAL).  Different than strerror,
75   strerrordesc_np does not attempt to translate the return description, both
76   functions return NULL for an invalid error number.
77
78   They should be used instead of sys_errlist and sys_nerr, both are
79   thread and async-signal safe.  These functions are GNU extensions.
80
81 * AArch64 now supports standard branch protection security hardening
82   in glibc when it is built with a GCC that is configured with
83   --enable-standard-branch-protection.  This includes branch target
84   identification (BTI) and pointer authentication for return addresses
85   (PAC-RET).  They require armv8.5-a and armv8.3-a architecture
86   extensions respectively for the protection to be effective,
87   otherwise the used instructions are nops.  User code can use PAC-RET
88   without libc support, but BTI requires a libc that is built with BTI
89   support, otherwise runtime objects linked into user code will not be
90   BTI compatible.
91
92 Deprecated and removed features, and other changes affecting compatibility:
93
94 * Remove configure option --enable-obsolete-rpc.  Sun RPC is removed
95   from glibc.  This includes the rpcgen program, librpcsvc, and the Sun
96   RPC header files.  Backward compatibility for old programs is kept
97   only for architectures and ABIs that have been added in or before
98   glibc 2.31.  New programs need to use TI-RPC
99   <http://git.linux-nfs.org/?p=steved/libtirpc.git;a=summary> and
100   rpcsvc-proto <https://github.com/thkukuk/rpcsvc-proto>.
101
102 * Remove configure option --enable-obsolete-nsl.  libnsl is only built
103   as shared library for backward compatibility and the NSS modules "nis"
104   and "nisplus" are not built at all and libnsl's headers aren't
105   installed.  This compatibility is kept only for architectures and ABIs
106   that have been added in or before version 2.28.  Replacement
107   implementations based on TI-RPC, which additionally support IPv6, are
108   available from <https://github.com/thkukuk/>.  This change does not
109   affect the "compat" NSS module, which does not depended on libnsl
110   since 2.27 and thus can be used without NIS.
111
112 * The deprecated <sys/sysctl.h> header and the sysctl function have been
113   removed.  To support old binaries, the sysctl function continues to
114   exist as a compatibility symbol (on those architectures which had it),
115   but always fails with ENOSYS.  This reflects the removal of the system
116   call from all architectures, starting with Linux 5.5.
117
118 * The sstk function is no longer available to newly linked binaries.
119   Its implementation always returned with a failure, and the function
120   was not declared in any header file.
121
122 * The legacy signal handling functions siginterrupt, sigpause, sighold,
123   sigrelse, sigignore and sigset, and the sigmask macro have been
124   deprecated.  Applications should use the sigsuspend, sigprocmask and
125   sigaction functions instead.
126
127 * ldconfig now defaults to the new format for ld.so.cache. glibc has
128   already supported this format for almost 20 years.
129
130 * The deprecated arrays sys_siglist, _sys_siglist, and sys_sigabbrev
131   are no longer available to newly linked binaries, and their declarations
132   have been removed from <string.h>.  They are exported solely as
133   compatibility symbols to support old binaries.  All programs should use
134   strsignal instead.
135
136 * The deprecated symbols sys_errlist, _sys_errlist, sys_nerr, and _sys_nerr
137   are no longer available to newly linked binaries, and their declarations
138   have been removed from from <stdio.h>.  They are exported solely as
139   compatibility symbols to support old binaries.  All programs should use
140   strerror or strerror_r instead.
141
142 * Both strerror and strerror_l now share the same internal buffer in the
143   calling thread, meaning that the returned string pointer may be invalided
144   or contents might be overwritten on subsequent calls in the same thread or
145   if the thread is terminated.  It makes strerror MT-safe.
146
147 * The "files" NSS module no longer supports the "key" database (used for
148   secure RPC).  The contents of the /etc/publickey file will be ignored,
149   regardless of the settings in /etc/nsswitch.conf.  (This method of
150   storing RPC keys only supported the obsolete and insecure AUTH_DES
151   flavor of secure RPC.)
152
153 * The __morecore and __after_morecore_hook malloc hooks and the default
154   implementation __default_morecore have been deprecated.  Applications
155   should use malloc interposition to change malloc behavior, and mmap to
156   allocate anonymous memory.  A future version of glibc may require that
157   applications which use the malloc hooks must preload a special shared
158   object, to enable the hooks.
159
160 Changes to build and runtime requirements:
161
162 * powerpc64le requires GCC 7.4 or newer.  This is required for supporting
163   long double redirects.
164
165 Security related changes:
166
167   CVE-2020-10029: Trigonometric functions on x86 targets suffered from stack
168   corruption when they were passed a pseudo-zero argument.  Reported by Guido
169   Vranken / ForAllSecure Mayhem.
170
171   CVE-2020-1751: A defect in the PowerPC backtrace function could cause an
172   out-of-bounds write when executed in a signal frame context.
173
174   CVE-2020-1752: A use-after-free vulnerability in the glob function when
175   expanding ~user has been fixed.
176
177 The following bugs are resolved with this release:
178
179   [The release manager will add the list generated by
180   scripts/list-fixed-bugs.py just before the release.]
181 \f
182 Version 2.31
183
184 Major new features:
185
186 * The GNU C Library now supports a feature test macro _ISOC2X_SOURCE to
187   enable features from the draft ISO C2X standard.  Only some features from
188   this draft standard are supported by the GNU C Library, and as the draft
189   is under active development, the set of features enabled by this macro is
190   liable to change.  Features from C2X are also enabled by _GNU_SOURCE, or
191   by compiling with "gcc -std=gnu2x".
192
193 * The <math.h> functions that round their results to a narrower type now
194   have corresponding type-generic macros in <tgmath.h>, as defined in TS
195   18661-1:2014 and TS 18661-3:2015 as amended by the resolution of
196   Clarification Request 13 to TS 18661-3.
197
198 * The function pthread_clockjoin_np has been added, enabling join with a
199   terminated thread with a specific clock.  It allows waiting against
200   CLOCK_MONOTONIC and CLOCK_REALTIME.  This function is a GNU extension.
201
202 * New locale added: mnw_MM (Mon language spoken in Myanmar).
203
204 * The DNS stub resolver will optionally send the AD (authenticated data) bit
205   in queries if the trust-ad option is set via the options directive in
206   /etc/resolv.conf (or if RES_TRUSTAD is set in _res.options).  In this
207   mode, the AD bit, as provided by the name server, is available to
208   applications which call res_search and related functions.  In the default
209   mode, the AD bit is not set in queries, and it is automatically cleared in
210   responses, indicating a lack of DNSSEC validation.  (Therefore, the name
211   servers and the network path to them are treated as untrusted.)
212
213 Deprecated and removed features, and other changes affecting compatibility:
214
215 * The totalorder and totalordermag functions, and the corresponding
216   functions for other floating-point types, now take pointer arguments to
217   avoid signaling NaNs possibly being converted to quiet NaNs in argument
218   passing.  This is in accordance with the resolution of Clarification
219   Request 25 to TS 18661-1, as applied for C2X.  Existing binaries that pass
220   floating-point arguments directly will continue to work.
221
222 * The obsolete function stime is no longer available to newly linked
223   binaries, and its declaration has been removed from <time.h>.
224   Programs that set the system time should use clock_settime instead.
225
226 * We plan to remove the obsolete function ftime, and the header <sys/timeb.h>,
227   in a future version of glibc.  In this release, the header still exists
228   but calling ftime will cause a compiler warning.  All programs should use
229   gettimeofday or clock_gettime instead.
230
231 * The gettimeofday function no longer reports information about a
232   system-wide time zone.  This 4.2-BSD-era feature has been deprecated for
233   many years, as it cannot handle the full complexity of the world's
234   timezones, but hitherto we have supported it on a best-effort basis.
235   Changes required to support 64-bit time_t on 32-bit architectures have
236   made this no longer practical.
237
238   As of this release, callers of gettimeofday with a non-null 'tzp' argument
239   should expect to receive a 'struct timezone' whose tz_minuteswest and
240   tz_dsttime fields are zero.  (For efficiency reasons, this does not always
241   happen on a few Linux-based ports.  This will be corrected in a future
242   release.)
243
244   All callers should supply a null pointer for the 'tzp' argument to
245   gettimeofday.  For accurate information about the time zone associated
246   with the current time, use the localtime function.
247
248   gettimeofday itself is obsolescent according to POSIX.  We have no plans
249   to remove access to this function, but portable programs should consider
250   using clock_gettime instead.
251
252 * The settimeofday function can still be used to set a system-wide time
253   zone when the operating system supports it.  This is because the Linux
254   kernel reused the API, on some architectures, to describe a system-wide
255   time-zone-like offset between the software clock maintained by the kernel,
256   and the "RTC" clock that keeps time when the system is shut down.
257
258   However, to reduce the odds of this offset being set by accident,
259   settimeofday can no longer be used to set the time and the offset
260   simultaneously.  If both of its two arguments are non-null, the call
261   will fail (setting errno to EINVAL).
262
263   Callers attempting to set this offset should also be prepared for the call
264   to fail and set errno to ENOSYS; this already happens on the Hurd and on
265   some Linux architectures.  The Linux kernel maintainers are discussing a
266   more principled replacement for the reused API.  After a replacement
267   becomes available, we will change settimeofday to fail with ENOSYS on all
268   platforms when its 'tzp' argument is not a null pointer.
269
270   settimeofday itself is obsolescent according to POSIX.  Programs that set
271   the system time should use clock_settime and/or the adjtime family of
272   functions instead.  We may cease to make settimeofday available to newly
273   linked binaries after there is a replacement for Linux's time-zone-like
274   offset API.
275
276 * SPARC ISA v7 is no longer supported.  v8 is still supported, but only if
277   the optional CAS instruction is implemented (for instance, LEON processors
278   are still supported, but SuperSPARC processors are not).
279
280   As the oldest 64-bit SPARC ISA is v9, this only affects 32-bit
281   configurations.
282
283 * If a lazy binding failure happens during dlopen, during the execution of
284   an ELF constructor, the process is now terminated.  Previously, the
285   dynamic loader would return NULL from dlopen, with the lazy binding error
286   captured in a dlerror message.  In general, this is unsafe because
287   resetting the stack in an arbitrary function call is not possible.
288
289 * For MIPS hard-float ABIs, the GNU C Library will be configured to need an
290   executable stack unless explicitly configured at build time to require
291   minimum kernel version 4.8 or newer.  This is because executing
292   floating-point branches on a non-executable stack on Linux kernels prior to
293   4.8 can lead to application crashes for some MIPS configurations. While
294   currently PT_GNU_STACK is not widely used on MIPS, future releases of GCC are
295   expected to enable non-executable stack by default  with PT_GNU_STACK by
296   default and is thus likely to trigger a crash on older kernels.
297
298   The GNU C Library can be built with --enable-kernel=4.8.0 in order to keep a
299   non-executable stack while dropping support for older kernels.
300
301 * System call wrappers for time system calls now use the new time64 system
302   calls when available. On 32-bit targets, these wrappers attempt to call
303   the new system calls first and fall back to the older 32-bit time system
304   calls if they are not present.  This may cause issues in environments
305   that cannot handle unsupported system calls gracefully by returning
306   -ENOSYS. Seccomp sandboxes are affected by this issue.
307
308 Changes to build and runtime requirements:
309
310 * It is no longer necessary to have recent Linux kernel headers to build
311   working (non-stub) system call wrappers on all architectures except 64-bit
312   RISC-V.  64-bit RISC-V requires a minimum kernel headers version of 5.0.
313
314 * The ChangeLog file is no longer present in the toplevel directory of the
315   source tree.  ChangeLog files are located in the ChangeLog.old directory as
316   ChangeLog.N where the highest N has the latest entries.
317
318 Security related changes:
319
320   CVE-2019-19126: ld.so failed to ignore the LD_PREFER_MAP_32BIT_EXEC
321   environment variable during program execution after a security
322   transition, allowing local attackers to restrict the possible mapping
323   addresses for loaded libraries and thus bypass ASLR for a setuid
324   program.  Reported by Marcin Kościelnicki.
325
326 The following bugs are resolved with this release:
327
328   [12031] localedata: iconv -t ascii//translit with Greek characters
329   [15813] libc: Multiple issues in __gen_tempname
330   [17726] libc: [arm, sparc] profil_counter should be compat symbol
331   [18231] libc: ipc_perm struct's mode member has wrong type in sys/ipc.h
332   [19767] libc: vdso is not used with static linking
333   [19903] hurd: Shared mappings not being inherited by children processes
334   [20358] network: RES_USE_DNSSEC sets DO; should also have a way to set AD
335   [20839] dynamic-link: Incomplete rollback of dynamic linker state on
336     linking failure
337   [23132] localedata: Missing transliterations in Miscellaneous Mathematical
338     Symbols-A/B Unicode blocks
339   [23518] libc: Eliminate __libc_utmp_jump_table
340   [24026] malloc: malloc_info() returns wrong numbers
341   [24054] localedata: Many locales are missing date_fmt
342   [24214] dynamic-link: user defined ifunc resolvers may run in ldd mode
343   [24304] dynamic-link: Lazy binding failure during ELF
344     constructors/destructors is not fatal
345   [24376] libc: RISC-V symbol size confusion with _start
346   [24682] localedata: zh_CN first weekday should be Monday per GB/T
347     7408-2005
348   [24824] libc: test-in-container does not install charmap files compatible
349     with localedef
350   [24844] regex: regex bad pointer / leakage if malloc fails
351   [24867] malloc: Unintended malloc_info formatting changes
352   [24879] libc: login: utmp alarm timer can arrive after lock acquisition
353   [24880] libc: login: utmp implementation uses struct flock with fcntl64
354   [24882] libc: login: pututline uses potentially outdated cache
355   [24899] libc: Missing nonstring attributes in <utmp.h>, <utmpx.h>
356   [24902] libc: login: Repeating pututxline on EINTR/EAGAIN causes stale
357     utmp entries
358   [24916] dynamic-link: [MIPS] Highest EI_ABIVERSION value not raised to
359     ABSOLUTE ABI
360   [24930] dynamic-link: dlopen of PIE executable can result in
361     _dl_allocate_tls_init assertion failure
362   [24950] localedata: Top-of-tree glibc does not build with top-of-tree GCC
363     (stringop-overflow error)
364   [24959] time: librt IFUNC resolvers for clock_gettime and clock_*
365     functions other  can lead to crashes
366   [24967] libc: jemalloc static linking causes runtime failure
367   [24986] libc: alpha: new getegid, geteuid and getppid syscalls used
368     unconditionally
369   [25035] libc: sbrk() failure handled poorly in tunables_strdup
370   [25087] dynamic-link: ldconfig mishandles unusual .dynstr placement
371   [25097] libc: new -Warray-bounds with GCC 10
372   [25112] dynamic-link: dlopen must not make new objects accessible when it
373     still can fail with an error
374   [25139] localedata: Please add the new mnw_MM locale
375   [25149] regex: Array bounds violation in proceed_next_node
376   [25157] dynamic-link: Audit cookie for the dynamic loader is not
377     initialized correctly
378   [25189] libc: glibc's __glibc_has_include causes issues with clang
379     -frewrite-includes
380   [25194] malloc: malloc.c: do_set_mxfast incorrectly casts the mallopt
381     value to an unsigned
382   [25204] dynamic-link: LD_PREFER_MAP_32BIT_EXEC not ignored in setuid
383     binaries (CVE-2019-19126)
384   [25225] libc: ld.so fails to link on x86 if GCC defaults to -fcf-
385     protection
386   [25226] string: strstr: Invalid result if needle crosses page on s390-z15
387     ifunc variant.
388   [25232] string: <string.h> does not enable const correctness for strchr et
389     al. for Clang++
390   [25233] localedata: Consider "." as the thousands separator for sl_SI
391     (Slovenian)
392   [25241] nptl: __SIZEOF_PTHREAD_MUTEX_T defined twice for x86
393   [25251] build: Failure to run tests when CFLAGS contains -DNDEBUG.
394   [25271] libc: undeclared identifier PTHREAD_MUTEX_DEFAULT when compiling
395     with -std=c11
396   [25323] localedata: km_KH: d_t_fmt contains "m" instead of "%M"
397   [25324] localedata: lv_LV: d_t_fmt contains suspicious words in the time
398     part
399   [25396] dynamic-link: Failing dlopen can leave behind dangling GL
400     (dl_initfirst) link map pointer
401   [25401] malloc: pvalloc must not have __attribute_alloc_size__
402   [25423] libc: Array overflow in backtrace on powerpc
403   [25425] network: Missing call to __resolv_context_put in
404     getaddrinfo.c:gethosts
405
406 \f
407 Version 2.30
408
409 Major new features:
410
411 * Unicode 12.1.0 Support: Character encoding, character type info, and
412   transliteration tables are all updated to Unicode 12.1.0, using
413   generator scripts contributed by Mike FABIAN (Red Hat).
414
415 * The dynamic linker accepts the --preload argument to preload shared
416   objects, in addition to the LD_PRELOAD environment variable.
417
418 * The twalk_r function has been added.  It is similar to the existing
419   twalk function, but it passes an additional caller-supplied argument
420   to the callback function.
421
422 * On Linux, the getdents64, gettid, and tgkill functions have been added.
423
424 * Minguo (Republic of China) calendar support has been added as an
425   alternative calendar for the following locales: zh_TW, cmn_TW, hak_TW,
426   nan_TW, lzh_TW.
427
428 * The entry for the new Japanese era has been added for ja_JP locale.
429
430 * Memory allocation functions malloc, calloc, realloc, reallocarray, valloc,
431   pvalloc, memalign, and posix_memalign fail now with total object size
432   larger than PTRDIFF_MAX.  This is to avoid potential undefined behavior with
433   pointer subtraction within the allocated object, where results might
434   overflow the ptrdiff_t type.
435
436 * The dynamic linker no longer refuses to load objects which reference
437   versioned symbols whose implementation has moved to a different soname
438   since the object has been linked.  The old error message, symbol
439   FUNCTION-NAME, version SYMBOL-VERSION not defined in file DSO-NAME with
440   link time reference, is gone.
441
442 * Add new POSIX-proposed pthread_cond_clockwait, pthread_mutex_clocklock,
443   pthread_rwlock_clockrdlock, pthread_rwlock_clockwrlock and sem_clockwait
444   functions.  These behave similarly to their "timed" equivalents, but also
445   accept a clockid_t parameter to determine which clock their timeout should
446   be measured against.  All functions allow waiting against CLOCK_MONOTONIC
447   and CLOCK_REALTIME.  The decision of which clock to be used is made at the
448   time of the wait (unlike with pthread_condattr_setclock, which requires
449   the clock choice at initialization time).
450
451 * On AArch64 the GNU IFUNC resolver call ABI changed: old resolvers still
452   work, new resolvers can use a second argument which can be extended in
453   the future, currently it contains the AT_HWCAP2 value.
454
455 Deprecated and removed features, and other changes affecting compatibility:
456
457 * The copy_file_range function fails with ENOSYS if the kernel does not
458   support the system call of the same name.  Previously, user space
459   emulation was performed, but its behavior did not match the kernel
460   behavior, which was deemed too confusing.  Applications which use the
461   copy_file_range function can no longer rely on glibc to provide a fallback
462   on kernels that do not support the copy_file_range system call, and if
463   this function returns ENOSYS, they will need to use their own fallback.
464   Support for copy_file_range for most architectures was added in version
465   4.5 of the mainline Linux kernel.
466
467 * The functions clock_gettime, clock_getres, clock_settime,
468   clock_getcpuclockid, clock_nanosleep were removed from the librt library
469   for new applications (on architectures which had them).  Instead, the
470   definitions in libc will be used automatically, which have been available
471   since glibc 2.17.
472
473 * The obsolete and never-implemented XSI STREAMS header files <stropts.h>
474   and <sys/stropts.h> have been removed.
475
476 * Support for the "inet6" option in /etc/resolv.conf and the RES_USE_INET6
477   resolver flag (deprecated in glibc 2.25) have been removed.
478
479 * The obsolete RES_INSECURE1 and RES_INSECURE2 option flags for the DNS stub
480   resolver have been removed from <resolv.h>.
481
482 * With --enable-bind-now, installed programs are now linked with the
483   BIND_NOW flag.
484
485 * Support for the PowerPC SPE ISA extension (powerpc-*-*gnuspe*
486   configurations) has been removed, following the deprecation of this
487   subarchitecture in version 8 of GCC, and its removal in version 9.
488
489 * On 32-bit Arm, support for the port-based I/O emulation and the <sys/io.h>
490   header have been removed.
491
492 * The Linux-specific <sys/sysctl.h> header and the sysctl function have been
493   deprecated and will be removed from a future version of glibc.
494   Application should directly access /proc instead.  For obtaining random
495   bits, the getentropy function can be used.
496
497 Changes to build and runtime requirements:
498
499 * GCC 6.2 or later is required to build the GNU C Library.
500
501   Older GCC versions and non-GNU compilers are still supported when
502   compiling programs that use the GNU C Library.
503
504 Security related changes:
505
506   CVE-2019-7309: x86-64 memcmp used signed Jcc instructions to check
507   size.  For x86-64, memcmp on an object size larger than SSIZE_MAX
508   has undefined behavior.  On x32, the size_t argument may be passed
509   in the lower 32 bits of the 64-bit RDX register with non-zero upper
510   32 bits.  When it happened with the sign bit of RDX register set,
511   memcmp gave the wrong result since it treated the size argument as
512   zero.  Reported by H.J. Lu.
513
514   CVE-2019-9169: Attempted case-insensitive regular-expression match
515   via proceed_next_node in posix/regexec.c leads to heap-based buffer
516   over-read.  Reported by Hongxu Chen.
517
518 The following bugs are resolved with this release:
519
520   [2872] locale: Transliteration Cyrillic -> ASCII fails
521   [6399] libc: gettid() should have a wrapper
522   [16573] malloc: mtrace hangs when MALLOC_TRACE is defined
523   [16976] glob: fnmatch unbounded stack VLA for collating symbols
524   [17396] localedata: globbing for locale by [[.collating-element.]]
525   [18035] dynamic-link: pldd does no longer work, enters infinite loop
526   [18465] malloc: memusagestat is built using system C library
527   [18830] locale: iconv -c -f ascii with >buffer size worth of input before
528     invalid input drops valid char
529   [20188] nptl: libpthread IFUNC resolver for vfork can lead to crash
530   [20568] locale: Segfault with wide characters and setlocale/fgetwc/UTF-8
531   [21897] localedata: Afar locales: Fix mon, abmon, and abday
532   [22964] localedata: The Japanese Era name will be changed on May 1, 2019
533   [23352] malloc: __malloc_check_init still defined in public header
534     malloc.h.
535   [23403] nptl: Wrong alignment of TLS variables
536   [23501] libc: nftw() doesn't return dangling symlink's inode
537   [23733] malloc: Check the count before calling tcache_get()
538   [23741] malloc: Missing __attribute_alloc_size__ in many allocation
539     functions
540   [23831] localedata: nl_NL missing LC_NUMERIC thousands_sep
541   [23844] nptl: pthread_rwlock_trywrlock results in hang
542   [23983] argparse: Missing compat versions of argp_failure and argp_error
543     for long double = double
544   [23984] libc: Missing compat versions of err.h and error.h functions for
545     long double = double
546   [23996] localedata: Dutch salutations
547   [24040] libc: riscv64: unterminated call chain in __thread_start
548   [24047] network: libresolv should use IP_RECVERR/IPV6_RECVERR to avoid
549     long timeouts
550   [24051] stdio: puts and putchar ouput to _IO_stdout instead of stdout
551   [24059] nss: nss_files: get_next_alias calls fgets_unlocked without
552     checking for NULL.
553   [24114] regex: regexec buffer read overrun in "grep -i
554     '\(\(\)*.\)*\(\)\(\)\1'"
555   [24122] libc: Segfaults if 0 returned from la_version
556   [24153] stdio: Some input functions do not react to stdin assignment
557   [24155] string: x32 memcmp can treat positive length as 0 (if sign bit in
558     RDX is set) (CVE-2019-7309)
559   [24161] nptl: __run_fork_handlers self-deadlocks in malloc/tst-mallocfork2
560   [24164] libc: Systemtap probes need to use "nr" constraint on 32-bit Arm,
561     not the default "nor"
562   [24166] dynamic-link: Dl_serinfo.dls_serpath[1] in dlfcn.h causes UBSAN
563     false positives, change to modern flexible array
564   [24180] nptl: pthread_mutex_trylock does not use the correct order of
565     instructions while maintaining the robust mutex list due to missing
566     compiler barriers.
567   [24194] librt: Non-compatibility symbols for clock_gettime etc. cause
568     unnecessary librt dependencies
569   [24200] localedata: Revert first_weekday removal in en_IE locale
570   [24211] nptl: Use-after-free in Systemtap probe in pthread_join
571   [24215] nptl: pthread_timedjoin_np should be a cancellation point
572   [24216] malloc: Check for large bin list corruption when inserting
573     unsorted chunk
574   [24228] stdio: old x86 applications that use legacy libio crash on exit
575   [24231] dynamic-link: [sparc64] R_SPARC_H34 implementation falls through
576     to R_SPARC_H44
577   [24293] localedata: Missing Minguo calendar support for TW locales
578   [24296] localedata: Orthographic mistakes in 'day' and 'abday' sections in
579     tt_RU (Tatar) locale
580   [24307] localedata: Update locale data to Unicode 12.0.0
581   [24323] dynamic-link: dlopen should not be able open PIE objects
582   [24335] build: "Obsolete types detected" with Linux 5.0 headers
583   [24369] localedata: Orthographic mistakes in 'mon' and 'abmon' sections in
584     tt_RU (Tatar) locale
585   [24370] localedata: Add lang_name for tt_RU locale
586   [24372] locale: Binary locale files are not architecture independent
587   [24394] time: strptime %Ey mis-parses final year of era
588   [24476] dynamic-link: __libc_freeres triggers bad free in libdl if dlerror
589     was not used
590   [24506] dynamic-link: FAIL: elf/tst-pldd with --enable-hardcoded-path-in-
591     tests
592   [24531] malloc: Malloc tunables give tcache assertion failures
593   [24532] libc: conform/arpa/inet.h failures due to linux kernel 64-bit
594     time_t changes
595   [24535] localedata: Update locale data to Unicode 12.1.0
596   [24537] build: nptl/tst-eintr1 test case can hit task limits on some
597     kernels and break testing
598   [24544] build: elf/tst-pldd doesn't work if you install with a --prefix
599   [24556] build: [GCC 9] error: ‘%s’ directive argument is null
600     [-Werror=format-overflow=]
601   [24570] libc: alpha: compat msgctl uses __IPC_64
602   [24584] locale: Data race in __wcsmbs_clone_conv
603   [24588] stdio: Remove codecvt vtables from libio
604   [24603] math: sysdeps/ieee754/dbl-64/branred.c is slow when compiled with
605     -O3 -march=skylake
606   [24614] localedata: nl_NL LC_MONETARY doesn't match CLDR 35
607   [24632] stdio: Old binaries which use freopen with default stdio handles
608     crash
609   [24640] libc: __ppc_get_timebase_freq() always return 0 when using static
610     linked glibc
611   [24652] localedata: szl_PL spelling correction
612   [24695] nss: nss_db: calling getpwent after endpwent crashes
613   [24696] nss: endgrent() clobbers errno=ERRNO for 'group: db files' entry
614     in /etc/nsswitch.conf
615   [24699] libc: mmap64 with very large offset broken on MIPS64 n32
616   [24740] libc: getdents64 type confusion
617   [24741] dynamic-link: ld.so should not require that a versioned symbol is
618     always implemented in the same library
619   [24744] libc: Remove copy_file_range emulation
620   [24757] malloc: memusagestat is linked against system libpthread
621   [24794] libc: Partial test suite run builds corrupt test-in-container
622     testroot
623
624 \f
625 Version 2.29
626
627 Major new features:
628
629 * The getcpu wrapper function has been added, which returns the currently
630   used CPU and NUMA node.  This function is Linux-specific.
631
632 * A new convenience target has been added for distribution maintainers
633   to build and install all locales as directories with files.  The new
634   target is run by issuing the following command in your build tree:
635   'make localedata/install-locale-files', with an optional DESTDIR
636   to set the install root if you wish to install into a non-default
637   configured location.
638
639 * Optimized generic exp, exp2, log, log2, pow, sinf, cosf, sincosf and tanf.
640
641 * The reallocarray function is now declared under _DEFAULT_SOURCE, not just
642   for _GNU_SOURCE, to match BSD environments.
643
644 * For powercp64le ABI, Transactional Lock Elision is now enabled iff kernel
645   indicates that it will abort the transaction prior to entering the kernel
646   (PPC_FEATURE2_HTM_NOSC on hwcap2).  On older kernels the transaction is
647   suspended, and this caused some undefined side-effects issues by aborting
648   transactions manually.  Glibc avoided it by abort transactions manually on
649   each syscall, but it lead to performance issues on newer kernels where the
650   HTM state is saved and restore lazily (the state being saved even when the
651   process actually does not use HTM).
652
653 * The functions posix_spawn_file_actions_addchdir_np and
654   posix_spawn_file_actions_addfchdir_np have been added, enabling
655   posix_spawn and posix_spawnp to run the new process in a different
656   directory.  These functions are GNU extensions.  The function
657   posix_spawn_file_actions_addchdir_np is similar to the Solaris function
658   of the same name.
659
660 * The popen and system do not run atfork handlers anymore (BZ#17490).
661   Although it is a possible POSIX violation, the POSIX rationale in
662   pthread_atfork documentation regarding atfork handlers is to handle
663   inconsistent mutex state after a fork call in a multi-threaded process.
664   In both popen and system there is no direct access to user-defined mutexes.
665
666 * Support for the C-SKY ABIV2 running on Linux has been added.  This port
667   requires at least binutils-2.32, gcc-9.0, and linux-4.20.  Two ABIs are
668   supported:
669     - C-SKY ABIV2 soft-float little-endian
670     - C-SKY ABIV2 hard-float little-endian
671
672 * strftime's default formatting of a locale's alternative year (%Ey)
673   has been changed to zero-pad the year to a minimum of two digits,
674   like "%y".  This improves the display of Japanese era years during
675   the first nine years of a new era, and is expected to be harmless
676   for all other locales (only Japanese locales regularly have
677   alternative year numbers less than 10).  Zero-padding can be
678   overridden with the '_' or '-' flags (which are GNU extensions).
679
680 * As a GNU extension, the '_' and '-' flags can now be applied to
681   "%EY" to control how the year number is formatted; they have the
682   same effect that they would on "%Ey".
683
684 Deprecated and removed features, and other changes affecting compatibility:
685
686 * The glibc.tune tunable namespace has been renamed to glibc.cpu and the
687   tunable glibc.tune.cpu has been renamed to glibc.cpu.name.
688
689 * The type of the pr_uid and pr_gid members of struct elf_prpsinfo, defined
690   in <sys/procfs.h>, has been corrected to match the type actually used by
691   the Linux kernel.  This affects the size and layout of that structure on
692   MicroBlaze, MIPS (n64 ABI only), Nios II and RISC-V.
693
694 * For the MIPS n32 ABI, the type of the pr_sigpend and pr_sighold members of
695   struct elf_prstatus, and the pr_flag member of struct elf_prpsinfo,
696   defined in <sys/procfs.h>, has been corrected to match the type actually
697   used by the Linux kernel.  This affects the size and layout of those
698   structures.
699
700 * An archaic GNU extension to scanf, under which '%as', '%aS', and '%a[...]'
701   meant to scan a string and allocate space for it with malloc, is now
702   restricted to programs compiled in C89 or C++98 mode with _GNU_SOURCE
703   defined.  This extension conflicts with C99's use of '%a' to scan a
704   hexadecimal floating-point number, which is now available to programs
705   compiled as C99 or C++11 or higher, regardless of _GNU_SOURCE.
706
707   POSIX.1-2008 includes the feature of allocating a buffer for string input
708   with malloc, using the modifier letter 'm' instead.  Programs using
709   '%as', '%aS', or '%a[...]' with the old GNU meaning should change to
710   '%ms', '%mS', or '%m[...]' respectively.  Programs that wish to use the
711   C99 '%a' no longer need to avoid _GNU_SOURCE.
712
713   GCC's -Wformat warnings can detect most uses of this extension, as long
714   as all functions that call vscanf, vfscanf, or vsscanf are annotated with
715   __attribute__ ((format (scanf, ...))).
716
717 Changes to build and runtime requirements:
718
719 * Python 3.4 or later is required to build the GNU C Library.
720
721 * On most architectures, GCC 5 or later is required to build the GNU C
722   Library.  (On powerpc64le, GCC 6.2 or later is still required, as before.)
723
724   Older GCC versions and non-GNU compilers are still supported when
725   compiling programs that use the GNU C Library.
726
727 Security related changes:
728
729   CVE-2018-19591: A file descriptor leak in if_nametoindex can lead to a
730   denial of service due to resource exhaustion when processing getaddrinfo
731   calls with crafted host names.  Reported by Guido Vranken.
732
733   CVE-2019-6488: On x32, the size_t parameter may be passed in the lower
734   32 bits of a 64-bit register with with non-zero upper 32 bit.  When it
735   happened, accessing the 32-bit size_t value as the full 64-bit register
736   in the assembly string/memory functions would cause a buffer overflow.
737   Reported by H.J. Lu.
738
739   CVE-2016-10739: The getaddrinfo function could successfully parse IPv4
740   addresses with arbitrary trailing characters, potentially leading to data
741   or command injection issues in applications.
742
743 The following bugs are resolved with this release:
744
745   [10425] localedata: it_IT/it_CH: LC_TIME format is wrong
746   [10496] localedata: 12h time representation in multiple locales faulty
747   [10797] localedata: it_IT locale numeric does not have a separator for
748     thousands
749   [11319] libc: dprintf doesn't handle errors properly
750   [16346] time: mktime: potentially unsafe use of localtime_offset
751   [17248] build: glibc should not sort CFLAGS (support gcc plugins and
752     --param options)
753   [17405] libc: Implement posix_spawn_file_actions_addchdir_np,
754     posix_spawn_file_actions_addfchdir_np
755   [17426] localedata: Indian locales: set the correct date format
756   [17490] stdio: popen should not invoke atfork handlers
757   [17783] libc: TIOCSER_TEMT conditions inconsistent
758   [18040] regex: use-after-free in regexec/get_subexp
759   [18093] libc: Corrupted aux-cache causes ldconfig to segfault
760   [20018] network: getaddrinfo should reject IP addresses with trailing
761     characters (CVE-2016-10739)
762   [20209] localedata: Spelling mistake for Sunday in Greenlandic kl_GL
763   [20271] libc: Missing "\n" in __libc_fatal calls
764   [20480] dynamic-link: Patch: ifunc not executable, crashes sudo qemu
765   [20544] libc: RFE: atexit, __cxa_atexit, on_exit should assert function
766     pointer argument is non-NULL
767   [21037] stdio: open_memstream and freopen
768   [21286] libc: bits/siginfo.h  is missing enum definition for TRAP_HWBKPT
769   [21716] time: Crash in glibc's mktime in low-memory situations
770   [22834] stdio: Subprocess forked by popen may crash in Linux when
771     multithreads call popen
772   [22927] network: crash in vn_gai_enqueue_request if requests_tail was NULL
773     and pthread_create fails.
774   [23032] hurd: sysdeps/htl/pt-barrier-init.c:39: bad call to memcmp ?
775   [23125] libc: riscv64: endless loop when throwing an exception from a
776     constructor
777   [23275] nptl: Race in pthread_mutex_lock while promoting to
778     PTHREAD_MUTEX_ELISION_NP.
779   [23400] libc: stdlib/test-bz22786.c creates temporary files in glibc
780     source tree
781   [23479] math: [mips] bits/fenv.h should not define some macros for soft-
782     float
783   [23490] libc: sysdeps/unix/sysv/linux/x86/tst-cet-property-2.c:49: off by
784     one error
785   [23497] libc: readdir64@GLIBC_2.1 cannot parse the kernel directory stream
786   [23509] dynamic-link: CET enabled glibc is incompatible with the older
787     linker
788   [23520] nscd: nscd: Use-after-free in addgetnetgrentX and its callers
789   [23521] nss: get_next_alias nss_files file stream leak
790   [23538] nptl: Hang in pthread_cond_broadcast
791   [23562] libc: Wrong type for si_band in Linux-specific siginfo_t
792   [23578] regex: Invalid memory access if regex pattern contains NUL byte
793   [23579] libc: Errors misreported in preadv2
794   [23597] build: support/test-container.c doesn't work with different
795     filesystems
796   [23603] time: mktime signed integer overflow on large timestamps
797   [23606] libc: Missing ENDBR32 in sysdeps/i386/start.S
798   [23614] libc: powerpc: missing CFI register information in __mpn_*
799     functions
800   [23637] string: Generic strstr/strcasestr fails with huge needles
801   [23640] libc: no way to easily clear FD_CLOEXEC in
802     posix_spawn_file_actions_adddup2()
803   [23649] libc: [microblaze/mips/nios2/riscv] sys/procfs.h pr_uid, pr_gid
804     have wrong type
805   [23656] libc: [mips n32] sys/procfs.h pr_sigpend, pr_sighold, pr_flag have
806     wrong type
807   [23679] libc: gethostid: Missing NULL check for gethostbyname_r result
808   [23689] libc: Bug in documentation for rusage.ru_ixrss in
809     bits/types/struct_rusage.h
810   [23690] dynamic-link: Segfault in _dl_profile_fixup with a high number of
811     threads
812   [23707] dynamic-link: Missing unwind info in sysdeps/powerpc/powerpc32/dl-
813     start.S
814   [23709] string: glibc 2.25 lacks sse2 optimized strstr()
815   [23716] dynamic-link: _dl_runtime_resolve_shstk isn't selected properly
816   [23717] libc: glibc: stdlib/tst-setcontext9 test suite failure on
817     powerpc64le
818   [23724] localedata: Albanian date formats are incorrect
819   [23735] math: libnldbl_nonshared.a references internal libm symbols
820   [23740] localedata: kl_GL: Month names and date formats need update
821   [23744] regex: regex refactorings to remove BE, avoid duplication
822   [23745] time: mktime fix for Gnulib + coreutils
823   [23758] time: Improve the width of alternate representation for year in
824     strftime
825   [23783] libc: [mips] Missing CMSPAR bits/termios.h
826   [23789] time: mktime does not set errno on failure
827   [23791] localedata: Wrong monetary format for ca_ES locale
828   [23793] locale: c32rtomb and mbrtoc32 should not alias wcrtomb and mbrtowc
829   [23794] locale: c16rtomb does not handle surrogate pairs
830   [23821] libc: si_band in siginfo_t has wrong type long int on sparc64
831   [23822] math: ia64 static libm.a is missing exp2f, log2f and powf symbols
832   [23836] time: time/tst-mktime2 test failure on Arm (32-bit)
833   [23848] libc: [sparc] Some socket syscalls wrongly assumed to be present
834   [23861] nptl: rdlock stalls indefinitely on an unlocked pthread rwlock
835   [23862] libc: [sh] missing kernel-features.h undefines
836   [23864] libc: [riscv] missing kernel-features.h undefines
837   [23867] libc: [arm/microblaze] __ASSUME_MLOCK2 incorrect
838   [23907] malloc: Incorrect double-free malloc tcache check disregards
839     tcache size
840   [23913] libc: off-by-one in function maybe_script_execute in
841     sysdeps/posix/spawni.c
842   [23915] libc: [arm] __ASSUME_COPY_FILE_RANGE incorrect
843   [23923] locale: Add --no-hard-links option to localedef
844   [23927] network: Linux if_nametoindex() does not close descriptor
845     (CVE-2018-19591)
846   [23961] math: powf can overflow to inf without setting errno in non-
847     nearest rounding mode
848   [23967] libc: [2.28 Regression]: New sigaction implementation breaks m68k
849   [23972] libc: __old_getdents64 uses wrong d_off value on overflow
850   [23993] libc: glibc 2.29 doesn't build with gcc 4.9
851   [23995] localedata: Remove execution flags from localedata/locales/bi_VU
852   [24011] localedata: Fixed small type in comment for locale bs_BA
853   [24018] libc: gettext() may return NULL
854   [24022] build: riscv build failure with Linux kernel 4.20-rc7
855   [24023] build: [2.29 Regression] FAIL: elf/check-localplt
856   [24024] string: strerror() might set errno to ENOMEM due to -fno-math-
857     error
858   [24027] malloc: glibc: realloc() ncopies 32-bit integer overflow
859   [24034] libc: tst-cancel21-static fails with SIGBUS on pre-ARMv7 when
860     using GCC 8
861   [24046] localedata: en_US locale doesn't define date_fmt
862   [24063] manual: @var{errno} should be @code{errno}
863   [24066] soft-fp: Inconsistent _FP_W_TYPE_SIZE check
864   [24088] libc: VSCR field is not being correctly read in ucontext_t on
865     ppc64le
866   [24096] time: Specifying '_' or '-' flag for "%EY" does not produce the
867     expected result
868   [24097] string: Can't use 64-bit register for size_t in assembly codes for
869     x32 (CVE-2019-6488)
870   [24110] hurd: SS_DISABLE never set in stack_t value returned by
871     sigaltstack
872   [24112] network: Do not send DNS queries for non-host names (where all
873     answers will be rejected)
874   [24130] libc: alpha __remqu corrupts $f3 register
875
876 \f
877 Version 2.28
878
879 Major new features:
880
881 * The localization data for ISO 14651 is updated to match the 2016
882   Edition 4 release of the standard, this matches data provided by
883   Unicode 9.0.0.  This update introduces significant improvements to the
884   collation of Unicode characters.  This release deviates slightly from
885   the standard in that the collation element ordering for lowercase and
886   uppercase LATIN script characters is adjusted to ensure that regular
887   expressions with ranges like [a-z] and [A-Z] don't interleave e.g. A
888   is not matched by [a-z].  With the update many locales have been
889   updated to take advantage of the new collation information.  The new
890   collation information has increased the size of the compiled locale
891   archive or binary locales.
892
893 * The GNU C Library can now be compiled with support for Intel CET, AKA
894   Intel Control-flow Enforcement Technology.  When the library is built
895   with --enable-cet, the resulting glibc is protected with indirect
896   branch tracking (IBT) and shadow stack (SHSTK).  CET-enabled glibc is
897   compatible with all existing executables and shared libraries.  This
898   feature is currently supported on i386, x86_64 and x32 with GCC 8 and
899   binutils 2.29 or later.  Note that CET-enabled glibc requires CPUs
900   capable of multi-byte NOPs, like x86-64 processors as well as Intel
901   Pentium Pro or newer.  NOTE: --enable-cet has been tested for i686,
902   x86_64 and x32 on non-CET processors.  --enable-cet has been tested
903   for x86_64 and x32 on CET SDVs, but Intel CET support hasn't been
904   validated for i686.
905
906 * The GNU C Library now has correct support for ABSOLUTE symbols
907   (SHN_ABS-relative symbols).  Previously such ABSOLUTE symbols were
908   relocated incorrectly or in some cases discarded.  The GNU linker can
909   make use of the newer semantics, but it must communicate it to the
910   dynamic loader by setting the ELF file's identification (EI_ABIVERSION
911   field) to indicate such support is required.
912
913 * Unicode 11.0.0 Support: Character encoding, character type info, and
914   transliteration tables are all updated to Unicode 11.0.0, using
915   generator scripts contributed by Mike FABIAN (Red Hat).
916
917 * <math.h> functions that round their results to a narrower type are added
918   from TS 18661-1:2014 and TS 18661-3:2015:
919
920   - fadd, faddl, daddl and corresponding fMaddfN, fMaddfNx, fMxaddfN and
921     fMxaddfNx functions.
922
923   - fsub, fsubl, dsubl and corresponding fMsubfN, fMsubfNx, fMxsubfN and
924     fMxsubfNx functions.
925
926   - fmul, fmull, dmull and corresponding fMmulfN, fMmulfNx, fMxmulfN and
927     fMxmulfNx functions.
928
929   - fdiv, fdivl, ddivl and corresponding fMdivfN, fMdivfNx, fMxdivfN and
930     fMxdivfNx functions.
931
932 * Two grammatical forms of month names are now supported for the following
933   languages: Armenian, Asturian, Catalan, Czech, Kashubian, Occitan, Ossetian,
934   Scottish Gaelic, Upper Sorbian, and Walloon.  The following languages now
935   support two grammatical forms in abbreviated month names: Catalan, Greek,
936   and Kashubian.
937
938 * Newly added locales: Lower Sorbian (dsb_DE) and Yakut (sah_RU) also
939   include the support for two grammatical forms of month names.
940
941 * Building and running on GNU/Hurd systems now works without out-of-tree
942   patches.
943
944 * The renameat2 function has been added, a variant of the renameat function
945   which has a flags argument.  If the flags are zero, the renameat2 function
946   acts like renameat.  If the flag is not zero and there is no kernel
947   support for renameat2, the function will fail with an errno value of
948   EINVAL.  This is different from the existing gnulib function renameatu,
949   which performs a plain rename operation in case of a RENAME_NOREPLACE
950   flags and a non-existing destination (and therefore has a race condition
951   that can clobber the destination inadvertently).
952
953 * The statx function has been added, a variant of the fstatat64
954   function with an additional flags argument.  If there is no direct
955   kernel support for statx, glibc provides basic stat support based on
956   the fstatat64 function.
957
958 * IDN domain names in getaddrinfo and getnameinfo now use the system libidn2
959   library if installed.  libidn2 version 2.0.5 or later is recommended.  If
960   libidn2 is not available, internationalized domain names are not encoded
961   or decoded even if the AI_IDN or NI_IDN flags are passed to getaddrinfo or
962   getnameinfo.  (getaddrinfo calls with non-ASCII names and AI_IDN will fail
963   with an encoding error.)  Flags which used to change the IDN encoding and
964   decoding behavior (AI_IDN_ALLOW_UNASSIGNED, AI_IDN_USE_STD3_ASCII_RULES,
965   NI_IDN_ALLOW_UNASSIGNED, NI_IDN_USE_STD3_ASCII_RULES) have been
966   deprecated.  They no longer have any effect.
967
968 * Parsing of dynamic string tokens in DT_RPATH, DT_RUNPATH, DT_NEEDED,
969   DT_AUXILIARY, and DT_FILTER has been expanded to support the full
970   range of ELF gABI expressions including such constructs as
971   '$ORIGIN$ORIGIN' (if valid).  For SUID/GUID applications the rules
972   have been further restricted, and where in the past a dynamic string
973   token sequence may have been interpreted as a literal string it will
974   now cause a load failure.  These load failures were always considered
975   unspecified behaviour from the perspective of the dynamic loader, and
976   for safety are now load errors e.g. /foo/${ORIGIN}.so in DT_NEEDED
977   results in a load failure now.
978
979 * Support for ISO C threads (ISO/IEC 9899:2011) has been added.  The
980   implementation includes all the standard functions provided by
981   <threads.h>:
982
983   - thrd_current, thrd_equal, thrd_sleep, thrd_yield, thrd_create,
984     thrd_detach, thrd_exit, and thrd_join for thread management.
985
986   - mtx_init, mtx_lock, mtx_timedlock, mtx_trylock, mtx_unlock, and
987     mtx_destroy for mutual exclusion.
988
989   - call_once for function call synchronization.
990
991   - cnd_broadcast, cnd_destroy, cnd_init, cnd_signal, cnd_timedwait, and
992     cnd_wait for conditional variables.
993
994   - tss_create, tss_delete, tss_get, and tss_set for thread-local storage.
995
996   Application developers must link against libpthread to use ISO C threads.
997
998 Deprecated and removed features, and other changes affecting compatibility:
999
1000 * The nonstandard header files <libio.h> and <_G_config.h> are no longer
1001   installed.  Software that was using either header should be updated to
1002   use standard <stdio.h> interfaces instead.
1003
1004 * The stdio functions 'getc' and 'putc' are no longer defined as macros.
1005   This was never required by the C standard, and the macros just expanded
1006   to call alternative names for the same functions.  If you hoped getc and
1007   putc would provide performance improvements over fgetc and fputc, instead
1008   investigate using (f)getc_unlocked and (f)putc_unlocked, and, if
1009   necessary, flockfile and funlockfile.
1010
1011 * All stdio functions now treat end-of-file as a sticky condition.  If you
1012   read from a file until EOF, and then the file is enlarged by another
1013   process, you must call clearerr or another function with the same effect
1014   (e.g. fseek, rewind) before you can read the additional data.  This
1015   corrects a longstanding C99 conformance bug.  It is most likely to affect
1016   programs that use stdio to read interactive input from a terminal.
1017   (Bug #1190.)
1018
1019 * The macros 'major', 'minor', and 'makedev' are now only available from
1020   the header <sys/sysmacros.h>; not from <sys/types.h> or various other
1021   headers that happen to include <sys/types.h>.  These macros are rarely
1022   used, not part of POSIX nor XSI, and their names frequently collide with
1023   user code; see https://sourceware.org/bugzilla/show_bug.cgi?id=19239 for
1024   further explanation.
1025
1026   <sys/sysmacros.h> is a GNU extension.  Portable programs that require
1027   these macros should first include <sys/types.h>, and then include
1028   <sys/sysmacros.h> if __GNU_LIBRARY__ is defined.
1029
1030 * The tilegx*-*-linux-gnu configurations are no longer supported.
1031
1032 * The obsolete function ustat is no longer available to newly linked
1033   binaries; the headers <ustat.h> and <sys/ustat.h> have been removed.  This
1034   function has been deprecated in favor of fstatfs and statfs.
1035
1036 * The obsolete function nfsservctl is no longer available to newly linked
1037   binaries.  This function was specific to systems using the Linux kernel
1038   and could not usefully be used with the GNU C Library on systems with
1039   version 3.1 or later of the Linux kernel.
1040
1041 * The obsolete function name llseek is no longer available to newly linked
1042   binaries.  This function was specific to systems using the Linux kernel
1043   and was not declared in a header.  Programs should use the lseek64 name
1044   for this function instead.
1045
1046 * The AI_IDN_ALLOW_UNASSIGNED and NI_IDN_ALLOW_UNASSIGNED flags for the
1047   getaddrinfo and getnameinfo functions have been deprecated.  The behavior
1048   previously selected by them is now always enabled.
1049
1050 * The AI_IDN_USE_STD3_ASCII_RULES and NI_IDN_USE_STD3_ASCII_RULES flags for
1051   the getaddrinfo and getnameinfo functions have been deprecated.  The STD3
1052   restriction (rejecting '_' in host names, among other things) has been
1053   removed, for increased compatibility with non-IDN name resolution.
1054
1055 * The fcntl function now have a Long File Support variant named fcntl64.  It
1056   is added to fix some Linux Open File Description (OFD) locks usage on non
1057   LFS mode.  As for others *64 functions, fcntl64 semantics are analogous with
1058   fcntl and LFS support is handled transparently.  Also for Linux, the OFD
1059   locks act as a cancellation entrypoint.
1060
1061 * The obsolete functions encrypt, encrypt_r, setkey, setkey_r, cbc_crypt,
1062   ecb_crypt, and des_setparity are no longer available to newly linked
1063   binaries, and the headers <rpc/des_crypt.h> and <rpc/rpc_des.h> are no
1064   longer installed.  These functions encrypted and decrypted data with the
1065   DES block cipher, which is no longer considered secure.  Software that
1066   still uses these functions should switch to a modern cryptography library,
1067   such as libgcrypt.
1068
1069 * Reflecting the removal of the encrypt and setkey functions above, the
1070   macro _XOPEN_CRYPT is no longer defined.  As a consequence, the crypt
1071   function is no longer declared unless _DEFAULT_SOURCE or _GNU_SOURCE is
1072   enabled.
1073
1074 * The obsolete function fcrypt is no longer available to newly linked
1075   binaries.  It was just another name for the standard function crypt,
1076   and it has not appeared in any header file in many years.
1077
1078 * We have tentative plans to hand off maintenance of the passphrase-hashing
1079   library, libcrypt, to a separate development project that will, we hope,
1080   keep up better with new passphrase-hashing algorithms.  We will continue
1081   to declare 'crypt' in <unistd.h>, and programs that use 'crypt' or
1082   'crypt_r' should not need to change at all; however, distributions will
1083   need to install <crypt.h> and libcrypt from a separate project.
1084
1085   In this release, if the configure option --disable-crypt is used, glibc
1086   will not install <crypt.h> or libcrypt, making room for the separate
1087   project's versions of these files.  The plan is to make this the default
1088   behavior in a future release.
1089
1090 Changes to build and runtime requirements:
1091
1092   GNU make 4.0 or later is now required to build glibc.
1093
1094 Security related changes:
1095
1096   CVE-2016-6261, CVE-2016-6263, CVE-2017-14062: Various vulnerabilities have
1097   been fixed by removing the glibc-internal IDNA implementation and using
1098   the system-provided libidn2 library instead.  Originally reported by Hanno
1099   Böck and Christian Weisgerber.
1100
1101   CVE-2017-18269: An SSE2-based memmove implementation for the i386
1102   architecture could corrupt memory.  Reported by Max Horn.
1103
1104   CVE-2018-11236: Very long pathname arguments to realpath function could
1105   result in an integer overflow and buffer overflow.  Reported by Alexey
1106   Izbyshev.
1107
1108   CVE-2018-11237: The mempcpy implementation for the Intel Xeon Phi
1109   architecture could write beyond the target buffer, resulting in a buffer
1110   overflow.  Reported by Andreas Schwab.
1111
1112 The following bugs are resolved with this release:
1113
1114   [1190] stdio: fgetc()/fread() behaviour is not POSIX compliant
1115   [6889] manual: 'PWD' mentioned but not specified
1116   [13575] libc: SSIZE_MAX defined as LONG_MAX is inconsistent with ssize_t,
1117     when __WORDSIZE != 64
1118   [13762] regex: re_search etc. should return -2 on memory exhaustion
1119   [13888] build: /tmp usage during testing
1120   [13932] math: dbl-64 pow unexpectedly slow for some inputs
1121   [14092] nptl: Support C11 threads
1122   [14095] localedata: Review / update collation data from Unicode / ISO
1123     14651
1124   [14508] libc: -Wformat warnings
1125   [14553] libc: Namespace pollution loff_t in sys/types.h
1126   [14890] libc: Make NT_PRFPREG canonical.
1127   [15105] libc: Extra PLT references with -Os
1128   [15512] libc: __bswap_constant_16 not compiled when -Werror -Wsign-
1129     conversion is given
1130   [16335] manual: Feature test macro documentation incomplete and out of
1131     date
1132   [16552] libc: Unify umount implementations in terms of umount2
1133   [17082] libc: htons et al.: statement-expressions prevent use on global
1134     scope with -O1 and higher
1135   [17343] libc: Signed integer overflow in /stdlib/random_r.c
1136   [17438] localedata: pt_BR: wrong d_fmt delimiter
1137   [17662] libc: please implement binding for the new renameat2 syscall
1138   [17721] libc: __restrict defined as /* Ignore */ even in c11
1139   [17979] libc: inconsistency between uchar.h and stdint.h
1140   [18018] dynamic-link: Additional $ORIGIN handling issues (CVE-2011-0536)
1141   [18023] libc: extend_alloca is broken (questionable pointer comparison,
1142     horrible machine code)
1143   [18124] libc: hppa: setcontext erroneously returns -1 as exit code for
1144     last constant.
1145   [18471] libc: llseek should be a compat symbol
1146   [18473] soft-fp: [powerpc-nofpu] __sqrtsf2, __sqrtdf2 should be compat
1147     symbols
1148   [18991] nss: nss_files skips large entry in database
1149   [19239] libc: Including stdlib.h ends up with macros major and minor being
1150     defined
1151   [19463] libc: linknamespace failures when compiled with -Os
1152   [19485] localedata: csb_PL: Update month translations + add yesstr/nostr
1153   [19527] locale: Normalized charset name not recognized by setlocale
1154   [19667] string: Missing Sanity Check for malloc calls in file 'testcopy.c'
1155   [19668] libc: Missing Sanity Check for malloc() in file 'tst-setcontext-
1156     fpscr.c'
1157   [19728] network: out of bounds stack read in libidn function
1158     idna_to_ascii_4i (CVE-2016-6261)
1159   [19729] network: out of bounds heap read on invalid utf-8 inputs in
1160     stringprep_utf8_nfkc_normalize (CVE-2016-6263)
1161   [19818] dynamic-link: Absolute (SHN_ABS) symbols incorrectly relocated by
1162     the base address
1163   [20079] libc: Add SHT_X86_64_UNWIND to elf.h
1164   [20251] libc: 32bit programs pass garbage in struct flock for OFD locks
1165   [20419] dynamic-link: files with large allocated notes crash in
1166     open_verify
1167   [20530] libc: bswap_16 should use __builtin_bswap16() when available
1168   [20890] dynamic-link: ldconfig: fsync the files before atomic rename
1169   [20980] manual: CFLAGS environment variable replaces vital options
1170   [21163] regex: Assertion failure in pop_fail_stack when executing a
1171     malformed regexp (CVE-2015-8985)
1172   [21234] manual: use of CFLAGS makes glibc detect no optimization
1173   [21269] dynamic-link: i386 sigaction sa_restorer handling is wrong
1174   [21313] build: Compile Error GCC 5.4.0 MIPS with -0S
1175   [21314] build: Compile Error GCC 5.2.0 MIPS with -0s
1176   [21508] locale: intl/tst-gettext failure with latest msgfmt
1177   [21547] localedata: Tibetan script collation broken (Dzongkha and Tibetan)
1178   [21812] network: getifaddrs() returns entries with ifa_name == NULL
1179   [21895] libc: ppc64 setjmp/longjmp not fully interoperable with static
1180     dlopen
1181   [21942] dynamic-link: _dl_dst_substitute incorrectly handles $ORIGIN: with
1182     AT_SECURE=1
1183   [22241] localedata: New locale: Yakut (Sakha) locale for Russia (sah_RU)
1184   [22247] network: Integer overflow in the decode_digit function in
1185     puny_decode.c in libidn (CVE-2017-14062)
1186   [22342] nscd: NSCD not properly caching netgroup
1187   [22391] nptl: Signal function clear NPTL internal symbols inconsistently
1188   [22550] localedata: es_ES locale (and  other es_* locales):  collation
1189     should treat ñ  as a primary different character,  sync the collation
1190     for Spanish with CLDR
1191   [22638] dynamic-link: sparc: static binaries are broken if glibc is built
1192     by gcc configured with --enable-default-pie
1193   [22639] time: year 2039 bug for localtime etc. on 64-bit platforms
1194   [22644] string: memmove-sse2-unaligned on 32bit x86 produces garbage when
1195     crossing 2GB threshold (CVE-2017-18269)
1196   [22646] localedata: redundant data (LC_TIME) for es_CL, es_CU, es_EC and
1197     es_BO
1198   [22735] time: Misleading typo in time.h source comment regarding
1199     CLOCKS_PER_SECOND
1200   [22753] libc: preadv2/pwritev2 fallback code should handle offset=-1
1201   [22761] libc: No trailing `%n' conversion specifier in FMT passed from
1202     `__assert_perror_fail ()' to `__assert_fail_base ()'
1203   [22766] libc: all glibc internal dlopen should use RTLD_NOW for robust
1204     dlopen failures
1205   [22786] libc: Stack buffer overflow in realpath() if input size is close
1206     to SSIZE_MAX (CVE-2018-11236)
1207   [22787] dynamic-link: _dl_check_caller returns false when libc is linked
1208     through an absolute DT_NEEDED path
1209   [22792] build: tcb-offsets.h dependency dropped
1210   [22797] libc: pkey_get() uses non-reserved name of argument
1211   [22807] libc: PTRACE_* constants missing for powerpc
1212   [22818] glob: posix/tst-glob_lstat_compat failure on alpha
1213   [22827] dynamic-link: RISC-V ELF64 parser mis-reads flag in ldconfig
1214   [22830] malloc: malloc_stats doesn't restore cancellation state on stderr
1215   [22848] localedata: ca_ES: update date definitions from CLDR
1216   [22862] build: _DEFAULT_SOURCE is defined even when _ISOC11_SOURCE is
1217   [22884] math: RISCV fmax/fmin handle signalling NANs incorrectly
1218   [22896] localedata: Update locale data for an_ES
1219   [22902] math: float128 test failures with GCC 8
1220   [22918] libc: multiple common of `__nss_shadow_database'
1221   [22919] libc: sparc32: backtrace yields infinite backtrace with
1222     makecontext
1223   [22926] libc: FTBFS on powerpcspe
1224   [22932] localedata: lt_LT: Update of abbreviated month names from CLDR
1225     required
1226   [22937] localedata: Greek (el_GR, el_CY) locales actually need ab_alt_mon
1227   [22947] libc: FAIL: misc/tst-preadvwritev2
1228   [22963] localedata: cs_CZ: Add alternative month names
1229   [22987] math: [powerpc/sparc] fdim inlines errno, exceptions handling
1230   [22996] localedata: change LC_PAPER to en_US in es_BO locale
1231   [22998] dynamic-link: execstack tests are disabled when SELinux is
1232     disabled
1233   [23005] network: Crash in __res_context_send after memory allocation
1234     failure
1235   [23007] math: strtod cannot handle -nan
1236   [23024] nss: getlogin_r is performing NSS lookups when loginid isn't set
1237   [23036] regex: regex equivalence class regression
1238   [23037] libc: initialize msg_flags to zero for sendmmsg() calls
1239   [23069] libc: sigaction broken on riscv64-linux-gnu
1240   [23094] localedata: hr_HR: wrong thousands_sep and mon_thousands_sep
1241   [23102] dynamic-link: Incorrect parsing of multiple consecutive $variable
1242     patterns in runpath entries (e.g. $ORIGIN$ORIGIN)
1243   [23137] nptl: s390: pthread_join sometimes block indefinitely (on 31bit
1244     and libc build with -Os)
1245   [23140] localedata: More languages need two forms of month names
1246   [23145] libc: _init/_fini aren't marked as hidden
1247   [23152] localedata: gd_GB: Fix typo in "May" (abbreviated)
1248   [23171] math: C++ iseqsig for long double converts arguments to double
1249   [23178] nscd: sudo will fail when it is run in concurrent with commands
1250     that changes /etc/passwd
1251   [23196] string: __mempcpy_avx512_no_vzeroupper mishandles large copies
1252     (CVE-2018-11237)
1253   [23206] dynamic-link: static-pie + dlopen breaks debugger interaction
1254   [23208] localedata: New locale - Lower Sorbian (dsb)
1255   [23233] regex: Memory leak in build_charclass_op function in file
1256     posix/regcomp.c
1257   [23236] stdio: Harden function pointers in _IO_str_fields
1258   [23250] nptl: Offset of __private_ss differs from GCC
1259   [23253] math: tgamma test suite failures on i686 with -march=x86-64
1260     -mtune=generic -mfpmath=sse
1261   [23259] dynamic-link: Unsubstituted ${ORIGIN} remains in DT_NEEDED for
1262     AT_SECURE
1263   [23264] libc: posix_spawnp wrongly executes ENOEXEC in non compat mode
1264   [23266] nis: stringop-truncation warning with new gcc8.1 in nisplus-
1265     parser.c
1266   [23272] math: fma(INFINITY,INFIITY,0.0) should be INFINITY
1267   [23277] math: nan function should not have const attribute
1268   [23279] math: scanf and strtod wrong for some hex floating-point
1269   [23280] math: wscanf rounds wrong; wcstod is ok for negative numbers and
1270     directed rounding
1271   [23290] localedata: IBM273 is not equivalent to ISO-8859-1
1272   [23303] build: undefined reference to symbol
1273     '__parse_hwcap_and_convert_at_platform@@GLIBC_2.23'
1274   [23307] dynamic-link: Absolute symbols whose value is zero ignored in
1275     lookup
1276   [23313] stdio: libio vtables validation and standard file object
1277     interposition
1278   [23329] libc: The __libc_freeres infrastructure is not properly run across
1279     DSO boundaries.
1280   [23349] libc: Various glibc headers no longer compatible with
1281     <linux/time.h>
1282   [23351] malloc: Remove unused code related to heap dumps and malloc
1283     checking
1284   [23363] stdio: stdio-common/tst-printf.c has non-free license
1285   [23396] regex: Regex equivalence regression in single-byte locales
1286   [23422] localedata: oc_FR: More updates of locale data
1287   [23442] build: New warning with GCC 8
1288   [23448] libc: Out of bounds access in IBM-1390 converter
1289   [23456] libc: Wrong index_cpu_LZCNT
1290   [23458] build: tst-get-cpu-features-static isn't added to tests
1291   [23459] libc: COMMON_CPUID_INDEX_80000001 isn't populated for Intel
1292     processors
1293   [23467] dynamic-link: x86/CET: A property note parser bug
1294
1295 \f
1296 Version 2.27
1297
1298 Major new features:
1299
1300 * The GNU C Library can now be compiled with support for building static
1301   PIE executables (See --enable-static-pie in INSTALL).  These static PIE
1302   executables are like static executables but can be loaded at any address
1303   and provide additional security hardening benefits at the cost of some
1304   memory and performance.  When the library is built with --enable-static-pie
1305   the resulting libc.a is usable with GCC 8 and above to create static PIE
1306   executables using the GCC option '-static-pie'.  This feature is currently
1307   supported on i386, x86_64 and x32 with binutils 2.29 or later, and on
1308   aarch64 with binutils 2.30 or later.
1309
1310 * Optimized x86-64 asin, atan2, exp, expf, log, pow, atan, sin, cosf,
1311   sinf, sincosf and tan with FMA, contributed by Arjan van de Ven and
1312   H.J. Lu from Intel.
1313
1314 * Optimized x86-64 trunc and truncf for processors with SSE4.1.
1315
1316 * Optimized generic expf, exp2f, logf, log2f, powf, sinf, cosf and sincosf.
1317
1318 * In order to support faster and safer process termination the malloc API
1319   family of functions will no longer print a failure address and stack
1320   backtrace after detecting heap corruption.  The goal is to minimize the
1321   amount of work done after corruption is detected and to avoid potential
1322   security issues in continued process execution.  Reducing shutdown time
1323   leads to lower overall process restart latency, so there is benefit both
1324   from a security and performance perspective.
1325
1326 * The abort function terminates the process immediately, without flushing
1327   stdio streams.  Previous glibc versions used to flush streams, resulting
1328   in deadlocks and further data corruption.  This change also affects
1329   process aborts as the result of assertion failures.
1330
1331 * On platforms where long double has the IEEE binary128 format (aarch64,
1332   alpha, mips64, riscv, s390 and sparc), the math library now implements
1333   _Float128 interfaces for that type, as defined by ISO/IEC TS 18661-3:2015.
1334   These are the same interfaces added in version 2.26 for some platforms where
1335   this format is supported but is not the format of long double.
1336
1337 * On platforms with support for _Float64x (aarch64, alpha, i386, ia64,
1338   mips64, powerpc64le, riscv, s390, sparc and x86_64), the math library now
1339   implements interfaces for that type, as defined by ISO/IEC TS
1340   18661-3:2015.  These are corresponding interfaces to those supported for
1341   _Float128.
1342
1343 * The math library now implements interfaces for the _Float32, _Float64 and
1344   _Float32x types, as defined by ISO/IEC TS 18661-3:2015.  These are
1345   corresponding interfaces to those supported for _Float128.
1346
1347 * glibc now implements the memfd_create and mlock2 functions on Linux.
1348
1349 * Support for memory protection keys was added.  The <sys/mman.h> header now
1350   declares the functions pkey_alloc, pkey_free, pkey_mprotect, pkey_set,
1351   pkey_get.
1352
1353 * The copy_file_range function was added.
1354
1355 * Optimized memcpy, mempcpy, memmove, and memset for sparc M7.
1356
1357 * The ldconfig utility now processes `include' directives using the C/POSIX
1358   collation ordering.  Previous glibc versions used locale-specific
1359   ordering, the change might break systems that relied on that.
1360
1361 * Support for two grammatical forms of month names has been added.
1362   In a call to strftime, the "%B" and "%b" format specifiers will now
1363   produce the grammatical form required when the month is used as part
1364   of a complete date.  New "%OB" and "%Ob" specifiers produce the form
1365   required when the month is named by itself.  For instance, in Greek
1366   and in many Slavic and Baltic languages, "%B" will produce the month
1367   in genitive case, and "%OB" will produce the month in nominative case.
1368
1369   In a call to strptime, "%B", "%b", "%h", "%OB", "%Ob", and "%Oh"
1370   are all valid and will all accept any known form of month
1371   name---standalone or complete, abbreviated or full.  In a call to
1372   nl_langinfo, the query constants MON_1..12 and ABMON_1..12 return
1373   the strings used by "%B" and "%b", respectively.  New query
1374   constants ALTMON_1..12 and _NL_ABALTMON_1..12 return the strings
1375   used by "%OB" and "%Ob", respectively.
1376
1377   In a locale definition file, use "alt_mon" and "ab_alt_mon" to
1378   define the strings for %OB and %Ob, respectively; these have the
1379   same syntax as "mon" and "abmon".  These arrays are optional; if they
1380   are not provided then they have the same content as "mon" and "abmon",
1381   respectively.
1382
1383   These features are provided for locales which define "alt_mon" and/or
1384   "ab_alt_mon" in their locale source data.  This release includes such
1385   alternative month name data for the following languages: Belarusian,
1386   Croatian, Greek, Lithuanian, Polish, Russian, and Ukrainian.
1387
1388   This feature is currently a GNU extension, but it is expected to
1389   be added to the next revision of POSIX, and it is also already
1390   available on some BSD-derived operating systems.
1391
1392   This feature will cause existing statically compiled applications
1393   to fail to load locales and fall back to the builtin C/POSIX locales.
1394   See notes below for other changes affecting compatibility.
1395
1396 * Support for the RISC-V ISA running on Linux has been added.  This port
1397   requires at least binutils-2.30, gcc-7.3.0, and linux-4.15; and is supported
1398   for the following ISA and ABI pairs:
1399
1400     - rv64imac lp64
1401     - rv64imafdc lp64
1402     - rv64imafdc lp64d
1403
1404 Deprecated and removed features, and other changes affecting compatibility:
1405
1406 * Statically compiled applications attempting to load locales compiled for the
1407   GNU C Library version 2.27 will fail and fall back to the builtin C/POSIX
1408   locale.  The reason for this is that the addition of the new "%OB" and "%Ob",
1409   support for two grammatical forms of the month names, also extends the locale
1410   data binary format.  Static applications needing locale support must be
1411   recompiled to match the runtime and data they are deployed with. In some
1412   distributions there is an upgrade window where dynamically linked applications
1413   may use a new library but the old locale data and also fall back to the
1414   builtin C/POSIX locales; restarting the application process is sufficient to
1415   fix this.
1416
1417 * Support for statically linked applications which call dlopen is deprecated
1418   and will be removed in a future version of glibc.  Applications which call
1419   dlopen need to be linked dynamically instead.
1420
1421 * Support for old programs which use internal stdio data structures and
1422   functions is deprecated.  This includes programs which use the C++ streams
1423   provided by libstdc++ in GCC 2.95.  Programs which use the internal
1424   symbols _IO_adjust_wcolumn, _IO_default_doallocate, _IO_default_finish,
1425   _IO_default_pbackfail, _IO_default_uflow, _IO_default_xsgetn,
1426   _IO_default_xsputn, _IO_doallocbuf, _IO_do_write, _IO_file_attach,
1427   _IO_file_close, _IO_file_close_it, _IO_file_doallocate, _IO_file_fopen,
1428   _IO_file_init, _IO_file_jumps, _IO_fileno, _IO_file_open,
1429   _IO_file_overflow, _IO_file_read, _IO_file_seek, _IO_file_seekoff,
1430   _IO_file_setbuf, _IO_file_stat, _IO_file_sync, _IO_file_underflow,
1431   _IO_file_write, _IO_file_xsputn, _IO_flockfile, _IO_flush_all,
1432   _IO_flush_all_linebuffered, _IO_free_backup_area, _IO_free_wbackup_area,
1433   _IO_init, _IO_init_marker, _IO_init_wmarker, _IO_iter_begin, _IO_iter_end,
1434   _IO_iter_file, _IO_iter_next, _IO_least_wmarker, _IO_link_in,
1435   _IO_list_all, _IO_list_lock, _IO_list_resetlock, _IO_list_unlock,
1436   _IO_marker_delta, _IO_marker_difference, _IO_remove_marker, _IO_seekmark,
1437   _IO_seekwmark, _IO_str_init_readonly, _IO_str_init_static,
1438   _IO_str_overflow, _IO_str_pbackfail, _IO_str_seekoff, _IO_str_underflow,
1439   _IO_switch_to_main_wget_area, _IO_switch_to_wget_mode,
1440   _IO_unsave_wmarkers, _IO_wdefault_doallocate, _IO_wdefault_finish,
1441   _IO_wdefault_pbackfail, _IO_wdefault_setbuf, _IO_wdefault_uflow,
1442   _IO_wdefault_xsgetn, _IO_wdefault_xsputn, _IO_wdoallocbuf, _IO_wdo_write,
1443   _IO_wfile_jumps, _IO_wfile_overflow, _IO_wfile_sync, _IO_wfile_underflow,
1444   _IO_wfile_xsputn, _IO_wmarker_delta, or _IO_wsetb may stop working with a
1445   future version of glibc.  Unlike other symbol removals, these old
1446   applications will not be supported using compatibility symbols.
1447
1448 * On GNU/Linux, the obsolete Linux constant PTRACE_SEIZE_DEVEL is no longer
1449   defined by <sys/ptrace.h>.
1450
1451 * libm no longer supports SVID error handling (calling a user-provided
1452   matherr function on error) or the _LIB_VERSION variable to control error
1453   handling.  (SVID error handling and the _LIB_VERSION variable still work
1454   for binaries linked against older versions of the GNU C Library.)  The
1455   libieee.a library is no longer provided.  math.h no longer defines struct
1456   exception, or the macros X_TLOSS, DOMAIN, SING, OVERFLOW, UNDERFLOW,
1457   TLOSS, PLOSS and HUGE.
1458
1459 * The libm functions pow10, pow10f and pow10l are no longer supported for
1460   new programs.  Programs should use the standard names exp10, exp10f and
1461   exp10l for these functions instead.
1462
1463 * The mcontext_t type is no longer the same as struct sigcontext.  On
1464   platforms where it was previously the same, this changes the C++ name
1465   mangling for interfaces involving this type.
1466
1467 * The add-ons mechanism for building additional packages at the same time as
1468   glibc has been removed.  The --enable-add-ons configure option is now
1469   ignored.
1470
1471 * The --without-fp configure option is now ignored.  Whether hardware
1472   floating-point instructions are used is now configured based on whether
1473   the compiler used at configure time (without any options implied by a
1474   --with-cpu= configure option) uses such instructions.
1475
1476 * The res_hnok, res_dnok, res_mailok and res_ownok functions now check that
1477   the specified string can be parsed as a domain name.
1478
1479 * In the malloc_info output, the <heap> element may contain another <aspace>
1480   element, "subheaps", which contains the number of sub-heaps.
1481
1482 * The libresolv function p_secstodate is no longer supported for new
1483   programs.
1484
1485 * The tilepro-*-linux-gnu configuration is no longer supported.
1486
1487 * The nonstandard header files <libio.h> and <_G_config.h> are deprecated
1488   and will be removed in a future release.  Software that is still using
1489   either header should be updated to use standard <stdio.h> interfaces
1490   instead.
1491
1492   libio.h was originally the header for a set of supported GNU extensions,
1493   but they have not been maintained as such in many years, they are now
1494   standing in the way of improvements to stdio, and we don't think there are
1495   any remaining external users.  _G_config.h was never intended for public
1496   use, but predates the bits convention.
1497
1498 Changes to build and runtime requirements:
1499
1500 * bison version 2.7 or later is required to generate code in the 'intl'
1501   subdirectory.
1502
1503 Security related changes:
1504
1505   CVE-2009-5064: The ldd script would sometimes run the program under
1506   examination directly, without preventing code execution through the
1507   dynamic linker.  (The glibc project disputes that this is a security
1508   vulnerability; only trusted binaries must be examined using the ldd
1509   script.)
1510
1511   CVE-2017-15670: The glob function, when invoked with GLOB_TILDE,
1512   suffered from a one-byte overflow during ~ operator processing (either
1513   on the stack or the heap, depending on the length of the user name).
1514   Reported by Tim Rühsen.
1515
1516   CVE-2017-15671: The glob function, when invoked with GLOB_TILDE,
1517   would sometimes fail to free memory allocated during ~ operator
1518   processing, leading to a memory leak and, potentially, to a denial
1519   of service.
1520
1521   CVE-2017-15804: The glob function, when invoked with GLOB_TILDE and
1522   without GLOB_NOESCAPE, could write past the end of a buffer while
1523   unescaping user names.  Reported by Tim Rühsen.
1524
1525   CVE-2017-17426: The malloc function, when called with an object size near
1526   the value SIZE_MAX, would return a pointer to a buffer which is too small,
1527   instead of NULL.  This was a regression introduced with the new malloc
1528   thread cache in glibc 2.26.  Reported by Iain Buclaw.
1529
1530   CVE-2017-1000408: Incorrect array size computation in _dl_init_paths leads
1531   to the allocation of too much memory.  (This is not a security bug per se,
1532   it is mentioned here only because of the CVE assignment.)  Reported by
1533   Qualys.
1534
1535   CVE-2017-1000409: Buffer overflow in _dl_init_paths due to miscomputation
1536   of the number of search path components.  (This is not a security
1537   vulnerability per se because no trust boundary is crossed if the fix for
1538   CVE-2017-1000366 has been applied, but it is mentioned here only because
1539   of the CVE assignment.)  Reported by Qualys.
1540
1541   CVE-2017-16997: Incorrect handling of RPATH or RUNPATH containing $ORIGIN
1542   for AT_SECURE or SUID binaries could be used to load libraries from the
1543   current directory.
1544
1545   CVE-2018-1000001: Buffer underflow in realpath function when getcwd function
1546   succeeds without returning an absolute path due to unexpected behaviour
1547   of the Linux kernel getcwd syscall.  Reported by halfdog.
1548
1549   CVE-2018-6485: The posix_memalign and memalign functions, when called with
1550   an object size near the value of SIZE_MAX, would return a pointer to a
1551   buffer which is too small, instead of NULL.  Reported by Jakub Wilk.
1552
1553   CVE-2018-6551: The malloc function, when called with an object size near
1554   the value of SIZE_MAX, would return a pointer to a buffer which is too
1555   small, instead of NULL.
1556
1557 The following bugs are resolved with this release:
1558
1559   [866] glob: glob should match dangling symlinks
1560   [1062] glob: sysdeps/generic/glob.c merge from gnulib (part 3 of 3)
1561   [2522] localedata: ca_ES@valencia: new Valencian (meridional Catalan)
1562     locale
1563   [5997] math: Very slow execution of sinf function
1564   [10580] localedata: hr_HR: updated locale
1565   [10871] locale: 'mon' array should contain both nominative and genitive
1566     cases
1567   [12349] localedata: eu_ES: incorrect thousands separator
1568   [13605] localedata: shn_MM: new Shan locale
1569   [13805] localedata: ru_RU: currency should use ',' as radix point
1570   [13953] localedata: km_KH: locale update
1571   [13994] localedata: mjw_IN: new locale
1572   [14121] build: make writes .mo files in po directory
1573   [14333] libc: Fix the race between atexit() and exit()
1574   [14681] dynamic-link: _dl_get_origin leaks memory via executable link map.
1575   [14925] localedata: bn_*: LC_IDENTIFICATION.language key should be
1576     "Bangla"
1577   [15260] localedata: LC_MESSAGES.{yes,no}{str,expr}: various errors
1578   [15261] localedata: LC_MESSAGES.yesexpr/noexpr: inconsistent use of full-
1579     width Latin characters
1580   [15332] localedata: es_CU: locale update
1581   [15436] stdio: Don't close or flush stdio streams on abort
1582   [15537] localedata: lv_LV: invalid collation for Latvian diacritical
1583     letters
1584   [16148] localedata: ca_ES: incorrect thousands separator
1585   [16750] dynamic-link: ldd should not try to execute the binaries
1586     (CVE-2009-5064)
1587   [16777] localedata: pl_PL: incorrect thousands separator in locale
1588   [16905] localedata: hanzi: new collation
1589   [17563] localedata: cmn_TW: add hanzi collation
1590   [17750] localedata: wrong collation order of diacritics in most locales
1591   [17804] libc: scandirat fails with ENOMEM because it checks for errno even
1592     if malloc succeeded
1593   [17956] build: Build fails on missing definitions from header file
1594     nss/nss.h when Mozilla NSS is used for cryptography
1595   [18203] libc: realpath() does not handle unreachable paths correctly
1596   [18572] dynamic-link: [arm] Lazy TLSDESC relocation has data race
1597   [18812] localedata: kab_DZ: new Kabyle Algeria locale
1598   [18822] libc: Internal functions are called via PLT
1599   [18858] string: _HAVE_STRING_ARCH_xxx aren't defined for i386 nor x86_64
1600   [19170] libc: __gmon_start__ defined in hppa in crtn.S
1601   [19574] libc: glibc should support building static PIE binaries
1602   [19852] localedata: charmaps/UTF-8: incorrect wcwidth for U+3099 and
1603     U+309A
1604   [19971] glob: glob: Do not skip entries with zero d_ino values
1605   [19982] localedata: fr.po: spelling mistake for error code EXDEV
1606   [20008] localedata: km_KH: convert to translit_neutral
1607   [20009] localedata: tr_TR: convert LC_CTYPE to i18n
1608   [20142] math: [x86_64] Add SSE4.1 trunc, truncf
1609   [20204] dynamic-link: _dl_open_hook and _dlfcn_hook hardening
1610   [20482] localedata: de_CH: abbreviated weekdays should be two letters
1611   [20498] localedata: miq_NI: new Mískitu / Miskito (miq) language locale
1612     for Nicaragua
1613   [20532] nss: getaddrinfo uses errno and h_errno without guaranteeing
1614     they're set, wrong errors returned by gaih_inet when lookup functions
1615     are not found.
1616   [20756] localedata: [PATCH] Use Unicode wise thousands separator
1617   [20826] network: posix/tst-getaddrinfo5 fails on hosts without network
1618     access
1619   [20952] localedata: yuw_PG: new locale
1620   [21084] localedata: charmaps/IBM858: new codepage
1621   [21161] manual: [PATCH] fix typo in manual/arith.texi on strtoul prototype
1622   [21242] libc: assert gives pedantic warning in old gcc versions
1623   [21265] dynamic-link: _dl_runtime_resolve isn't compatible with Intel C++
1624     __regcall calling convention
1625   [21309] math: signed integer overflow in sysdeps/ieee754/dbl-64/e_pow.c
1626   [21326] libc: C99 functions are not declared for C++11 and later if
1627     _GNU_SOURCE is not predefined by g++
1628   [21457] libc: sys/ucontext.h namespace
1629   [21530] libc: tmpfile() should be implemented using O_TMPFILE
1630   [21660] math: GCC fails to compile a formula with tgmath.h
1631   [21672] nptl: sys-libs/glibc on ia64 crashes on thread exit: signal
1632     SIGSEGV, Segmentation fault: pthread_create.c:432: __madvise
1633     (pd->stackblock, freesize - PTHREAD_STACK_MIN, MADV_DONTNEED);
1634   [21684] math: tgmath.h handling of complex integers
1635   [21685] math: tgmath.h handling of bit-fields
1636   [21686] math: tgmath.h handling of __int128
1637   [21706] localedata: yesstr and nostr  are missing for Breton [LC_MESSAGES]
1638     locale
1639   [21745] libc: [powerpc64le] Extra PLT reference with --enable-stack-
1640     protector=all
1641   [21750] localedata: column width of characters incompatible with classical
1642     wcwidth
1643   [21754] malloc: malloc: Perform as little work as possible after heap
1644     consistency check failures
1645   [21780] libc: hppa: p{read,write}v2 does not set ENOSUP on invalid flag
1646   [21790] libc: Missing __memset_zero_constant_len_parameter in libc.so
1647   [21791] string: Unused XXX_chk_XXX functions in libc.a
1648   [21815] dynamic-link: FAIL: elf/tst-prelink-cmp with GCC is defaulted to
1649     PIE
1650   [21836] localedata: Removed redundant data (LC_MONETARY) in various Indian
1651     locales
1652   [21845] localedata: Added new Locale bho_NP
1653   [21853] localedata: Fix abday Which looks same as day in zh_SG
1654   [21854] localedata: Added New Locale en_SC
1655   [21864] libc: xmalloc.o is compiled with -DMODULE_NAME=libc
1656   [21871] dynamic-link: _dl_runtime_resolve_avx_opt is slower than
1657     _dl_runtime_resolve_avx_slow
1658   [21885] network: getaddrinfo: gethosts does not release resolver context
1659     on memory allocation failure
1660   [21899] libc: XPG4.2 sigaction namespace
1661   [21908] dynamic-link: dynamic linker broke on ia64 (mmap2 consolidation is
1662     the suspect)
1663   [21913] libc: static binaries SIGSEGV in __brk when host's gcc is pie-by-
1664     default (i386)
1665   [21915] nss: nss_files can return with NSS_STATUS_SUCCESS and a clobbered
1666     errno value, causing getaddrinfo to fail
1667   [21920] localedata: Fix p_cs_precedes/n_cs_precedes for mt_MT
1668   [21922] network: getaddrinfo with AF_INET/AF_INET6 returns EAI_NONAME
1669     instead of EAI_NODATA
1670   [21928] libc: sys/ptrace.h: remove obsolete temporary development Linux
1671     constant PTRACE_SEIZE_DEVEL
1672   [21930] math: C-only gcc builtins used in <math.h> isinf
1673   [21932] network: Unpaired __resolv_context_get in generic get*_r
1674     implementation
1675   [21941] math: powerpc: Wrong register constraint for xssqrtqp in sqrtf128
1676   [21944] libc: sigval namespace
1677   [21951] localedata: Update hanzi collation by stroke
1678   [21955] math: Wrong alignment of  L(SP_RANGE)/L(SP_INF_0) in
1679     sysdeps/x86_64/fpu/e_expf.S
1680   [21956] libc: Stack allocation in MIPS syscall impl (ubounded stack
1681     allocation in syscall loops)
1682   [21959] localedata: Fix Country name for xh_ZA
1683   [21960] localedata: Fix abmon for bem_ZM
1684   [21966] math: AVX2 mathvec functions use FMA without checking
1685   [21967] math: When 512-bit AVX2 wrapper functions in mathvec are used?
1686   [21971] localedata: Added New Locale for mfe_MU
1687   [21972] libc: assert macro requires operator== (int) for its argument type
1688   [21973] math: [sparc] libm missing sqrtl compat symbol
1689   [21974] libc: Remove __bb_init_func and __bb_exit_func
1690   [21982] string: stratcliff.c: error: assuming signed overflow does not
1691     occur with -O3
1692   [21986] stdio: __guess_grouping is called incorrectly
1693   [21987] math: [sparc32] wrong bits/long-double.h installed
1694   [22019] localedata: Wrong placement of monetary symbol in el_GR (negative
1695     amounts)
1696   [22022] localedata: Missing country_name for mni_IN
1697   [22023] localedata: Removed redundant data (LC_TIME and LC_MESSAGES) for
1698     niu_NZ
1699   [22025] locale: iconv: Inconsistency between pointer mangling and NULL
1700     checks
1701   [22026] locale: iconv_open: heap overflow on gconv_init failure
1702   [22028] math: bits/math-finite.h _MSUF_ expansion namespace
1703   [22035] math: [m68k] bits/math-inline.h macro namespace
1704   [22038] localedata: Fix abbreviated weeks and months for Somali
1705   [22044] localedata: Remove redundant data for Limburgish Language
1706   [22050] malloc: Linking with -lmcheck does not hook
1707     __malloc_initialize_hook correctly
1708   [22051] libc: zero terminator in the middle of glibc's .eh_frame
1709   [22052] malloc: malloc failed to compile with GCC 7 and -O3
1710   [22070] localedata: charmaps/UTF-8: wcwidth for
1711     Prepended_Concatenation_Mark codepoints set to 0 (should be 1)
1712   [22074] localedata: charmaps/UTF-8: wcwidth for U+1160-U+11FF (Hangul
1713     Jungseong and Jongseong) should be 0
1714   [22078] nss: nss_files performance issue in multi mode
1715   [22082] math: bits/math-finite.h exp10 condition
1716   [22086] libc: pcprofiledump incorrect cross-endian condition
1717   [22093] dynamic-link: ld.so no longer searches in .../x86_64
1718   [22095] network: Name server address allocation memory leak in resolv.conf
1719     parsing after OOM
1720   [22096] network: __resolv_conf_attach can incorrectly free passed conf
1721     object
1722   [22100] localedata: om_KE: LC_TIME: copy redundant data from om_ET
1723   [22101] dynamic-link: Dynamic loader must ignore "debug" shared objects
1724     e.g. ET_GNU_DEBUG_*
1725   [22111] malloc: malloc: per thread cache is not returned when thread exits
1726   [22112] localedata: Fix LC_TELEPHONE/LC_NAME for az_AZ
1727   [22134] libc: [linux] implement fexecve with execveat
1728   [22142] libc: [powerpc] printf oupts a wrong value of DBL_MAX on ppc64 and
1729     ppc64le
1730   [22145] libc: ttyname() gives up too early in the face of namespaces
1731   [22146] math: C++ build issue with float128 on x86_64
1732   [22153] nptl: nptl: save error code before process termination
1733   [22156] libc: [hppa,ia64,microblaze] Executable stack default
1734   [22159] malloc: malloc: MALLOC_CHECK_ broken with --enable-tunables=no
1735   [22161] nscd: nscd cache prune for netgroups hangs after timeout bump
1736   [22165] libc: [hppa] Text relocations in libc.so
1737   [22180] libc: destructor registered via __cxa_atexit is called twice
1738   [22183] glob: commit 5554304f0ddd ("posix: Allow glob to match dangling
1739     symlinks") cause "make" segfaults
1740   [22189] math: [powerpc] math_private.h definitions of math_opt_barrier and
1741     math_force_eval
1742   [22207] libc: FAIL: stdlib/test-atexit-race
1743   [22225] math: nearbyint arithmetic moved before feholdexcept
1744   [22229] math: [sparc32] missing copysignl, fabsl, fmal compat symbols
1745   [22235] math: iscanonical in C++ and float128
1746   [22243] math: log2(0) and log10(0) are wrong in downward rounding without
1747     the svid compat wrapper
1748   [22244] math: ynf and yn are wrong without the svid compat wrapper
1749   [22273] libc: Improper assert in Linux posix_spawn implementation
1750   [22284] libc: -pg -pie doesn't work
1751   [22292] locale: localedef exits with error 4 when it should be error 1
1752   [22294] locale: Allow "" for int_currency_symbol definition in locales.
1753   [22295] locale: Don't warn on non-symbolic characters in locale sources in
1754     --verbose.
1755   [22296] math: glibc 2.26: signbit build issue with Gcc 5.5.0 on x86_64
1756   [22298] nptl: x32: lockups on recursive pthread_mutex_lock after upgrade
1757     to 2.26
1758   [22299] dynamic-link: Problem with $PLATFORM on x86_64 platform
1759   [22320] glob: Buffer overflow in glob with GLOB_TILDE (CVE-2017-15670)
1760   [22321] libc: sysconf(_SC_IOV_MAX) returns -1 on Linux
1761   [22322] libc: [mips64] wrong bits/long-double.h installed
1762   [22325] glob: Memory leak in glob with GLOB_TILDE (CVE-2017-15671)
1763   [22332] glob: Buffer overflow in glob with GLOB_TILDE in unescaping
1764     (CVE-2017-15804)
1765   [22336] localedata: cs_CZ LC_COLLATE does not use i18n
1766   [22343] malloc: Integer overflow in posix_memalign
1767   [22347] libc: getrandom() returns the number of bytes that were copied  to
1768     the buffer even though the comments say "Return 0 on success and -1 on
1769     failure."
1770   [22353] string: sysdeps/i386/i586/strcpy.S isn't maintainable
1771   [22362] libc: Installed crt1.o, crti,.o and crtn.o files are used with
1772     -m32
1773   [22370] dynamic-link: Incorrect note padding check
1774   [22375] libc: malloc returns pointer from tcache_get when should return
1775     NULL (CVE-2017-17426)
1776   [22377] math: iseqsig, float128 and C++
1777   [22382] localedata: Error in tpi_PG locale
1778   [22387] localedata: Replace unicode sequences <Uxxxx> for characters
1779     inside the ASCII printable range
1780   [22402] math: [powerpc64le] __MATH_TG does not support _Float128 for
1781     -mlong-double-64
1782   [22403] localedata: Slash needs escaping in some locales
1783   [22408] malloc: malloc_info access heaps without arena lock, ignores heaps
1784   [22409] network: res_hnok does not accept some host names used on the
1785     Internet
1786   [22412] network: res_dnok, res_hnok should perform syntax checks
1787   [22413] network: ns_name_pton ignores syntactically invalid trailing
1788     backslash
1789   [22415] stdio: setvbuf can lead to invalid free/segfault
1790   [22432] build: Non-deterministic build
1791   [22439] malloc: malloc_info should compute summary statistics for all sub-
1792     heaps in an arena
1793   [22442] network: if_nametoindex could report index for the wrong
1794     networking interface
1795   [22446] build: aliasing violation calling readlink in handle_request
1796   [22447] build: unsafe call to strlen with a non-string in getlogin_r.c
1797   [22457] libc: Generic preadv/pwritev incorrectly calls __posix_memalign
1798   [22459] libc: FAIL: elf/check-localplt with __stack_chk_fail related to
1799     __nscd_hash/__nss_hash
1800   [22463] network: p_secstodate overflow handling
1801   [22469] localedata: pl_PL LC_COLLATE does not use i18n
1802   [22478] libc: sigwait can fail with EINTR
1803   [22505] libc: ldconfig processes include directive in locale-specific
1804     order
1805   [22515] localedata: hsb_DE LC_COLLATE does not use copy "iso14651_t1"
1806   [22517] localedata: et_EE LC_COLLATE does not use copy "iso14651_t1"
1807   [22519] localedata: is_IS LC_COLLATE does not use copy "iso14651_t1"
1808   [22524] localedata: lt_LT  LC_COLLATE does not use copy "iso14651_t1"
1809   [22527] localedata: tr_TR  LC_COLLATE does not use copy "iso14651_t1"
1810   [22534] localedata: Collation rules for Serbian and Bosnian should be the
1811     same as for Croatian
1812   [22561] math: [DR#471] cacosh (0 + iNaN) should return NaN +/- i pi/2
1813   [22568] math: [DR#471] ctanh (0 + iNaN), ctanh (0 + i Inf)
1814   [22577] libc: missing newline after "cannot allocate TLS data structures
1815     for initial thread"
1816   [22588] manual: manual/conf.texi: missing underscore in front of
1817     SC_SSIZE_MAX
1818   [22593] math: nextafter and nexttoward are declared with const attribute
1819   [22596] manual: manual: finite(nan) wrongly described as returning nonzero
1820   [22603] string: ia64 memchr overflows internal pointer check
1821   [22605] libc: SH clone does not set the exit code correctly
1822   [22606] dynamic-link: Incorrect array size computation in _dl_init_paths
1823     (CVE-2017-1000408)
1824   [22607] dynamic-link: Buffer Overflow in _dl_init_paths (CVE-2017-1000409)
1825   [22611] malloc: malloc/tst-realloc wrongly assumes that errno must not be
1826     modified in case of success
1827   [22614] build: gcc: error: unrecognized command line option ‘-no-pie’
1828   [22615] manual: manual: ambiguous wording about errno value in case of
1829     success
1830   [22624] libc: MIPS setjmp() saves incorrect 'o0' register in --enable-
1831     stack-protector=all
1832   [22625] dynamic-link: RPATH $ORIGIN replaced by PWD for AT_SECURE/SUID
1833     binaries or if /proc is not mounted (CVE-2017-16997)
1834   [22627] dynamic-link: $ORIGIN in $LD_LIBRARY_PATH is substituted twice
1835   [22630] build: $(no-pie-ldflag) is no longer effective
1836   [22631] math: [m68k] Bad const attributes in bits/mathinline.h
1837   [22635] nptl: pthread_self returns NULL before libpthread is loaded
1838   [22636] nptl: PTHREAD_STACK_MIN is too small on x86-64
1839   [22637] nptl: guard size is subtracted from thread stack size instead of
1840     adding it on top
1841   [22648] libc: getrlimit/setrlimit with RLIM_INFINITY broken on alpha
1842   [22657] localedata: hu_HU: Avoid double space in date
1843   [22660] math: fmax, fmin sNaN handling on alpha
1844   [22664] libc: New warning of GCC8
1845   [22665] math: alpha: ceil and floor raise inexact exceptions
1846   [22666] math: alpha: trunc raise inexact exceptions
1847   [22667] libc: makecontext lacks stack alignment on i386
1848   [22678] libc: prlimit fails for RLIM_INFINITY values on 32-bit machines
1849   [22679] libc: getcwd(3) can succeed without returning an absolute path
1850     (CVE-2018-1000001)
1851   [22685] libc: PowerPC: Static AT_SECURE binaries segfault with lock-
1852     elision and tunables
1853   [22687] math: [powerpc-nofpu] complex long double functions spurious
1854     "invalid" exception
1855   [22688] math: [powerpc-nofpu] remainderl wrong sign of zero result
1856   [22690] math: [ldbl-128ibm] lrintl, lroundl missing "invalid" exceptions
1857   [22691] math: [powerpc-nofpu] fmaxmagl, fminmagl spurious "invalid"
1858     exception
1859   [22693] math: [ldbl-128ibm] log1pl (-qNaN) spurious "invalid" exception
1860   [22697] math: [powerpc] llround spurious "inexact" exceptions on 32-bit
1861     power4
1862   [22701] nis: Incomplete removal of libnsl
1863   [22702] math: [powerpc-nofpu] nearbyintl traps with trapping "inexact"
1864   [22707] libc: Missing defines in elf.h for DF_1_STUB and DF_1_PIE.
1865   [22715] dynamic-link: FAIL: elf/tst-audit10
1866   [22719] libc: Backtrace tests fail on hppa
1867   [22742] libc: [aarch64] mcontext_t __reserved field got renamed
1868   [22743] nptl: __pthread_register_cancel corrupts stack after f81ddabffd
1869   [22765] crypt: (struct crypt_data *data)->initialized is not set to zero
1870     before the first call to crypt_r () in crypt/badsalttest.c
1871
1872 \f
1873 Version 2.26
1874
1875 Major new features:
1876
1877 * A per-thread cache has been added to malloc. Access to the cache requires
1878   no locks and therefore significantly accelerates the fast path to allocate
1879   and free small amounts of memory. Refilling an empty cache requires locking
1880   the underlying arena. Performance measurements show significant gains in a
1881   wide variety of user workloads. Workloads were captured using a special
1882   instrumented malloc and analyzed with a malloc simulator. Contributed by
1883   DJ Delorie with the help of Florian Weimer, and Carlos O'Donell.
1884
1885 * Unicode 10.0.0 Support: Character encoding, character type info, and
1886   transliteration tables are all updated to Unicode 10.0.0, using
1887   generator scripts contributed by Mike FABIAN (Red Hat).
1888   These updates cause user visible changes, especially the changes in
1889   wcwidth for many emoji characters cause problems when emoji sequences
1890   are rendered with pango, see for example:
1891   https://bugzilla.gnome.org/show_bug.cgi?id=780669#c5
1892
1893 * Collation of Hungarian has been overhauled and is now consistent with "The
1894   Rules of Hungarian Orthography, 12th edition" (Bug 18934).  Contributed by
1895   Egmont Koblinger.
1896
1897 * Improvements to the DNS stub resolver, contributed by Florian Weimer:
1898
1899   - The GNU C Library will now detect when /etc/resolv.conf has been
1900     modified and reload the changed configuration.  The new resolver option
1901     “no-reload” (RES_NORELOAD) disables this behavior.
1902
1903   - The GNU C Library now supports an arbitrary number of search domains
1904     (configured using the “search” directive in /etc/resolv.conf);
1905     previously, there was a hard limit of six domains.  For backward
1906     compatibility, applications that directly modify the ‘_res’ global
1907     object are still limited to six search domains.
1908
1909   - When the “rotate” (RES_ROTATE) resolver option is active, the GNU C
1910     Library will now randomly pick a name server from the configuration as a
1911     starting point.  (Previously, the second name server was always used.)
1912
1913 * The tunables feature is now enabled by default.  This allows users to tweak
1914   behavior of the GNU C Library using the GLIBC_TUNABLES environment variable.
1915
1916 * New function reallocarray, which resizes an allocated block (like realloc)
1917   to the product of two sizes, with a guaranteed clean failure upon integer
1918   overflow in the multiplication.  Originally from OpenBSD, contributed by
1919   Dennis Wölfing and Rüdiger Sonderfeld.
1920
1921 * New wrappers for the Linux-specific system calls preadv2 and pwritev2.
1922   These are extended versions of preadv and pwritev, respectively, taking an
1923   additional flags argument.  The set of supported flags depends on the
1924   running kernel; full support currently requires kernel 4.7 or later.
1925
1926 * posix_spawnattr_setflags now supports the flag POSIX_SPAWN_SETSID, to
1927   create a new session ID for the spawned process.  This feature is
1928   scheduled to be added to the next major revision of POSIX; for the time
1929   being, it is available under _GNU_SOURCE.
1930
1931 * errno.h is now safe to use from C-preprocessed assembly language on all
1932   supported operating systems.  In this context, it will only define the
1933   Exxxx constants, as preprocessor macros expanding to integer literals.
1934
1935 * On ia64, powerpc64le, x86-32, and x86-64, the math library now implements
1936   128-bit floating point as defined by ISO/IEC/IEEE 60559:2011 (IEEE
1937   754-2008) and ISO/IEC TS 18661-3:2015.  Contributed by Paul E. Murphy,
1938   Gabriel F. T. Gomes, Tulio Magno Quites Machado Filho, and Joseph Myers.
1939
1940   To compile programs that use this feature, the compiler must support
1941   128-bit floating point with the type name _Float128 (as defined by TS
1942   18661-3) or __float128 (the nonstandard name used by GCC for C++, and for
1943   C prior to version 7).  _GNU_SOURCE or __STDC_WANT_IEC_60559_TYPES_EXT__
1944   must be defined to make the new interfaces visible.
1945
1946   The new functions and macros correspond to those present for other
1947   floating-point types (except for a few obsolescent interfaces not
1948   supported for the new type), with F128 or f128 suffixes; for example,
1949   strtof128, HUGE_VAL_F128 and cosf128.  Following TS 18661-3, there are no
1950   printf or scanf formats for the new type; the strfromf128 and strtof128
1951   interfaces should be used instead.
1952
1953 Deprecated and removed features, and other changes affecting compatibility:
1954
1955 * The synchronization that pthread_spin_unlock performs has been changed to
1956   now be equivalent to a C11 atomic store with release memory order to the
1957   spin lock's memory location.  Previously, several (but not all)
1958   architectures used stronger synchronization (e.g., containing what is
1959   often called a full barrier).  This change can improve performance, but
1960   may affect odd fringe uses of spin locks that depend on the previous
1961   behavior (e.g., using spin locks as atomic variables to try to implement
1962   Dekker's mutual exclusion algorithm).
1963
1964 * The port to Native Client running on ARMv7-A (--host=arm-nacl) has been
1965   removed.
1966
1967 * Sun RPC is deprecated.  The rpcgen program, librpcsvc, and Sun RPC headers
1968   will only be built and installed when the GNU C Library is configured with
1969   --enable-obsolete-rpc.  This allows alternative RPC implementations, such
1970   as TIRPC or rpcsvc-proto, to be used.
1971
1972 * The NIS(+) name service modules, libnss_nis, libnss_nisplus, and
1973   libnss_compat, are deprecated, and will not be built or installed by
1974   default.
1975
1976   The NIS(+) support library, libnsl, is also deprecated.  By default, a
1977   compatibility shared library will be built and installed, but not headers
1978   or development libraries. Only a few NIS-related programs require this
1979   library.  (In particular, the GNU C Library has never required programs
1980   that use 'gethostbyname' to be linked with libnsl.)
1981
1982   Replacement implementations based on TIRPC, which additionally support
1983   IPv6, are available from <https://github.com/thkukuk/>.  The configure
1984   option --enable-obsolete-nsl will cause libnsl's headers, and the NIS(+)
1985   name service modules, to be built and installed.
1986
1987 * The DNS stub resolver no longer performs EDNS fallback.  If EDNS or DNSSEC
1988   support is enabled, the configured recursive resolver must support EDNS.
1989   (Responding to EDNS-enabled queries with responses which are not
1990   EDNS-enabled is fine, but FORMERR responses are not.)
1991
1992 * res_mkquery and res_nmkquery no longer support the IQUERY opcode.  DNS
1993   servers have not supported this opcode for a long time.
1994
1995 * The _res_opcodes variable has been removed from libresolv.  It had been
1996   exported by accident.
1997
1998 * <string.h> no longer includes inline versions of any string functions,
1999   as this kind of optimization is better done by the compiler.  The macros
2000   __USE_STRING_INLINES and __NO_STRING_INLINES no longer have any effect.
2001
2002 * The nonstandard header <xlocale.h> has been removed.  Most programs should
2003   use <locale.h> instead.  If you have a specific need for the definition of
2004   locale_t with no other declarations, please contact
2005   libc-alpha@sourceware.org and explain.
2006
2007 * The obsolete header <sys/ultrasound.h> has been removed.
2008
2009 * The obsolete signal constant SIGUNUSED is no longer defined by <signal.h>.
2010
2011 * The obsolete function cfree has been removed.  Applications should use
2012   free instead.
2013
2014 * The stack_t type no longer has the name struct sigaltstack.  This changes
2015   the C++ name mangling for interfaces involving this type.
2016
2017 * The ucontext_t type no longer has the name struct ucontext.  This changes
2018   the C++ name mangling for interfaces involving this type.
2019
2020 * On M68k GNU/Linux and MIPS GNU/Linux, the fpregset_t type no longer has
2021   the name struct fpregset.  On Nios II GNU/Linux, the mcontext_t type no
2022   longer has the name struct mcontext.  On SPARC GNU/Linux, the struct
2023   mc_fq, struct rwindow, struct fpq and struct fq types are no longer
2024   defined in sys/ucontext.h, the mc_fpu_t type no longer has the name struct
2025   mc_fpu, the gwindows_t type no longer has the name struct gwindows and the
2026   fpregset_t type no longer has the name struct fpu.  This changes the C++
2027   name mangling for interfaces involving those types.
2028
2029 * On S/390 GNU/Linux, the constants defined by <sys/ptrace.h> have been
2030   synced with the kernel:
2031
2032     - PTRACE_GETREGS, PTRACE_SETREGS, PTRACE_GETFPREGS and PTRACE_SETFPREGS
2033       are not supported on this architecture and have been removed.
2034
2035     - PTRACE_SINGLEBLOCK, PTRACE_SECCOMP_GET_FILTER, PTRACE_PEEKUSR_AREA,
2036       PTRACE_POKEUSR_AREA, PTRACE_GET_LAST_BREAK, PTRACE_ENABLE_TE,
2037       PTRACE_DISABLE_TE and PTRACE_TE_ABORT_RAND have been added.
2038
2039   Programs that assume the GET/SETREGS ptrace requests are universally
2040   available will now fail to build, instead of malfunctioning at runtime.
2041
2042 Changes to build and runtime requirements:
2043
2044 * Linux kernel 3.2 or later is required at runtime, on all architectures
2045   supported by that kernel.  (This is a change from version 2.25 only for
2046   x86-32 and x86-64.)
2047
2048 * GNU Binutils 2.25 or later is now required to build the GNU C Library.
2049
2050 * On most architectures, GCC 4.9 or later is required to build the GNU C
2051   Library.  On powerpc64le, GCC 6.2 or later is required.
2052
2053   Older GCC versions and non-GNU compilers are still supported when
2054   compiling programs that use the GNU C Library.  (We do not know exactly
2055   how old, and some GNU extensions to C may be _de facto_ required.  If you
2056   are interested in helping us make this statement less vague, please
2057   contact libc-alpha@sourceware.org.)
2058
2059 Security related changes:
2060
2061 * The DNS stub resolver limits the advertised UDP buffer size to 1200 bytes,
2062   to avoid fragmentation-based spoofing attacks (CVE-2017-12132).
2063
2064 * LD_LIBRARY_PATH is now ignored in binaries running in privileged AT_SECURE
2065   mode to guard against local privilege escalation attacks (CVE-2017-1000366).
2066
2067 * Avoid printing a backtrace from the __stack_chk_fail function since it is
2068   called on a corrupt stack and a backtrace is unreliable on a corrupt stack
2069   (CVE-2010-3192).
2070
2071 * A use-after-free vulnerability in clntudp_call in the Sun RPC system has been
2072   fixed (CVE-2017-12133).
2073
2074 The following bugs are resolved with this release:
2075
2076   [984] network: Respond to changed resolv.conf in gethostbyname
2077   [5010] network: sunrpc service cleanup causes unwanted port mapper traffic
2078   [12068] localedata: sc_IT: misspelled yesexpr/day/abday/mon/abmon/date_fmt
2079     fields
2080   [12189] libc: __stack_chk_fail should not attempt a backtrace
2081     (CVE-2010-3192)
2082   [14096] time: Race condition on timezone/tst-timezone.out
2083   [14172] localedata: az_IR: new locale
2084   [14995] build: glibc fails to build if gold is the default linker, even if
2085     ld.bfd is available
2086   [15998] build: [powerpc] Set arch_minimum_kernel for powerpc LE
2087   [16637] network: inet_pton function is accepting IPv6 with bad format
2088   [16640] string: string/strtok.c: undefined behaviour inconsistent between
2089     x86 and other generic code
2090   [16875] localedata: ko_KR: fix lang_name
2091   [17225] localedata: ar_SY: localized month names for May and June are
2092     incorrect
2093   [17297] localedata: da_DK: wrong date_fmt string
2094   [18907] stdio: Incorrect order of __wur __THROW in <printf.h>
2095   [18934] localedata: hu_HU: collate: fix multiple bugs and add tests
2096   [18988] nptl: pthread wastes memory with mlockall(MCL_FUTURE)
2097   [19066] localedata: ar_SA abbreviated day and month names are in English
2098   [19569] network: resolv: Support an arbitrary number of search domains
2099   [19570] network: Implement random DNS server selection in the stub
2100     resolver
2101   [19838] locale: localedef fails on PA-RISC
2102   [19919] localedata: iso14651_t1_common: Correct the Malayalam sorting
2103     order of 0D36 and 0D37
2104   [19922] localedata: iso14651_t1_common: Define collation for Malayalam
2105     chillu characters
2106   [20098] libc: FAIL: debug/backtrace-tst on hppa
2107   [20257] network: sunrpc: clntudp_call does not enforce timeout when
2108     receiving data
2109   [20275] localedata: locale day/abday/mon/abmon should not have trailing
2110     whitespace
2111   [20313] localedata: Update locale data to Unicode 9.0
2112   [20424] manual: Document how to provide a malloc replacement
2113   [20496] localedata: agr_PE: new language locale Awajún / Aguaruna (agr)
2114     for Peru
2115   [20686] locale: Add el_GR@euro to SUPPORTED.
2116   [20831] dynamic-link: _dl_map_segments does not test for __mprotect
2117     failures consistently
2118   [21015] dynamic-link: Document and fix --enable-bind-now
2119   [21016] nptl: pthread_cond support is broken on hppa
2120   [21029] libc: glibc-2.23 (and later) fails to compile with -fno-omit-
2121     frame-pointer on i386
2122   [21049] libc: segfault in longjmp_chk() due to clobbered processor
2123     register
2124   [21075] libc: unused assigment to %g4 in sparc/sparc{64,32}/clone.S
2125   [21088] libc: Build fails with --enable-static-nss
2126   [21094] math: cosf(1.57079697) has 3 ulp error on targets where the
2127     generic c code is used
2128   [21109] libc: Tunables broken on big-endian
2129   [21112] math: powf has large ulp errors with base close to 1 and exponent
2130     around 4000
2131   [21115] network: sunrpc: Use-after-free in error path in clntudp_call
2132     (CVE-2017-12133)
2133   [21120] malloc: glibc malloc is incompatible with GCC 7
2134   [21130] math: Incorrect return from y0l (-inf) and y1l (-inf) when linking
2135     with -lieee
2136   [21134] math: Exception (divide by zero) not set for y0/y1 (0.0) and y0/y1
2137     (-0.0) when linking with -lieee
2138   [21171] math: log10, log2 and lgamma return incorrect results
2139   [21179] libc: handle R_SPARC_DISP64 and R_SPARC_REGISTER relocs
2140   [21182] libc: __memchr_sse2: regression in glibc-2.25 on i686
2141   [21207] localedata: ce_RU: update weekdays from CLDR
2142   [21209] dynamic-link: LD_HWCAP_MASK read in setuid binaries
2143   [21217] localedata: Update months from CLDR-31
2144   [21232] libc: miss posix_fadvise64 on MIPS64 when static linking
2145   [21243] libc: support_delete_temp_file should issue warning for failed
2146     remove()
2147   [21244] libc: support resolv_test_start() socket fd close should be
2148     checked for errors.
2149   [21253] libc: localedef randomly segfaults when using -fstack-check due to
2150     new posix_spawn implementation
2151   [21258] dynamic-link: Branch predication in _dl_runtime_resolve_avx512_opt
2152     leads to lower CPU frequency
2153   [21259] libc: [alpha] termios.h missing IXANY for POSIX
2154   [21261] libc: [sparc64] bits/setjmp.h namespace
2155   [21267] network: [mips] bits/socket.h IOC* namespace
2156   [21268] libc: [alpha] termios.h NL2, NL3 namespace
2157   [21270] libc: mmap64 silently truncates large offset values
2158   [21275] libc: posix_spawn always crashes on ia64 now
2159   [21277] libc: [alpha] termios.h missing IUCLC for UNIX98 and older
2160   [21280] math: [powerpc] logbl for POWER7 return incorrect results
2161   [21289] libc: Incorrect declaration for 32-bit platforms with
2162     _FILE_OFFSET_BITS=64 causes build error
2163   [21295] network: GETAI(AF_UNSPEC) drops IPv6 addresses if nss module does
2164     not support gethostbyname4_r
2165   [21298] nptl: rwlock can deadlock on frequent reader/writer phase
2166     switching
2167   [21338] malloc: mallopt M_ARENA_MAX doesn't set the maximum number of
2168     arenas
2169   [21340] libc: Support POSIX_SPAWN_SETSID
2170   [21357] libc: unwind-dw2-fde deadlock when using AddressSanitizer
2171   [21359] network: ns_name_pack needs additional byte in destination buffer
2172   [21361] network: resolv: Reduce advertised EDNS0 buffer size to guard
2173     against fragmentation attacks (CVE-2017-12132)
2174   [21369] network: resolv: Remove EDNS fallback
2175   [21371] libc: Missing timespec definition when compiled with _XOPEN_SOURCE
2176     and _POSIX_C_SOURCE
2177   [21386] nptl: Assertion in fork for distinct parent PID is incorrect
2178   [21391] dynamic-link: x86: Set dl_platform and dl_hwcap from CPU features
2179   [21393] stdio: Missing dup3 error check in freopen, freopen64
2180   [21396] libc: Use AVX2 memcpy/memset on Skylake server
2181   [21399] localedata: Bad description for U00EC in
2182     localedata/charmaps/CP1254
2183   [21411] malloc: realloc documentation error
2184   [21426] network: sys/socket.h uio.h namespace
2185   [21428] libc: [aarch64] tst-backtrace5 testsuite failure
2186   [21445] libc: signal.h bsd_signal namespace
2187   [21455] network: Network headers stdint.h namespace
2188   [21474] network: resolv: res_init does not use RES_DFLRETRY (2) but 4 for
2189     retry value
2190   [21475] network: resolv: Overlong search path is truncated mid-label
2191   [21511] libc: sigstack namespace
2192   [21512] libc: clone() ends up calling exit_group() through _exit() wrapper
2193   [21514] libc: sysdeps/unix/sysv/linux/sys/syscall.h:31:27: fatal error:
2194     bits/syscall.h: No  such file or directory
2195   [21517] libc: struct sigaltstack namespace
2196   [21528] dynamic-link: Duplicated minimal strtoul implementations in ld.so
2197   [21533] localedata: Update locale data to Unicode 10.0
2198   [21537] libc:
2199     ../sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S:44: Error:
2200     junk at end of line, first unrecognized character is `@'
2201   [21538] libc: SIG_HOLD missing for XPG4
2202   [21539] libc: S390: Mismatch between kernel and glibc ptrace.h with
2203     request 12: PTRACE_SINGLEBLOCK vs PTRACE_GETREGS.
2204   [21542] libc: Use conservative default for sysconf (_SC_NPROCESSORS_ONLN)
2205   [21543] libc: sigevent namespace
2206   [21548] libc: [mips] get/set/make/swap context for MIPS O32 assume wrong
2207     size for general purpose registers in mcontext_t structure
2208   [21550] libc: sigwait namespace
2209   [21552] libc: XPG4 bsd_signal namespace
2210   [21554] libc: sigpause namespace
2211   [21560] libc: sys/wait.h signal.h namespace
2212   [21561] libc: waitid namespace
2213   [21573] nptl: GCC 7: /usr/bin/install: cannot remove
2214     '/usr/include/stdlib.h': Permission denied
2215   [21575] libc: sys/wait.h missing struct rusage definition
2216   [21584] libc: sigaltstack etc namespace
2217   [21597] libc: siginterrupt namespace
2218   [21607] math: hppa: FAIL: math/test-tgmath
2219   [21609] dynamic-link: Incomplete workaround for GCC __tls_get_addr ABI
2220     issue on x86-64
2221   [21622] libc: [tile] missing SA_* for POSIX.1:2008
2222   [21624] dynamic-link: ld.so: Unsafe alloca allows local attackers to alias
2223     stack and heap (CVE-2017-1000366)
2224   [21625] libc: wait3 namespace
2225   [21654] nss: Incorrect pointer alignment in NSS group merge result
2226     construction
2227   [21657] network: Parse interface zone id for node-local multicast
2228   [21662] string: memcmp-avx2-movbe.S lacks saturating subtraction for
2229     between_2_3
2230   [21666] libc: .symver is used on common symbol
2231   [21668] network: resolv: res_init cross-thread broadcast introduces race
2232     conditions
2233   [21687] math: tgmath.h totalorder, totalordermag return type
2234   [21694] locale: Current Glibc Locale Does Not Support Tok-Pisin and Fiji
2235     Hindi Locale
2236   [21696] libc: Incorrect assumption of of __cpu_mask in
2237     posix/sched_cpucount.c
2238   [21697] libc: sysdeps/posix/spawni.c: 2 * suspicious condition ?
2239   [21706] localedata: yesstr and nostr  are missing for Breton [LC_MESSAGES]
2240     locale
2241   [21707] math: ppc64le: Invalid IFUNC resolver from libgcc calls getauxval,
2242     leading to relocation crash
2243   [21709] libc: resolv_conf.c:552: update_from_conf: Assertion
2244     `resolv_conf_matches (resp, conf)' failed.
2245   [21710] localedata: Added Samoan language locale for Samoa
2246   [21711] localedata: Pashto yesstr/nostr locale are missing
2247   [21715] nptl: sysdeps/nptl/bits/pthreadtypes.h: typedef guard
2248     __have_pthread_attr_t can cause redefinition of typedef ‘pthread_attr_t’
2249   [21721] localedata: Incorrect Full Weekday names for ks_IN@devanagari
2250   [21723] localedata: yesstr/nostr missing for Chinese language locale
2251   [21724] localedata: yesstr and nostr  are missing for  Xhosa [LC_MESSAGES]
2252     locale
2253   [21727] localedata: yesstr and nostr  are missing for Tsonga [LC_MESSAGES]
2254     locale
2255   [21728] localedata: New Locale for Tongan language
2256   [21729] localedata: incorrect LC_NAME fields for hi_IN
2257   [21733] localedata: yesstr and nostr  are missing for zh_HK
2258   [21734] localedata: Missing yesstr and nostr  are for kw_GB
2259   [21738] libc: misc/tst-preadvwritev2 and misc/tst-preadvwritev64v2 fail
2260   [21741] libc: Undefined __memmove_chk_XXX and __memset_chk_XXX in libc.a
2261   [21742] libc: _dl_num_cache_relocations is undefined in libc.a
2262   [21743] localedata: ks_IN@devanagari: abday strings mismatch the day
2263     strings
2264   [21744] libc: Tests failing on --enable-tunables --enable-stack-
2265     protector=all
2266   [21749] localedata: Wrong abbreviated day name (“abday”) for
2267     ar_JO/ar_LB/ar_SY
2268   [21756] localedata: missing yesstr, nostr  for nds_DE and nds_NL
2269   [21757] localedata: missing yesstr, nostr  for pap_AW and pap_CW
2270   [21759] localedata: missing yesstr and nostr for Tigrinya
2271   [21760] localedata: Fix LC_MESSAGES and LC_ADDRESS for anp_IN
2272   [21766] localedata: Wrong LC_MESSAGES for om_ET Locale
2273   [21767] localedata: Missing Bislama locales
2274   [21768] localedata: Missing yesstr and nostr for aa_ET
2275   [21770] localedata: Missing  Field in li_NL
2276   [21778] nptl: Robust mutex may deadlock
2277   [21779] libc: MicroBlaze segfaults when loading libpthread
2278   [21783] localedata: Fix int_select international_call_prefixes
2279   [21784] localedata: Inconsistency  in country_isbn
2280   [21788] localedata: Missing  Country Postal Abbreviations
2281   [21794] localedata: Added-country_isbn-for-Italy
2282   [21795] localedata: Add/Fix country_isbn for France
2283   [21796] localedata: Added country_isbn for Republic of Korea
2284   [21797] localedata: Fix inconsistency in country_isbn and missing prefixes
2285   [21799] localedata: Added int_select international_call_prefixes
2286   [21801] localedata: Added int_select international_call_prefixes
2287   [21804] nptl: Double semicolon in thread-shared-types.h
2288   [21807] localedata: LC_ADDRESS fix for pap_CW
2289   [21808] localedata: Fix LC_ADDRESS for pap_AW
2290   [21821] localedata: Added country_name in mai_IN
2291   [21822] localedata: Fix LC_TIME for mai_IN
2292   [21823] localedata: missing yesstr, nostr  for sa_IN
2293   [21825] localedata: Fix name_mrs for mag_IN
2294   [21828] localedata: 2.26 changelog should mention user visible changes
2295     with unicode 9.0
2296   [21835] localedata: Added Maithili language locale for Nepal
2297   [21838] localedata: Removed redundant data for the_NP
2298   [21839] localedata: Fix LC_MONETARY for ta_LK
2299   [21844] localedata: Fix Latin characters and Months Sequence.
2300   [21848] localedata: Fix mai_NP Title Name
2301
2302 \f
2303 Version 2.25
2304
2305 * The feature test macro __STDC_WANT_LIB_EXT2__, from ISO/IEC TR
2306   24731-2:2010, is supported to enable declarations of functions from that
2307   TR.  Note that not all functions from that TR are supported by the GNU C
2308   Library.
2309
2310 * The feature test macro __STDC_WANT_IEC_60559_BFP_EXT__, from ISO/IEC TS
2311   18661-1:2014, is supported to enable declarations of functions and macros
2312   from that TS.  Note that not all features from that TS are supported by
2313   the GNU C Library.
2314
2315 * The feature test macro __STDC_WANT_IEC_60559_FUNCS_EXT__, from ISO/IEC TS
2316   18661-4:2015, is supported to enable declarations of functions and macros
2317   from that TS.  Note that most features from that TS are not supported by
2318   the GNU C Library.
2319
2320 * The nonstandard feature selection macros _REENTRANT and _THREAD_SAFE are
2321   now treated as compatibility synonyms for _POSIX_C_SOURCE=199506L.
2322   Since the GNU C Library defaults to a much newer revision of POSIX, this
2323   will only affect programs that specifically request an old conformance
2324   mode.  For instance, a program compiled with -std=c89 -D_REENTRANT will
2325   see a change in the visible declarations, but a program compiled with
2326   just -D_REENTRANT, or -std=c99 -D_POSIX_C_SOURCE=200809L -D_REENTRANT,
2327   will not.
2328
2329   Some C libraries once required _REENTRANT and/or _THREAD_SAFE to be
2330   defined by all multithreaded code, but glibc has not required this for
2331   many years.
2332
2333 * The inclusion of <sys/sysmacros.h> by <sys/types.h> is deprecated.  This
2334   means that in a future release, the macros “major”, “minor”, and “makedev”
2335   will only be available from <sys/sysmacros.h>.
2336
2337   These macros are not part of POSIX nor XSI, and their names frequently
2338   collide with user code; see for instance glibc bug 19239 and Red Hat bug
2339   130601.  <stdlib.h> includes <sys/types.h> under _GNU_SOURCE, and C++ code
2340   presently cannot avoid being compiled under _GNU_SOURCE, exacerbating the
2341   problem.
2342
2343 * New <fenv.h> features from TS 18661-1:2014 are added to libm: the
2344   fesetexcept, fetestexceptflag, fegetmode and fesetmode functions, the
2345   femode_t type and the FE_DFL_MODE and FE_SNANS_ALWAYS_SIGNAL macros.
2346
2347 * Integer width macros from TS 18661-1:2014 are added to <limits.h>:
2348   CHAR_WIDTH, SCHAR_WIDTH, UCHAR_WIDTH, SHRT_WIDTH, USHRT_WIDTH, INT_WIDTH,
2349   UINT_WIDTH, LONG_WIDTH, ULONG_WIDTH, LLONG_WIDTH, ULLONG_WIDTH; and to
2350   <stdint.h>: INT8_WIDTH, UINT8_WIDTH, INT16_WIDTH, UINT16_WIDTH,
2351   INT32_WIDTH, UINT32_WIDTH, INT64_WIDTH, UINT64_WIDTH, INT_LEAST8_WIDTH,
2352   UINT_LEAST8_WIDTH, INT_LEAST16_WIDTH, UINT_LEAST16_WIDTH,
2353   INT_LEAST32_WIDTH, UINT_LEAST32_WIDTH, INT_LEAST64_WIDTH,
2354   UINT_LEAST64_WIDTH, INT_FAST8_WIDTH, UINT_FAST8_WIDTH, INT_FAST16_WIDTH,
2355   UINT_FAST16_WIDTH, INT_FAST32_WIDTH, UINT_FAST32_WIDTH, INT_FAST64_WIDTH,
2356   UINT_FAST64_WIDTH, INTPTR_WIDTH, UINTPTR_WIDTH, INTMAX_WIDTH,
2357   UINTMAX_WIDTH, PTRDIFF_WIDTH, SIG_ATOMIC_WIDTH, SIZE_WIDTH, WCHAR_WIDTH,
2358   WINT_WIDTH.
2359
2360 * New <math.h> features are added from TS 18661-1:2014:
2361
2362   - Signaling NaN macros: SNANF, SNAN, SNANL.
2363
2364   - Nearest integer functions: roundeven, roundevenf, roundevenl, fromfp,
2365     fromfpf, fromfpl, ufromfp, ufromfpf, ufromfpl, fromfpx, fromfpxf,
2366     fromfpxl, ufromfpx, ufromfpxf, ufromfpxl.
2367
2368   - llogb functions: the llogb, llogbf and llogbl functions, and the
2369     FP_LLOGB0 and FP_LLOGBNAN macros.
2370
2371   - Max-min magnitude functions: fmaxmag, fmaxmagf, fmaxmagl, fminmag,
2372     fminmagf, fminmagl.
2373
2374   - Comparison macros: iseqsig.
2375
2376   - Classification macros: iscanonical, issubnormal, iszero.
2377
2378   - Total order functions: totalorder, totalorderf, totalorderl,
2379     totalordermag, totalordermagf, totalordermagl.
2380
2381   - Canonicalize functions: canonicalize, canonicalizef, canonicalizel.
2382
2383   - NaN functions: getpayload, getpayloadf, getpayloadl, setpayload,
2384     setpayloadf, setpayloadl, setpayloadsig, setpayloadsigf, setpayloadsigl.
2385
2386 * The functions strfromd, strfromf, and strfroml, from ISO/IEC TS 18661-1:2014,
2387   are added to libc.  They convert a floating-point number into string.
2388
2389 * Most of glibc can now be built with the stack smashing protector enabled.
2390   It is recommended to build glibc with --enable-stack-protector=strong.
2391   Implemented by Nick Alcock (Oracle).
2392
2393 * The function explicit_bzero, from OpenBSD, has been added to libc.  It is
2394   intended to be used instead of memset() to erase sensitive data after use;
2395   the compiler will not optimize out calls to explicit_bzero even if they
2396   are "unnecessary" (in the sense that no _correct_ program can observe the
2397   effects of the memory clear).
2398
2399 * On ColdFire, MicroBlaze, Nios II and SH3, the float_t type is now defined
2400   to float instead of double.  This does not affect the ABI of any libraries
2401   that are part of the GNU C Library, but may affect the ABI of other
2402   libraries that use this type in their interfaces.
2403
2404 * On x86_64, when compiling with -mfpmath=387 or -mfpmath=sse+387, the
2405   float_t and double_t types are now defined to long double instead of float
2406   and double.  These options are not the default, and this does not affect
2407   the ABI of any libraries that are part of the GNU C Library, but it may
2408   affect the ABI of other libraries that use this type in their interfaces,
2409   if they are compiled or used with those options.
2410
2411 * The getentropy and getrandom functions, and the <sys/random.h> header file
2412   have been added.
2413
2414 * The buffer size for byte-oriented stdio streams is now limited to 8192
2415   bytes by default.  Previously, on Linux, the default buffer size on most
2416   file systems was 4096 bytes (and thus remains unchanged), except on
2417   network file systems, where the buffer size was unpredictable and could be
2418   as large as several megabytes.
2419
2420 * The <sys/quota.h> header now includes the <linux/quota.h> header.  Support
2421   for the Linux quota interface which predates kernel version 2.4.22 has
2422   been removed.
2423
2424 * The malloc_get_state and malloc_set_state functions have been removed.
2425   Already-existing binaries that dynamically link to these functions will
2426   get a hidden implementation in which malloc_get_state is a stub.  As far
2427   as we know, these functions are used only by GNU Emacs and this change
2428   will not adversely affect already-built Emacs executables.  Any undumped
2429   Emacs executables, which normally exist only during an Emacs build, should
2430   be rebuilt by re-running “./configure; make” in the Emacs build tree.
2431
2432 * The “ip6-dotint” and “no-ip6-dotint” resolver options, and the
2433   corresponding RES_NOIP6DOTINT flag from <resolv.h> have been removed.
2434   “no-ip6-dotint” had already been the default, and support for the
2435   “ip6-dotint” option was removed from the Internet in 2006.
2436
2437 * The "ip6-bytestring" resolver option and the corresponding RES_USEBSTRING
2438   flag from <resolv.h> have been removed.  The option relied on a
2439   backwards-incompatible DNS extension which was never deployed on the
2440   Internet.
2441
2442 * The flags RES_AAONLY, RES_PRIMARY, RES_NOCHECKNAME, RES_KEEPTSIG,
2443   RES_BLAST defined in the <resolv.h> header file have been deprecated.
2444   They were already unimplemented.
2445
2446 * The "inet6" option in /etc/resolv.conf and the RES_USE_INET6 flag for
2447   _res.flags are deprecated.  The flag was standardized in RFC 2133, but
2448   removed again from the IETF name lookup interface specification in RFC
2449   2553.  Applications should use getaddrinfo instead.
2450
2451 * DNSSEC-related declarations and definitions have been removed from the
2452   <arpa/nameser.h> header file, and libresolv will no longer attempt to
2453   decode the data part of DNSSEC record types.  Previous versions of glibc
2454   only implemented minimal support for the previous version of DNSSEC, which
2455   is incompatible with the currently deployed version.
2456
2457 * The resource record type classification macros ns_t_qt_p, ns_t_mrr_p,
2458   ns_t_rr_p, ns_t_udp_p, ns_t_xfr_p have been removed from the
2459   <arpa/nameser.h> header file because the distinction between RR types and
2460   meta-RR types is not officially standardized, subject to revision, and
2461   thus not suitable for encoding in a macro.
2462
2463 * The types res_sendhookact, res_send_qhook, re_send_rhook, and the qhook
2464   and rhook members of the res_state type in <resolv.h> have been removed.
2465   The glibc stub resolver did not support these hooks, but the header file
2466   did not reflect that.
2467
2468 * For multi-arch support it is recommended to use a GCC which has
2469   been built with support for GNU indirect functions.  This ensures
2470   that correct debugging information is generated for functions
2471   selected by IFUNC resolvers.  This support can either be enabled by
2472   configuring GCC with '--enable-gnu-indirect-function', or by
2473   enabling it by default by setting 'default_gnu_indirect_function'
2474   variable for a particular architecture in the GCC source file
2475   'gcc/config.gcc'.
2476
2477 * GDB pretty printers have been added for mutex and condition variable
2478   structures in POSIX Threads. When installed and loaded in gdb these pretty
2479   printers show various pthread variables in human-readable form when read
2480   using the 'print' or 'display' commands in gdb.
2481
2482 * Tunables feature added to allow tweaking of the runtime for an application
2483   program.  This feature can be enabled with the '--enable-tunables' configure
2484   flag.  The GNU C Library manual has details on usage and README.tunables has
2485   instructions on adding new tunables to the library.
2486
2487 * A new version of condition variables functions have been implemented in
2488   the NPTL implementation of POSIX Threads to provide stronger ordering
2489   guarantees.
2490
2491 * A new version of pthread_rwlock functions have been implemented to use a more
2492   scalable algorithm primarily through not using a critical section anymore to
2493   make state changes.
2494
2495 Security related changes:
2496
2497 * On ARM EABI (32-bit), generating a backtrace for execution contexts which
2498   have been created with makecontext could fail to terminate due to a
2499   missing .cantunwind annotation.  This has been observed to lead to a hang
2500   (denial of service) in some Go applications compiled with gccgo.  Reported
2501   by Andreas Schwab.  (CVE-2016-6323)
2502
2503 * The DNS stub resolver functions would crash due to a NULL pointer
2504   dereference when processing a query with a valid DNS question type which
2505   was used internally in the implementation.  The stub resolver now uses a
2506   question type which is outside the range of valid question type values.
2507   (CVE-2015-5180)
2508
2509 The following bugs are resolved with this release:
2510
2511   [4099] stdio: Overly agressive caching by stream i/o functions.
2512   [7065] build: Support building glibc with -fstack-protector or -fstack-
2513     protector-all
2514   [9842] localedata: en_CA: incorrect date format
2515   [13165] nptl: pthread_cond_wait() can consume a signal that was sent
2516     before it started waiting
2517   [14139] manual: Do not hardcode platform names in manual/libm-err-tab.pl
2518   [15765] nptl: sem_open is wrongly a cancellation point
2519   [16421] network: IN6_IS_ADDR_UNSPECIFIED can use undefined s6_addr32
2520   [16458] libc: endian.h and netinet/in.h byte order macros return values of
2521     wrong type
2522   [16628] dynamic-link: Segfault after a binary without pthread dlopen()s a
2523     library linked with pthread
2524   [16630] nptl: Use SYSENTER for pthread_cond_broadcast/signal() (i.e. fix
2525     "FIXME: Ingo" issue)
2526   [16907] libc: <argp.h> compiled with --std=cXX disables __attribute__
2527   [17252] libc: getrandom and getentropy syscall
2528   [17730] malloc: thread-local storage is sometimes improperly free()'d
2529     after being __libc_memalign()'d
2530   [18241] stdio: failed fseek on memstream does not set errno and can fail
2531     when it shouldnt
2532   [18243] nptl: sem_wait, sem_timedwait are cancellation points shm_open is
2533     not
2534   [18463] nptl: pthread_cond_broadcast issue when surrounded by
2535     PTHREAD_PRIO_INHERIT mutex on ARM
2536   [18784] network: res_query and related function crash for special record
2537     type queries (CVE-2015-5180)
2538   [19380] math: strtod does not raise "inexact"
2539   [19387] string: Integer overflow in memchr
2540   [19390] string: Integer overflow in strncat
2541   [19398] build: linknamespace tests fail with massively parallel build
2542   [19402] nptl: Deadlock with robust shared mutex and asynchronous
2543     termination
2544   [19469] malloc: M_PERTURB in test-skeleton.c invalidates malloc tests
2545   [19473] malloc: Turn malloc_get_state etc. in compatibility symbols
2546   [19514] libc: [PATCH] Fix spelling errors in spelling
2547     "implement"/"implementation" in several places
2548   [19582] network: Deprecate RES_USE_INET6
2549   [19673] manual: clog10 docs appear to be erroneous
2550   [19810] dynamic-link: dlopen with both RTLD_NOLOAD and RTLD_NODELETE
2551     causes a segmentation fault
2552   [19826] libc: invalid pointer returned from __tls_get_addr with static
2553     linking
2554   [20016] network: resolv: Remove hooks support from the API
2555   [20019] dynamic-link: NULL pointer dereference in libc.so.6 IFUNC due to
2556     uninitialized GOT
2557   [20033] math: [x86_64] vectorized math function don't call the __finite
2558     versions
2559   [20116] nptl: use after free in pthread_create
2560   [20181] stdio: open_memstream(): writes not at end of stream corrupt data
2561   [20292] dynamic-link: Comparison in elf/dl-open.c _dl_addr_inside_object
2562     is always true.
2563   [20311] nptl: please install proc_service.h
2564   [20366] libc: Compilation errors in installed headers in strict-compliance
2565     modes
2566   [20370] malloc: malloc: Arena free list management is still racy
2567     (incorrect fix in bug 19243)
2568   [20386] libc: assert (X = 0) does not result in GCC warning
2569   [20432] malloc: malloc: Minimize interface required for interposition
2570   [20435] libc: Missing unwind info in __startcontext causes infinite loop
2571     in _Unwind_Backtrace (CVE-2016-6323)
2572   [20444] hurd: recvmsg: PF_LOCAL sockets and msg_name lead to SIGLOST
2573   [20452] nptl: Addition of sysdep.o to libpthread.a breaks relinking
2574     libpthread.a
2575   [20455] math: [powerpc] fesetexceptflag fails to clear FE_INVALID
2576   [20459] localedata: et_EE: locale has wrong {p,n}_cs_precedes value
2577   [20477] network: resolv: incorrect double-checked locking related to
2578     _res_hconf
2579   [20478] libc: libc_ifunc macro and similar usages leads to false debug-
2580     information.
2581   [20495] math: x86_64 performance degradation due to AVX/SSE transition
2582     penalty
2583   [20497] localedata: lt_LT: LC_TIME d_fmt used is obsolete
2584   [20508] dynamic-link: _dl_runtime_resolve_avx/_dl_runtime_profile_avx512
2585     cause transition penalty
2586   [20517] math: sparcv9 missing fdiml compat symbol
2587   [20524] manual: strverscmp is inconsistent
2588   [20525] libc: <sys/quota.h> should be based on kernel headers
2589   [20539] math: GCC 7 -static -lm fails to link at -O3
2590   [20554] libc: ld: bss-plt forced due to /usr/lib/libc_nonshared.a(ppc-
2591     mcount.oS)
2592   [20558] string: POSIX bcopy/bzero decls do not implement Object Size
2593     Checking
2594   [20591] network: Remove obsolete DNSSEC support
2595   [20592] network: DNS resource record type classification macros in
2596     <arpa/nameser.h> are incorrect
2597   [20593] network: Update DNS RR type definitions
2598   [20611] network: getaddrinfo accepts invalid numeric scope IDs
2599   [20615] build: glibc build fails when using --with-cpu=power9 --enable-
2600     multi-arch
2601   [20629] network: libresolv: Remove support for bitstring labels
2602     (RES_USEBSTRING)
2603   [20647] libc: GLIBC quitting every program - glibc on Pentium-S leads to
2604     assertion: "maxidx >= 2"
2605   [20660] math: [arm] Use VSQRT
2606   [20662] libc: checking whether x86_64-pc-linux-gnu-gcc implicitly enables
2607     -fstack-protector no (32bit gcc 6.2.0 pie and ssp enable)
2608   [20689] libc: Test for FMA should also check for AVX.
2609   [20707] glob: gl_pathv entries not set to NULL with GLOB_DOOFFS
2610   [20715] math: iszero macro breaks existing code
2611   [20718] math: [powerpc] copysignl raises "invalid" for sNaN
2612   [20728] libc: powerpc: Missing TOC stub in clone
2613   [20729] build: glibc-2.24 fails to build for i486 with -Os
2614   [20750] build: Build fails with default PIE enabled gcc-6.x
2615   [20768] math: [alpha] sqrt fegetenv namespace
2616   [20785] libc: binutils 2.28 fails to assemble power6/memset.S file in
2617     glibc
2618   [20787] math: float_t is defined as float incorrectly on x86_64 even if
2619     __FLT_EVAL_METHOD__ is 2
2620   [20790] network: rpcgen buffer overrun in get_prog_declaration
2621   [20822] nptl: race condition in __lll_unlock_elision on powerpc
2622   [20829] libc: crypt snprintf namespace
2623   [20847] libc: tst-vfork3 failure
2624   [20855] math: Default bits/mathdef.h has inappropriate float_t
2625   [20859] math: [sh4] FP_ILOGB0 invalid
2626   [20864] localedata: iconv: cp936 missing single-byte euro sign (0x80,
2627     U+20AC), not same as GBK
2628   [20915] dynamic-link: global-dynamic TLS broken on aarch64
2629   [20916] math: pow handling of sNaN arguments
2630   [20918] build: Building with --enable-nss-crypt fails tst-linkall-static.
2631   [20919] math: Bad pow (qNaN, 0) result with -lieee
2632   [20940] math: hypot sNaN handling
2633   [20947] math: fmax, fmin sNaN handling
2634   [20956] libc: debug/tst-backtrace3-6 don't work with -O3 anymore
2635   [20964] network: sunrpc: Stack-based buffer overflow in getrpcport with
2636     RES_USE_INET6
2637   [20971] string: powerpc64/power7 memchr overflows internal pointer check
2638   [20973] nptl: robust mutexes: Lost wake-ups
2639   [20974] locale: bs_BA: yesexpr/noexpr regexes accept any character
2640   [20978] nis: strlen on null pointer in nss_nisplus
2641   [20985] nptl: robust mutexes: lowlevelrobustlock assembly on x86 blocks on
2642     wrong condition
2643   [21014] string: i686 memchr overflows internal pointer check
2644   [21019] libc: [mips] n32 lseek incorrect on overflow
2645   [21022] libc: [microblaze] __backtrace get_frame_size namespace
2646   [21026] libc: [MIPS] readahead syscall is broken on n64
2647   [21028] math: Fallback fesetexceptflag should always succeed
2648   [21045] libc: [powerpc-nofpu] swapcontext does not restore signal mask
2649   [21047] math: arm: fpu_control.h: _FPU_GETCW/_FPU_SETCW is rejected by
2650     clang
2651   [21053] libc: [SH] Namespace pollution from sys/ucontext.h
2652   [21061] librt: [microblaze] librt lost clock_* exports
2653   [21073] libc: tunables: insecure environment variables passed to
2654     subprocesses with AT_SECURE
2655   [21081] string: Missing vzeroupper in memset-vec-unaligned-erms.S
2656 \f
2657 Version 2.24
2658
2659 * The minimum Linux kernel version that this version of the GNU C Library
2660   can be used with is 3.2, except on i[4567]86 and x86_64, where Linux
2661   kernel version 2.6.32 or later suffices (on architectures that already
2662   required kernel versions more recent than 3.2, those requirements remain
2663   unchanged).  Linux 3.2 or later kernel headers are required on all
2664   architectures.
2665
2666 * The pap_AN locale has been deleted.  This has been deprecated for a long
2667   time.  It has been replaced by pap_AW & pap_CW, both of which have long
2668   been included in previous releases.
2669
2670 * The readdir_r and readdir64_r functions have been deprecated.  It is
2671   recommended to use readdir and readdir64 instead.
2672
2673 * The type “union wait” has been removed.  It was deprecated in the early
2674   1990s and never part of POSIX.  Application code should use the int type
2675   instead of “union wait”.
2676
2677 * A new NSS action is added to facilitate large distributed system
2678   administration.  The action, MERGE, allows remote user stores like LDAP
2679   to be merged into local user stores like /etc/groups in order to provide
2680   easy to use, updated, and managed sets of merged credentials.  The new
2681   action can be used by configuring it in /etc/nsswitch.conf:
2682   group: files [SUCCESS=merge] nis
2683   Implemented by Stephen Gallagher (Red Hat).
2684
2685 * The deprecated __malloc_initialize_hook variable has been removed from the
2686   API.
2687
2688 * The long unused localedef --old-style option has been removed.  It hasn't
2689   done anything in over 16 years.  Scripts using this option can safely
2690   drop it.
2691
2692 * nextupl, nextup, nextupf, nextdownl, nextdown and nextdownf are added to
2693   libm.  They are defined by TS 18661 and IEEE754-2008.  The nextup functions
2694   return the next representable value in the direction of positive infinity
2695   and the nextdown functions return the next representable value in the
2696   direction of negative infinity.  These are currently enabled as GNU
2697   extensions.
2698
2699 Security related changes:
2700
2701 * An unnecessary stack copy in _nss_dns_getnetbyname_r was removed.  It
2702   could result in a stack overflow when getnetbyname was called with an
2703   overly long name.  (CVE-2016-3075)
2704
2705 * Previously, getaddrinfo copied large amounts of address data to the stack,
2706   even after the fix for CVE-2013-4458 has been applied, potentially
2707   resulting in a stack overflow.  getaddrinfo now uses a heap allocation
2708   instead.  Reported by Michael Petlan.  (CVE-2016-3706)
2709
2710 * The glob function suffered from a stack-based buffer overflow when it was
2711   called with the GLOB_ALTDIRFUNC flag and encountered a long file name.
2712   Reported by Alexander Cherepanov.  (CVE-2016-1234)
2713
2714 * The Sun RPC UDP client could exhaust all available stack space when
2715   flooded with crafted ICMP and UDP messages.  Reported by Aldy Hernandez'
2716   alloca plugin for GCC.  (CVE-2016-4429)
2717
2718 * The IPv6 name server management code in libresolv could result in a memory
2719   leak for each thread which is created, performs a failing naming lookup,
2720   and exits.  Over time, this could result in a denial of service due to
2721   memory exhaustion.  Reported by Matthias Schiffer.  (CVE-2016-5417)
2722
2723 The following bugs are resolved with this release:
2724
2725   [1170] localedata: ne_NP: update Nepali locale definition file
2726   [3629] manual: stpcpy description in string.texi refers to MS-DOG instead
2727     of MS-DOS.
2728   [6527] malloc: [powerpc] Malloc alignment insufficient for PowerPC
2729   [6796] math: fdim() does not set errno on overflow
2730   [10354] libc: posix_spawn should use vfork() in more cases than presently
2731   [11213] localedata: localedata: add copyright disclaimer to locale files
2732   [12143] localedata: chr_US: new Cherokee locale
2733   [12450] localedata: sgs_LT: new locale
2734   [12676] localedata: ln_CD: new locale
2735   [13237] localedata: LC_ADDRESS.country_name: update all locales w/latest
2736     CLDR data
2737   [13304] math: fma, fmaf, fmal produce wrong results
2738   [14259] build: --localedir arg to configure is ignored
2739   [14499] nptl: Does posix_spawn invoke atfork handlers / use vfork?
2740   [14750] libc: Race condition in posix_spawn vfork usage vs signal handlers
2741   [14934] localedata: es_CL: wrong first weekday chilean locale
2742   [15262] localedata: LC_MESSAGES.yesexpr/noexpr: inconsistent use of
2743     romanisation
2744   [15263] localedata: LC_MESSAGES.yesexpr/noexpr: inconsistent use of 1/0
2745     and +/-
2746   [15264] localedata: LC_MESSAGES.yesstr/nostr: lacking in many locales
2747   [15368] nptl: raise() is not async-signal-safe
2748   [15479] math: ceil, floor, round and trunc raise inexact exception
2749   [15578] localedata: kk_KZ: various updates
2750   [16003] localedata: pap_AN: punt old locale
2751   [16137] localedata: iw_IL: punt old locale
2752   [16190] localedata: eo: new esperanto locale
2753   [16374] localedata: lv_LV: change currency symbol in LC_MONETARY to euro
2754   [16742] malloc: race condition: pthread_atfork() called before first
2755     malloc() results in unexpected locking behaviour/deadlocks
2756   [16975] localedata: LC_MESSAGES.yesexpr/noexpr: revisit capitalization in
2757     all locales
2758   [16983] localedata: postal_fmt does not allow %l and %n modifiers
2759   [17565] localedata: pt_PT: wrong (work-)week start
2760   [17899] math: [powerpc] floorl returns negative zero with FE_DOWNWARD
2761   [17950] build: Build fails with -msse
2762   [18205] localedata: be_BY*: wrong first_weekday and first_workday
2763   [18433] libc: posix_spawn does not return correctly upon failure to
2764     execute
2765   [18453] localedata: charmaps/IBM875: incorrect codes
2766   [18712] string: bits/string2.h incompatible with -O2 -Werror=packed
2767     -Wsystem-headers
2768   [18896] localedata: he_IL: improvements for currency
2769   [18911] localedata: ro_RO: Correcting week day name for "Tuesday" in
2770     Romanian locale data
2771   [18960] locale: s390: _nl_locale_subfreeres uses larl opcode on misaligned
2772     symbol
2773   [19056] libc: Deprecate readdir_r
2774   [19133] localedata: pt_*: days & months should be lowercase in Portuguese
2775     language
2776   [19198] localedata: nl_NL: small improvements for Dutch locales
2777   [19257] network: Per-thread memory leak in __res_vinit with IPv6
2778     nameservers (CVE-2016-5417)
2779   [19269] build: tst-audit4 and tst-audit10 failures with gcc-6 on non avx
2780     machine
2781   [19400] locale: Language missing in  "iso-639.def", trivial fix in
2782     description
2783   [19431] malloc: Deadlock between fflush, getdelim, and fork
2784   [19505] libc: Incorrect file descriptor validity checks in
2785     posix_spawn_file_actions_add{open,close,dup2}
2786   [19509] dynamic-link: dlsym, dlvsym do not report errors through dlerror
2787     when using RTLD_NEXT
2788   [19512] locale: Stale `#ifndef HAVE_BUILTIN_EXPECT' in
2789     `intl/{gettextP,loadinfo}.h'
2790   [19534] libc: execle, execlp may use malloc
2791   [19568] localedata: *_CH: Swiss locales have inconsistent start of week
2792   [19573] network: res_nclose and __res_maybe_init disagree about name
2793     server initialization, breaking Hesiod
2794   [19575] localedata: Status of GB18030 tables
2795   [19581] localedata: sr_* date_fmt string contains additional newline
2796   [19583] string: SSSE3_Fast_Copy_Backward flag needs to be enabled for AMD
2797     Excavator core
2798   [19592] math: [ldbl-128ibm] ceill incorrect in non-default rounding modes
2799   [19593] math: [ldbl-128ibm] truncl incorrect in non-default rounding modes
2800   [19594] math: [ldbl-128ibm] roundl incorrect in non-default rounding modes
2801   [19595] math: [ldbl-128ibm] fmodl incorrect for results in subnormal
2802     double range
2803   [19602] math: [ldbl-128ibm] fmodl handling of equal arguments with low
2804     part zero incorrect
2805   [19603] math: [ldbl-128ibm] remainderl, remquol incorrect sign handling in
2806     equality tests
2807   [19610] dynamic-link: ldconfig -X removes stale symbolic links
2808   [19613] libc: s390x (64 bit) macro expansion WCOREDUMP and others
2809   [19633] locale: strfmon_l applies global locale to number formatting
2810   [19642] network: Memory leak in getnameinfo
2811   [19648] libc: test-skeleton.c: Do not set RLIMIT_DATA
2812   [19653] libc: Potential for NULL pointer dereference (CWE-476) in
2813     glibc-2.22
2814   [19654] math: [x86_64] Need testcase for BZ #19590 fix
2815   [19671] localedata: Missing Sanity Check for malloc() in 'tst-fmon.c' &
2816     'tst-numeric.c'
2817   [19674] math: [ldbl-128ibm] powl incorrect overflow handling
2818   [19677] math: [ldbl-128ibm] remainderl equality test incorrect for zero
2819     low part
2820   [19678] math: [ldbl-128ibm] nextafterl, nexttowardl incorrect sign of zero
2821     result
2822   [19679] dynamic-link: gcc-4.9.3 C++ exception handling broken due to
2823     unaligned stack
2824   [19726] locale: Converting UCS4LE to INTERNAL with iconv() does not update
2825     pointers and lengths in error-case.
2826   [19727] locale: Converting from/to UTF-xx with iconv() does not always
2827     report errors on UTF-16 surrogates values.
2828   [19755] nscd: nscd assertion failure in gc
2829   [19758] dynamic-link: Typo in EXTRA_LD_ENVVARS for x86-64
2830   [19759] libc: mempcpy shouldn't be inlined
2831   [19762] dynamic-link: HAS_CPU_FEATURE/HAS_ARCH_FEATURE are easy to misuse
2832   [19765] libc: s390 needs an optimized mempcpy
2833   [19779] glob: glob: buffer overflow with GLOB_ALTDIRFUNC due to incorrect
2834     NAME_MAX limit assumption (CVE-2016-1234)
2835   [19783] build: benchtests don't support --enable-hardcoded-path-in-tests
2836   [19787] network: Missing and incorrect truncation checks in getnameinfo
2837   [19790] math: [ldbl-128ibm] nearbyintl incorrect in non-default rounding
2838     modes
2839   [19791] network: Assertion failure in res_query.c with un-connectable name
2840     server addresses
2841   [19792] libc: MIPS: backtrace yields infinite backtrace with makecontext
2842   [19822] math: libm.so install clobbers old version
2843   [19825] network: resolv: send_vc can return uninitialized data in second
2844     response to getaddrinfo
2845   [19830] network: nss_dns: should check RDATA length against buffer length
2846   [19831] network: nss_dns: getaddrinfo returns uninitialized data when
2847     confronted with A/AAAA records of invalid size
2848   [19837] nss: nss_db: No retries for some long lines with a larger buffer
2849   [19848] math: powl(10,n) for n=-4,-5,-6,-7 is off by more than 1 ULP
2850   [19853] stdio: Printing IBM long double in decimal with high precision is
2851     sometimes incorrect
2852   [19860] build: x86_64: compile errors for tst-audit10 and tst-auditmod10b
2853   [19861] nptl: libpthread IFUNC resolver for fork can lead to crash
2854   [19862] network: resolv, nss_dns: Remove remaining logging of unexpected
2855     record types
2856   [19865] network: Assertion failure or memory leak in
2857     _nss_dns_getcanonname_r
2858   [19868] network: nss_dns: netent code does not skip over non-PTR records
2859   [19879] network: nss_dns: Stack overflow in getnetbyname implementation
2860     (CVE-2016-3075)
2861   [19881] string: Improve x86-64 memset
2862   [19907] string: Incorrect memcpy tests
2863   [19916] dynamic-link: S390: fprs/vrs are not saved/restored while
2864     resolving symbols
2865   [19925] libc: termios.h XCASE namespace
2866   [19928] string: memmove-vec-unaligned-erms.S is slow with large data size
2867   [19929] libc: limits.h NL_NMAX namespace
2868   [19931] stdio: Memory leak in vfprintf
2869   [19957] libc: clone(CLONE_VM) access invalid parent memory
2870   [19963] localedata: en_IL: New locale
2871   [19989] stdio: stdio.h cuserid namespace
2872   [19994] network: getaddrinfo does not restore RES_USE_INET6 flag in
2873     gethosts
2874   [19996] locale: langinfo.h nl_langinfo_l namespace
2875   [20005] stdio: fflush on a file opened with fmemopen resets position to 0
2876   [20010] network: getaddrinfo: Stack overflow in hostent translation
2877     (CVE-2016-3706)
2878   [20012] stdio: libio: fmemopen append mode failure
2879   [20014] stdio: stdio.h namespace for pre-threads POSIX
2880   [20017] network: resolv: Use gmtime_r instead of gmtime in p_secstodate
2881   [20023] libc: fcntl.h timespec namespace
2882   [20024] math: [x86_64] vectorized sincos trashes the stack
2883   [20031] network: nss_hesiod: Heap overflow in get_txt_records
2884   [20041] time: sys/time.h timespec namespace
2885   [20043] libc: unistd.h missing cuserid for UNIX98 and before
2886   [20044] libc: unistd.h missing pthread_atfork for UNIX98
2887   [20051] libc: ttyslot in wrong header under wrong conditions
2888   [20054] libc: gethostname not declared for XPG4
2889   [20055] libc: termios.h missing tcgetsid for XPG4
2890   [20072] dynamic-link: x86 init_cpu_features is called twice in static
2891     executable
2892   [20073] libc: sys/stat.h fchmod namespace
2893   [20074] libc: stdlib.h rand_r namespace
2894   [20076] libc: sys/stat.h missing S_IFSOCK, S_ISSOCK for XPG4
2895   [20094] libc: stdlib.h should not declare grantpt, ptsname, unlockpt for
2896     XPG3
2897   [20111] libc: struct sockaddr_storage cannot be aggregate-copied
2898   [20112] network: sunrpc: stack (frame) overflow in Sun RPC clntudp_call
2899     (CVE-2016-4429)
2900   [20115] string: Extra alignment in memset-vec-unaligned-erms.S
2901   [20119] libc: Wrong mask for processors level type from CPUID
2902   [20139] dynamic-link: Upper part of zmm is zeroed if Glibc is built with
2903     AS not supporting AVX512
2904   [20151] math: [ldbl-128/ldbl-128ibm] j0l, j1l, y0l, y1l return sNaN for
2905     sNaN argument
2906   [20153] math: [ldbl-128ibm] sqrtl (sNaN) returns sNaN
2907   [20156] math: [ldbl-128ibm] ceill, rintl etc. return sNaN for sNaN
2908     argument
2909   [20157] math: [powerpc] fabsl (sNaN) wrongly raises "invalid"
2910   [20160] math: [powerpc] ceil, rint etc. return sNaN for sNaN input
2911   [20178] libc: posix_spawn{p} should not call exit
2912   [20191] stdio: libio: vtables hardening
2913   [20195] string: FMA4 detection requires CPUID execution with register
2914     eax=0x80000001
2915   [20198] libc: quick_exit incorrectly destroys C++11 thread objects.
2916   [20205] math: [i386/x86_64] nextafterl incorrect incrementing negative
2917     subnormals
2918   [20212] math: acos (sNaN) returns sNaN
2919   [20213] math: asin (sNaN) returns sNaN
2920   [20214] network: Linux header sync with linux/in6.h and ipv6.h again.
2921   [20218] math: [i386] asinhl (sNaN) returns sNaN
2922   [20219] math: [i386] atanhl (sNaN) returns sNaN
2923   [20222] stdio: fopencookie: Mangle function pointers
2924   [20224] math: [i386] cbrtl (sNaN) returns sNaN
2925   [20225] math: ldexp, scalbn, scalbln return sNaN for sNaN input
2926   [20226] math: [i386/x86_64] expl, exp10l, expm1l return sNaN for sNaN
2927     input
2928   [20227] math: [i386/x86_64] logl (sNaN) returns sNaN
2929   [20228] math: [i386/x86_64] log10l (sNaN) returns sNaN
2930   [20229] math: [i386/x86_64] log1pl (sNaN) returns sNaN
2931   [20232] math: [ldbl-128] expm1l (sNaN) returns sNaN
2932   [20233] math: [ldbl-128ibm] expm1l (sNaN) returns sNaN
2933   [20234] math: [ldbl-128ibm] log1pl (sNaN) returns sNaN
2934   [20235] math: [i386/x86_64] log2l (sNaN) returns sNaN
2935   [20237] nss: nss_db: get*ent segfaults without preceding set*ent
2936   [20240] math: modf (sNaN) returns sNaN
2937   [20248] libc: debug/tst-longjump_chk2 calls printf from a signal handler
2938   [20250] math: frexp (sNaN) returns sNaN
2939   [20252] math: atan2 (sNaN, qNaN) fails to raise "invalid"
2940   [20255] math: [i386] fdim, fdimf return with excess range and precision /
2941     double rounding
2942   [20256] math: [i386/x86_64] fdiml returns sNaN for sNaN input
2943   [20260] string: ../sysdeps/x86/bits/string.h:1092:3: error: array
2944     subscript is below array bounds [-Werror=array-bounds]
2945   [20262] nis: _nss_nis_initgroups_dyn always returns NSS_STATUS_NOTFOUND
2946   [20263] nptl: robust mutex deadlocks if other thread requests timedlock
2947     (Only arm/linux)
2948   [20277] libc: $dp is not initialized correctly in sysdeps/hppa/start.S
2949   [20284] malloc: malloc: Corrupt arena avoidance causes unnecessary mmap
2950     fallbacks
2951   [20296] math: [i386/x86_64] scalbl returns sNaN for sNaN input, missing
2952     "invalid" exceptions
2953   [20314] nptl: make[4]: *** [/usr/include/stdlib.h] Error 1
2954   [20316] localedata: id_ID: Februari instead of Pebruari
2955   [20327] string: POWER8 strcasecmp returns incorrect result
2956   [20347] math: Failure: Test: j0_downward (0xap+0)
2957   [20348] libc: FAIL: misc/tst-preadvwritev64
2958   [20349] libc: 64-bit value is passed differently in p{readv,writev}{64}
2959   [20350] libc: There is no test for p{read,write}64
2960   [20357] math: Incorrect cos result for 1.5174239687223976
2961   [20384] build: Don't run libmvec-sincos-avx* tests on non avx machines
2962 \f
2963 Version 2.23
2964
2965 * Unicode 8.0.0 Support: Character encoding, character type info, and
2966   transliteration tables are all updated to Unicode 8.0.0, using new
2967   and/or improved generator scripts contributed by Mike FABIAN (Red Hat).
2968   These updates cause user visible changes, such as the fixes for bugs
2969   89, 16061, and 18568.
2970
2971 * sched_setaffinity, pthread_setaffinity_np no longer attempt to guess the
2972   kernel-internal CPU set size.  This means that requests that change the
2973   CPU affinity which failed before (for example, an all-ones CPU mask) will
2974   now succeed.  Applications that need to determine the effective CPU
2975   affinities need to call sched_getaffinity or pthread_getaffinity_np after
2976   setting it because the kernel can adjust it (and the previous size check
2977   would not detect this in the majority of cases).
2978
2979 * The fts.h header can now be used with -D_FILE_OFFSET_BITS=64.  With LFS
2980   the following new symbols are used: fts64_children, fts64_close,
2981   fts64_open, fts64_read and fts64_set.
2982
2983 * getaddrinfo now detects certain invalid responses on an internal netlink
2984   socket.  If such responses are received, an affected process will
2985   terminate with an error message of "Unexpected error <number> on netlink
2986   descriptor <number>" or "Unexpected netlink response of size <number> on
2987   descriptor <number>".  The most likely cause for these errors is a
2988   multi-threaded application which erroneously closes and reuses the netlink
2989   file descriptor while it is used by getaddrinfo.
2990
2991 * A defect in the malloc implementation, present since glibc 2.15 (2012) or
2992   glibc 2.10 via --enable-experimental-malloc (2009), could result in the
2993   unnecessary serialization of memory allocation requests across threads.
2994   The defect is now corrected.  Users should see a substantial increase in
2995   the concurent throughput of allocation requests for applications which
2996   trigger this bug.  Affected applications typically create and
2997   destroy threads frequently.  (Bug 19048 was reported and analyzed by
2998   Ericsson.)
2999
3000 * There is now a --disable-timezone-tools configure option for disabling the
3001   building and installing of the timezone related utilities (zic, zdump, and
3002   tzselect).  This is useful for people who build the timezone data and code
3003   independent of the GNU C Library.
3004
3005 * The obsolete header <regexp.h> has been removed.  Programs that require
3006   this header must be updated to use <regex.h> instead.
3007
3008 * The obsolete functions bdflush, create_module, get_kernel_syms,
3009   query_module and uselib are no longer available to newly linked binaries;
3010   the header <sys/kdaemon.h> has been removed.  These functions and header
3011   were specific to systems using the Linux kernel and could not usefully be
3012   used with the GNU C Library on systems with version 2.6 or later of the
3013   Linux kernel.
3014
3015 * Optimized string, wcsmbs and memory functions for IBM z13.
3016   Implemented by Stefan Liebler.
3017
3018 * Newly linked programs that define a variable called signgam will no longer
3019   have it set by the lgamma, lgammaf and lgammal functions.  Programs that
3020   require signgam to be set by those functions must ensure that they use the
3021   variable provided by the GNU C Library and declared in <math.h>, without
3022   defining their own copy.
3023
3024 * The minimum GCC version that can be used to build this version of the GNU
3025   C Library is GCC 4.7.  Older GCC versions, and non-GNU compilers, can
3026   still be used to compile programs using the GNU C Library.
3027
3028 Security related changes:
3029
3030 * An out-of-bounds value in a broken-out struct tm argument to strftime no
3031   longer causes a crash.  Reported by Adam Nielsen.  (CVE-2015-8776)
3032
3033 * The LD_POINTER_GUARD environment variable can no longer be used to disable
3034   the pointer guard feature.  It is always enabled.  Previously,
3035   LD_POINTER_GUARD could be used to disable security hardening in binaries
3036   running in privileged AT_SECURE mode.  Reported by Hector Marco-Gisbert.
3037   (CVE-2015-8777)
3038
3039 * An integer overflow in hcreate and hcreate_r could lead to an
3040   out-of-bounds memory access.  Reported by Szabolcs Nagy.  (CVE-2015-8778)
3041
3042 * The catopen function no longer has unbounded stack usage.  Reported by
3043   Max.  (CVE-2015-8779)
3044
3045 * The nan, nanf and nanl functions no longer have unbounded stack usage
3046   depending on the length of the string passed as an argument to the
3047   functions.  Reported by Joseph Myers.  (CVE-2014-9761)
3048
3049 * A stack-based buffer overflow was found in libresolv when invoked from
3050   libnss_dns, allowing specially crafted DNS responses to seize control
3051   of execution flow in the DNS client.  The buffer overflow occurs in
3052   the functions send_dg (send datagram) and send_vc (send TCP) for the
3053   NSS module libnss_dns.so.2 when calling getaddrinfo with AF_UNSPEC
3054   family.  The use of AF_UNSPEC triggers the low-level resolver code to
3055   send out two parallel queries for A and AAAA.  A mismanagement of the
3056   buffers used for those queries could result in the response of a query
3057   writing beyond the alloca allocated buffer created by
3058   _nss_dns_gethostbyname4_r.  Buffer management is simplified to remove
3059   the overflow.  Thanks to the Google Security Team and Red Hat for
3060   reporting the security impact of this issue, and Robert Holiday of
3061   Ciena for reporting the related bug 18665. (CVE-2015-7547)
3062
3063 The following bugs are resolved with this release:
3064
3065   [89] localedata: Locales nb_NO and nn_NO should transliterate æøå
3066   [887] math: Math library function "logb" and "nextafter" inconsistent
3067   [2542] math: Incorrect return from float gamma (-0X1.FA471547C2FE5P+1)
3068   [2543] math: Incorrect return from float gamma (-0X1.9260DCP+1)
3069   [2558] math: Incorrect return from double gamma (-0X1.FA471547C2FE5P+1)
3070   [2898] libc: [improve]  warning: the use  of `mktemp' is dangerous, better
3071     use `mkstemp'
3072   [4404] localedata: German translation of "Alarm clock" is misleading
3073   [6799] math: nextafter() and nexttoward() doen't set errno on
3074     overflow/underflow errors
3075   [6803] math: scalb(), scalbln(), scalbn() do not set errno on
3076     overflow/underflow
3077   [10432] nis: _nss_nis_setnetgrent assertion failure
3078   [11460] libc: fts has no LFS support
3079   [12926] network: getaddrinfo()/make_request() may spin forever
3080   [13065] nptl: Race condition in pthread barriers
3081   [13690] nptl: pthread_mutex_unlock potentially cause invalid access
3082   [14341] dynamic-link: Dynamic linker crash when DT_JMPREL and DT_REL{,A}
3083     are not contiguous
3084   [14551] math: [ldbl-128ibm] strtold overflow handling for IBM long double
3085   [14912] libc: Rename non-installed bits/*.h headers
3086   [15002] libc: Avoid undefined behavior in posix_fallocate overflow check
3087   [15367] math: Let gcc use __builtin_isinf
3088   [15384] math: One constant fewer in ieee754/dbl-64/wordsize-64/s_finite.c
3089   [15421] math: lgamma wrongly sets signgam for ISO C
3090   [15470] math: [arm] On ARM llrintl() and llroundl() do not raise
3091     FE_INVALID with argument out of range
3092   [15491] math: [i386/x86_64] x86 nearbyint implementations wrongly clear
3093     all exceptions
3094   [15786] dynamic-link: ifunc resolver functions can smash function
3095     arguments
3096   [15918] math: Unnecessary check for equality in hypotf()
3097   [16061] localedata: Review / update transliteration data
3098   [16068] math: [i386/x86_64] x86 and x86_64 fesetenv exclude state they
3099     should include
3100   [16141] time: strptime %z offset restriction
3101   [16171] math: drem should be alias of remainder
3102   [16296] math: fegetround is pure?
3103   [16347] math: [ldbl-128ibm] ldbl-128/e_lgammal_r.c may not be suitable.
3104   [16364] libc: sleep may leave SIGCHLD blocked on sync cancellation on
3105     GNU/Linux
3106   [16399] math: [mips] lrint / llrint / lround / llround missing exceptions
3107   [16415] math: Clean up ldbl-128 / ldbl-128ibm expm1l for large positive
3108     arguments
3109   [16422] math: [powerpc] math-float, math-double failing llrint tests with
3110     "Exception "Inexact" set" on ppc32
3111   [16495] localedata: nl_NL: date_fmt: shuffle year/month around
3112   [16517] math: Missing underflow exception from tanf/tan/tanl
3113   [16519] math: Missing underflow exception from sinhf
3114   [16520] math: Missing underflow exception from tanhf
3115   [16521] math: Missing underflow exception from exp2
3116   [16620] math: [ldbl-128ibm] exp10l spurious overflows / bad directed
3117     rounding results
3118   [16734] stdio: fopen calls mmap to allocate its buffer
3119   [16961] math: nan function incorrect handling of bad sequences
3120   [16962] math: nan function unbounded stack allocation (CVE-2014-9761)
3121   [16973] localedata: Fix lang_lib/lang_term as per ISO 639-2
3122   [16985] locale: localedef: confusing error message when opening output
3123     fails
3124   [17118] math: ctanh(INFINITY + 2 * I) returns incorrect value
3125   [17197] locale: Redundant shift character in iconv conversion output at
3126     block boundary
3127   [17243] libc: trunk/posix/execl.c:53: va_args problem ?
3128   [17244] libc: trunk/sysdeps/unix/sysv/linux/semctl.c:116: va_args muxup ?
3129   [17250] dynamic-link: static linking breaks nss loading
3130     (getaddrinfo/getpwnam/etc...)
3131   [17404] libc: atomic_exchange_rel lacking a barrier on MIPS16, GCC before
3132     4.7?
3133   [17441] math: isnan() should use __builtin_isnan() in GCC
3134   [17514] nptl: Assert failure unlocking ERRORCHECK mutex after timedlock
3135     (related to lock elision)
3136   [17787] manual: Exponent on page 324 of the PDF ends prematurely
3137   [17886] time: strptime should be able to parse "Z" as a timezone with %z
3138   [17887] time: strptime should be able to parse "+01:00" style timezones
3139   [17905] libc: catopen() Multiple unbounded stack allocations
3140     (CVE-2015-8779)
3141   [18084] libc: backtrace (..., 0) dumps core on x86
3142   [18086] libc: nice() sets errno to 0 on success
3143   [18240] libc: hcreate, hcreate_r should fail with ENOMEM if element count
3144     is too large (CVE-2015-8778)
3145   [18251] dynamic-link: SONAME missing when audit modules provides path
3146   [18265] libc: add attributes for wchar string and memory functions
3147   [18370] math: csqrt missing underflows
3148   [18421] libc: [hppa] read-only segment has dynamic relocations
3149   [18472] libc: Obsolete syscall wrappers should be compat symbols
3150   [18480] libc: hppa glibc miscompilation in sched_setaffinity()
3151   [18491] localedata: Update tr_TR LC_CTYPE as part of Unicode updates
3152   [18525] localedata: Remove locale timezone information
3153   [18560] libc: [powerpc] spurious bits/ipc.h definitions
3154   [18568] localedata: Update locale data to Unicode 8.0
3155   [18589] locale: sort-test.sh fails at random
3156   [18595] math: ctan, ctanh missing underflows
3157   [18604] libc: assert macro-expands its argument
3158   [18610] math: S390: fetestexcept() reports any exception if DXC-code
3159     contains a vector instruction exception.
3160   [18611] math: j1, jn missing errno setting on underflow
3161   [18618] localedata: sync Chechen locale definitions with other *_RU
3162     locales
3163   [18647] math: powf(-0x1.000002p0, 0x1p30) returns 0 instead of +inf
3164   [18661] libc: Some x86-64 assembly codes don't align stack to 16 bytes
3165   [18665] network: In send_dg, the recvfrom function is NOT always using the
3166     buffer size of a newly created buffer (CVE-2015-7547)
3167   [18674] libc: [i386] trunk/sysdeps/i386/tst-auditmod3b.c:84: possible
3168     missing break ?
3169   [18675] libc: fpathconf(_PC_NAME_MAX) fails against large filesystems for
3170     32bit processes
3171   [18681] libc: regexp.h is obsolete and buggy, and should be desupported
3172   [18699] math: tilegx cproj() for various complex infinities does not yield
3173     infinity
3174   [18724] libc: Harden put*ent functions against data injection
3175   [18743] nptl: PowerPC: findutils testcase fails with --enable-lock-elision
3176   [18755] build: build errors with -DNDEBUG
3177   [18757] stdio: fmemopen fails to set errno on failure
3178   [18778] dynamic-link: ld.so crashes if failed dlopen causes libpthread to
3179     be forced unloaded
3180   [18781] libc: openat64 lacks O_LARGEFILE
3181   [18787] libc: [hppa] sysdeps/unix/sysv/linux/hppa/bits/atomic.h:71:6:
3182     error: can’t find a register in class ‘R1_REGS’ while reloading ‘asm’
3183   [18789] math: [ldbl-128ibm] sinhl inaccurate near 0
3184   [18790] math: [ldbl-128ibm] tanhl inaccurate
3185   [18795] libc: stpncpy fortification misses buffer lengths that are
3186     statically too large
3187   [18796] build: build fails for --disable-mathvec
3188   [18803] math: hypot missing underflows
3189   [18820] stdio: fmemopen may leak memory on failure
3190   [18823] math: csqrt spurious underflows
3191   [18824] math: fma spurious underflows
3192   [18825] math: pow missing underflows
3193   [18857] math: [ldbl-128ibm] nearbyintl wrongly uses signaling comparisons
3194   [18868] nptl: pthread_barrier_init typo has in-theory-undefined behavior
3195   [18870] build: sem_open.c fails to compile with missing symbol
3196     FUTEX_SHARED
3197   [18872] stdio: Fix memory leak in printf_positional
3198   [18873] libc: posix_fallocate overflow check ineffective
3199   [18875] math: Excess precision leads incorrect libm
3200   [18877] libc: arm: mmap offset regression
3201   [18887] libc: memory corruption when using getmntent on blank lines
3202   [18918] localedata: hu_HU: change time to HH:MM:SS format
3203   [18921] libc: Regression: extraneous stat() and fstat() performed by
3204     opendir()
3205   [18928] dynamic-link: LD_POINTER_GUARD is not ignored for privileged
3206     binaries (CVE-2015-8777)
3207   [18951] math: tgamma missing underflows
3208   [18952] math: [ldbl-128/ldbl-128ibm] lgammal spurious "invalid", incorrect
3209     signgam
3210   [18953] localedata: lt_LT: change currency symbol to the euro
3211   [18956] math: powf inaccuracy
3212   [18961] math: [i386] exp missing underflows
3213   [18966] math: [i386] exp10 missing underflows
3214   [18967] math: math.h XSI POSIX namespace (gamma, isnan, scalb)
3215   [18969] build: multiple string test failures due to missing locale
3216     dependencies
3217   [18970] libc: Reference of pthread_setcancelstate in libc.a
3218   [18977] math: float / long double Bessel functions not in XSI POSIX
3219   [18980] math: i386 libm functions return with excess range and precision
3220   [18981] math: i386 scalb*, ldexp return with excess range and precision
3221   [18982] stdio: va_list and vprintf
3222   [18985] time: Passing out of range data to strftime() causes a segfault
3223     (CVE-2015-8776)
3224   [19003] math: [x86_64] fma4 version of pow inappropriate contraction
3225   [19007] libc: FAIL: elf/check-localplt with -z now and binutils 2.26
3226   [19012] locale: iconv_open leaks memory on error path
3227   [19016] math: clog, clog10 inaccuracy
3228   [19018] nptl: Mangle function pointers in tls_dtor_list
3229   [19032] math: [i386] acosh (-qNaN) spurious "invalid" exception
3230   [19046] math: ldbl-128 / ldbl-128ibm lgamma bad overflow handling
3231   [19048] malloc: malloc: arena free list can become cyclic, increasing
3232     contention
3233   [19049] math: [powerpc] erfc incorrect zero sign
3234   [19050] math: [powerpc] log* incorrect zero sign
3235   [19058] math: [x86_64] Link fail with -fopenmp and -flto
3236   [19059] math: nexttoward overflow incorrect in non-default rounding modes
3237   [19071] math: ldbl-96 lroundl incorrect just below powers of 2
3238   [19074] network: Data race in _res_hconf_reorder_addrs
3239   [19076] math: [ldbl-128ibm] log1pl (-1) wrong sign of infinity
3240   [19077] math: [ldbl-128ibm] logl (1) incorrect sign of zero result
3241   [19078] math: [ldbl-128ibm] expl overflow incorrect in non-default
3242     rounding modes
3243   [19079] math: dbl-64/wordsize-64 lround based on llround incorrect for
3244     ILP32
3245   [19085] math: ldbl-128 lrintl, lroundl missing exceptions for 32-bit long
3246   [19086] manual: posix_fallocate64 documented argument order is wrong.
3247   [19088] math: lround, llround missing exceptions close to overflow
3248     threshold
3249   [19094] math: lrint, llrint missing exceptions close to overflow threshold
3250   [19095] math: dbl-64 lrint incorrect for 64-bit long
3251   [19122] dynamic-link: Unnecessary PLT relocations in librtld.os
3252   [19124] dynamic-link: ld.so failed to build with older assmebler
3253   [19125] math: [powerpc32] llroundf, llround incorrect exceptions
3254   [19129] dynamic-link: [arm] Concurrent lazy TLSDESC resolution can crash
3255   [19134] math: [powerpc32] lround, lroundf spurious exceptions
3256   [19137] libc: i386/epoll_pwait.S doesn't support cancellation
3257   [19143] nptl: Remove CPU set size checking from sched_setaffinity,
3258     pthread_setaffinity_np
3259   [19156] math: [ldbl-128] j0l spurious underflows
3260   [19164] nptl: tst-getcpu fails with many possible CPUs
3261   [19168] math: math/test-ildoubl and math/test-ldouble failure
3262   [19174] nptl: PowerPC: TLE enabled pthread mutex performs poorly.
3263   [19178] dynamic-link: ELF_RTYPE_CLASS_EXTERN_PROTECTED_DATA confuses
3264     prelink
3265   [19181] math: [i386/x86_64] fesetenv (FE_DFL_ENV), fesetenv
3266     (FE_NOMASK_ENV) do not clear SSE exceptions
3267   [19182] malloc: malloc deadlock between ptmalloc_lock_all and
3268     _int_new_arena/reused_arena
3269   [19189] math: [ldbl-128] log1pl (-qNaN) spurious "invalid" exception
3270   [19201] math: dbl-64 remainder incorrect sign of zero result
3271   [19205] math: bits/math-finite.h conditions do not match math.h and
3272     bits/mathcalls.h
3273   [19209] math: bits/math-finite.h wrongly maps ldexp to scalbn
3274   [19211] math: lgamma functions do not set signgam for -ffinite-math-only
3275     for C99-based standards
3276   [19212] libc: features.h not -Wundef clean
3277   [19213] math: [i386/x86_64] log* (1) incorrect zero sign for -ffinite-
3278     math-only
3279   [19214] libc: Family and model identification for AMD CPU's are incorrect.
3280   [19219] libc: GLIBC build fails for ia64 with missing __nearbyintl
3281   [19228] math: [powerpc] nearbyint wrongly clears "inexact", leaves traps
3282     disabled
3283   [19235] math: [powerpc64] lround, lroundf, llround, llroundf spurious
3284     "inexact" exceptions
3285   [19238] math: [powerpc] round, roundf spurious "inexact" for integer
3286     arguments
3287   [19242] libc: strtol incorrect in Turkish locales
3288   [19243] malloc: reused_arena can pick an arena on the free list, leading
3289     to an assertion failure and reference count corruption
3290   [19253] time: tzset() ineffective when temporary TZ did not include DST
3291     rules
3292   [19266] math: strtod ("NAN(I)") incorrect in Turkish locales
3293   [19270] math: [hppa] Shared libm missing __isnanl
3294   [19285] libc: [hppa] sysdeps/unix/sysv/linux/hppa/bits/mman.h: missing
3295     MAP_HUGETLB and MAP_STACK defines
3296   [19313] nptl: Wrong __cpu_mask for x32
3297   [19347] libc: grantpt: try to force a specific gid even without pt_chown
3298   [19349] math: [ldbl-128ibm] tanhl inaccurate for small arguments
3299   [19350] math: [ldbl-128ibm] sinhl spurious overflows
3300   [19351] math: [ldbl-128ibm] logl inaccurate near 1
3301   [19363] time: x32: times() return value wrongly truncates/sign extends
3302     from 32bit
3303   [19367] dynamic-link: Improve branch prediction on Silvermont
3304   [19369] network: Default domain name not reset by res_ninit when "search"
3305     / "domain" entry is removed from resolv.conf
3306   [19375] math: powerpc: incorrect results for POWER7 logb with negative
3307     subnormals
3308   [19385] localedata: bg_BG: time separator should be colon, not comma
3309   [19408] libc: linux personality syscall wrapper may erroneously return an
3310     error on 32-bit architectures
3311   [19415] libc: dladdr returns wrong names on hppa
3312   [19432] libc: iconv rejects redundant escape sequences in IBM900, IBM903,
3313     IBM905, IBM907, and IBM909
3314   [19439] math: Unix98 isinf and isnan functions conflict with C++11
3315   [19443] build: build failures with -DDEBUG
3316   [19451] build: Make check fails on test-double-vlen2
3317   [19462] libc: Glibc failed to build with -Os
3318   [19465] math: Wrong code with -Os
3319   [19466] time: time/tst-mktime2.c is compiled into an infinite loop with
3320     -Os
3321   [19467] string: Fast_Unaligned_Load needs to be enabled for Excavator core
3322     CPU's.
3323   [19475] libc: Glibc 2.22 doesn't build on sparc [PATCH]
3324   [19486] math: S390: Math tests fail with "Exception Inexact set".
3325   [19529] libc: [ARM]: FAIL: stdlib/tst-makecontext
3326   [19550] libc: [mips] mmap negative offset handling inconsistent with other
3327     architectures
3328   [19590] math: Fail to build shared objects that use libmvec.so functions.
3329 \f
3330 Version 2.22
3331
3332 * The following bugs are resolved with this release:
3333
3334   438, 2981, 4719, 6544, 6792, 11216, 12836, 13028, 13064, 13151, 13152,
3335   14094, 14113, 14292, 14841, 14906, 14958, 15319, 15467, 15790, 15969,
3336   16159, 16339, 16350, 16351, 16352, 16353, 16361, 16512, 16526, 16538,
3337   16559, 16560, 16704, 16783, 16850, 17053, 17090, 17195, 17269, 17293,
3338   17322, 17403, 17475, 17523, 17542, 17569, 17581, 17588, 17596, 17620,
3339   17621, 17628, 17631, 17692, 17711, 17715, 17776, 17779, 17792, 17833,
3340   17836, 17841, 17912, 17916, 17930, 17932, 17944, 17949, 17964, 17965,
3341   17967, 17969, 17977, 17978, 17987, 17991, 17996, 17998, 17999, 18007,
3342   18019, 18020, 18029, 18030, 18032, 18034, 18036, 18038, 18039, 18042,
3343   18043, 18046, 18047, 18049, 18068, 18078, 18080, 18093, 18100, 18104,
3344   18110, 18111, 18116, 18125, 18128, 18134, 18138, 18185, 18196, 18197,
3345   18206, 18210, 18211, 18217, 18219, 18220, 18221, 18234, 18244, 18245,
3346   18247, 18287, 18319, 18324, 18333, 18346, 18371, 18383, 18397, 18400,
3347   18409, 18410, 18412, 18418, 18422, 18434, 18444, 18457, 18468, 18469,
3348   18470, 18479, 18483, 18495, 18496, 18497, 18498, 18502, 18507, 18508,
3349   18512, 18513, 18519, 18520, 18522, 18527, 18528, 18529, 18530, 18532,
3350   18533, 18534, 18536, 18539, 18540, 18542, 18544, 18545, 18546, 18547,
3351   18549, 18553, 18557, 18558, 18569, 18583, 18585, 18586, 18592, 18593,
3352   18594, 18602, 18612, 18613, 18619, 18633, 18635, 18641, 18643, 18648,
3353   18657, 18676, 18694, 18696, 18887.
3354
3355 * Cache information can be queried via sysconf() function on s390 e.g. with
3356   _SC_LEVEL1_ICACHE_SIZE as argument.
3357
3358 * A buffer overflow in gethostbyname_r and related functions performing DNS
3359   requests has been fixed.  If the NSS functions were called with a
3360   misaligned buffer, the buffer length change due to pointer alignment was
3361   not taken into account.  This could result in application crashes or,
3362   potentially arbitrary code execution, using crafted, but syntactically
3363   valid DNS responses.  (CVE-2015-1781)
3364
3365 * The time zone file parser has been made more robust against crafted time
3366   zone files, avoiding heap buffer overflows related to the processing of
3367   the tzh_ttisstdcnt and tzh_ttisgmtcnt fields, and a stack overflow due to
3368   large time zone data files.  Overly long time zone specifiers in the TZ
3369   variable no longer result in stack overflows and crashes.
3370
3371 * A powerpc and powerpc64 optimization for TLS, similar to TLS descriptors
3372   for LD and GD on x86 and x86-64, has been implemented.  You will need
3373   binutils-2.24 or later to enable this optimization.
3374
3375 * Character encoding and ctype tables were updated to Unicode 7.0.0, using
3376   new generator scripts contributed by Pravin Satpute and Mike FABIAN (Red
3377   Hat).  These updates cause user visible changes, such as the fix for bug
3378   17998.
3379
3380 * CVE-2014-8121 The NSS backends shared internal state between the getXXent
3381   and getXXbyYY NSS calls for the same database, causing a denial-of-service
3382   condition in some applications.
3383
3384 * Added vector math library named libmvec with the following vectorized x86_64
3385   implementations: cos, cosf, sin, sinf, sincos, sincosf, log, logf, exp, expf,
3386   pow, powf.
3387   The library can be disabled with --disable-mathvec. Use of the functions is
3388   enabled with -fopenmp -ffast-math starting from -O1 for GCC version >= 4.9.0.
3389   Shared library libmvec.so is linked in as needed when using -lm (no need to
3390   specify -lmvec explicitly for not static builds).
3391   Visit <https://sourceware.org/glibc/wiki/libmvec> for detailed information.
3392
3393 * A new fmemopen implementation has been added with the goal of POSIX
3394   compliance. The new implementation fixes the following long-standing
3395   issues: BZ#6544, BZ#11216, BZ#12836, BZ#13151, BZ#13152, and BZ#14292. The
3396   old implementation is still present for use be by existing binaries.
3397
3398 * The 32-bit sparc sigaction ABI was inadvertently broken in the 2.20 and 2.21
3399   releases.  It has been fixed to match 2.19 and older, but binaries built
3400   against 2.20 and 2.21 might need to be recompiled.  See BZ#18694.
3401
3402 * Port to Native Client running on ARMv7-A (--host=arm-nacl).
3403   Contributed by Roland McGrath (Google).
3404
3405 * The header <regexp.h> is deprecated, and will be removed in a future
3406   release.  Use of this header will trigger a deprecation warning.
3407   Application developers should update their code to use <regex.h> instead.
3408
3409   This header was formerly part of SUS, but was deprecated in 1994 and
3410   removed from the standard in 2001.  Also, the glibc implementation
3411   leaks memory.  See BZ#18681 for more details.
3412 \f
3413 Version 2.21
3414
3415 * The following bugs are resolved with this release:
3416
3417   6652, 10672, 12674, 12847, 12926, 13862, 14132, 14138, 14171, 14498,
3418   15215, 15378, 15884, 16009, 16418, 16191, 16469, 16576, 16617, 16618,
3419   16619, 16657, 16740, 16857, 17192, 17266, 17273, 17344, 17363, 17370,
3420   17371, 17411, 17460, 17475, 17485, 17501, 17506, 17508, 17522, 17555,
3421   17570, 17571, 17572, 17573, 17574, 17582, 17583, 17584, 17585, 17589,
3422   17594, 17601, 17608, 17616, 17625, 17630, 17633, 17634, 17635, 17647,
3423   17653, 17657, 17658, 17664, 17665, 17668, 17682, 17702, 17717, 17719,
3424   17722, 17723, 17724, 17725, 17732, 17733, 17744, 17745, 17746, 17747,
3425   17748, 17775, 17777, 17780, 17781, 17782, 17791, 17793, 17796, 17797,
3426   17801, 17803, 17806, 17834, 17844, 17848, 17868, 17869, 17870, 17885,
3427   17892.
3428
3429 * CVE-2015-1472 CVE-2015-1473 Under certain conditions wscanf can allocate
3430   too little memory for the to-be-scanned arguments and overflow the
3431   allocated buffer.  The implementation now correctly computes the required
3432   buffer size when using malloc, and switches to malloc from alloca as
3433   intended.
3434
3435 * A new semaphore algorithm has been implemented in generic C code for all
3436   machines. Previous custom assembly implementations of semaphore were
3437   difficult to reason about or ensure that they were safe. The new version
3438   of semaphore supports machines with 64-bit or 32-bit atomic operations.
3439   The new semaphore algorithm is used by sem_init, sem_open, sem_post,
3440   sem_wait, sem_timedwait, sem_trywait, and sem_getvalue.
3441
3442 * Port to Altera Nios II has been contributed by Mentor Graphics.
3443
3444 * Optimized strcpy, stpcpy, strncpy, stpncpy, strcmp, and strncmp
3445   implementations for powerpc64/powerpc64le.
3446   Implemented by Adhemerval Zanella (IBM).
3447
3448 * Added support for TSX lock elision of pthread mutexes on powerpc32, powerpc64
3449   and powerpc64le.  This may improve lock scaling of existing programs on
3450   HTM capable systems.  The lock elision code is only enabled with
3451   --enable-lock-elision=yes.  Also, the TSX lock elision implementation for
3452   powerpc will issue a transaction abort on every syscall to avoid side
3453   effects being visible outside transactions.
3454
3455 * Optimized strcpy, stpcpy, strchrnul and strrchr implementations for
3456   AArch64.  Contributed by ARM Ltd.
3457
3458 * i386 memcpy functions optimized with SSE2 unaligned load/store.
3459
3460 * CVE-2104-7817 The wordexp function could ignore the WRDE_NOCMD flag
3461   under certain input conditions resulting in the execution of a shell for
3462   command substitution when the application did not request it. The
3463   implementation now checks WRDE_NOCMD immediately before executing the
3464   shell and returns the error WRDE_CMDSUB as expected.
3465
3466 * CVE-2012-3406 printf-style functions could run into a stack overflow when
3467   processing format strings with a large number of format specifiers.
3468
3469 * CVE-2014-9402 The nss_dns implementation of getnetbyname could run into an
3470   infinite loop if the DNS response contained a PTR record of an unexpected
3471   format.
3472
3473 * The minimum GCC version that can be used to build this version of the GNU
3474   C Library is GCC 4.6.  Older GCC versions, and non-GNU compilers, can
3475   still be used to compile programs using the GNU C Library.
3476
3477 * The GNU C Library is now built with -Werror by default.  This can be
3478   disabled by configuring with --disable-werror.
3479
3480 * New locales: tu_IN, bh_IN, raj_IN, ce_RU.
3481
3482 * The obsolete sigvec function has been removed.  This was the original
3483   4.2BSD interface that inspired the POSIX.1 sigaction interface, which
3484   programs have been using instead for about 25 years.  Of course, ABI
3485   compatibility for old binaries using sigvec remains intact.
3486
3487 * Merged gettext 0.19.3 into the intl subdirectory.  This fixes building
3488   with newer versions of bison.
3489
3490 * Support for MIPS o32 FPXX, FP64A and FP64 ABI Extensions.
3491   The original MIPS o32 hard-float ABI requires an FPU where double-precision
3492   registers overlay two consecutive single-precision registers.  MIPS32R2
3493   introduced a new FPU mode (FR=1) where double-precision registers extend the
3494   corresponding single-precision registers which is incompatible with the
3495   o32 hard-float ABI.  The MIPS SIMD ASE and the MIPSR6 architecture both
3496   require the use of FR=1 making a transition necessary.  New o32 ABI
3497   extensions enable users to migrate over time from the original o32 ABI
3498   through to the updated o32 FP64 ABI.  To achieve this the dynamic linker now
3499   tracks the ABI of any loaded object and verifies that new objects are
3500   compatible.  Mode transitions will also be requested as required and
3501   unsupportable objects will be rejected.  The ABI checks include both soft and
3502   hard float ABIs for o32, n32 and n64.
3503
3504   GCC 5 with GNU binutils 2.25 onwards:
3505   It is strongly recommended that all o32 system libraries are built using the
3506   new o32 FPXX ABI (-mfpxx) to facilitate the transition as this is compatible
3507   with the original and all new o32 ABI extensions.  Configure a MIPS GCC
3508   compiler using --with-fp-32=xx to set this by default.
3509 \f
3510 Version 2.20
3511
3512 * The following bugs are resolved with this release:
3513
3514   6804, 9894, 11505, 12994, 13347, 13651, 14308, 14770, 15119, 15132, 15347,
3515   15514, 15698, 15804, 15894, 15946, 16002, 16064, 16095, 16194, 16198,
3516   16275, 16284, 16287, 16315, 16348, 16349, 16354, 16357, 16362, 16447,
3517   16516, 16532, 16539, 16545, 16561, 16562, 16564, 16574, 16599, 16600,
3518   16609, 16610, 16611, 16613, 16619, 16623, 16629, 16632, 16634, 16639,
3519   16642, 16648, 16649, 16670, 16674, 16677, 16680, 16681, 16683, 16689,
3520   16695, 16701, 16706, 16707, 16712, 16713, 16714, 16724, 16731, 16739,
3521   16740, 16743, 16754, 16758, 16759, 16760, 16770, 16786, 16789, 16791,
3522   16796, 16799, 16800, 16815, 16823, 16824, 16831, 16838, 16839, 16849,
3523   16854, 16876, 16877, 16878, 16882, 16885, 16888, 16890, 16892, 16912,
3524   16915, 16916, 16917, 16918, 16922, 16927, 16928, 16932, 16943, 16958,
3525   16965, 16966, 16967, 16977, 16978, 16984, 16990, 16996, 17009, 17022,
3526   17031, 17042, 17048, 17050, 17058, 17061, 17062, 17069, 17075, 17078,
3527   17079, 17084, 17086, 17088, 17092, 17097, 17125, 17135, 17137, 17150,
3528   17153, 17187, 17213, 17259, 17261, 17262, 17263, 17319, 17325, 17354.
3529
3530 * Reverted change of ABI data structures for s390 and s390x:
3531   On s390 and s390x the size of struct ucontext and jmp_buf was increased in
3532   2.19. This change is reverted in 2.20. The introduced 2.19 symbol versions
3533   of getcontext, setjmp, _setjmp, __sigsetjmp, longjmp, _longjmp, siglongjmp
3534   are preserved pointing straight to the same implementation as the old ones.
3535   Given that, new callers will simply provide a too-big buffer to these
3536   functions. Any applications/libraries out there that embed jmp_buf or
3537   ucontext_t in an ABI-relevant data structure that have already been rebuilt
3538   against 2.19 headers will have to rebuilt again. This is necessary in any
3539   case to revert the breakage in their ABI caused by the glibc change.
3540
3541 * Support for file description locks is added to systems running the
3542   Linux kernel. The standard file locking interfaces are extended to
3543   operate on file descriptions, not file descriptors, via the use of
3544   F_OFD_GETLK, F_OFD_SETLK, and F_OFD_SETLKW. File description locks
3545   are associated with an open file instead of a process.
3546
3547 * Optimized strchr implementation for AArch64.  Contributed by ARM Ltd.
3548
3549 * The minimum Linux kernel version that this version of the GNU C Library
3550   can be used with is 2.6.32.
3551
3552 * Running the testsuite no longer terminates as soon as a test fails.
3553   Instead, a file tests.sum (xtests.sum from "make xcheck") is generated,
3554   with PASS or FAIL lines for individual tests.  A summary of the results is
3555   printed, including a list of failing lists, and "make check" exits with
3556   error status if there were any unexpected failures.  "make check
3557   stop-on-test-failure=y" may be used to keep the old behavior.
3558
3559 * The am33 port, which had not worked for several years, has been removed
3560   from ports.
3561
3562 * The _BSD_SOURCE and _SVID_SOURCE feature test macros are no longer
3563   supported; they now act the same as _DEFAULT_SOURCE (but generate a
3564   warning).  Except for cases where _BSD_SOURCE enabled BSD interfaces that
3565   conflicted with POSIX (support for which was removed in 2.19), the
3566   interfaces those macros enabled remain available when compiling with
3567   _GNU_SOURCE defined, with _DEFAULT_SOURCE defined, or without any feature
3568   test macros defined.
3569
3570 * Optimized strcmp implementation for ARMv7.  Contributed by ARM Ltd.
3571
3572 * Added support for TX lock elision of pthread mutexes on s390 and s390x.
3573   This may improve lock scaling of existing programs on TX capable systems.
3574   The lock elision code is only built with --enable-lock-elision=yes and
3575   then requires a GCC version supporting the TX builtins.  With lock elision
3576   default mutexes are elided via __builtin_tbegin, if the cpu supports
3577   transactions. By default lock elision is not enabled and the elision code
3578   is not built.
3579
3580 * CVE-2014-4043 The posix_spawn_file_actions_addopen implementation did not
3581   copy the path argument.  This allowed programs to cause posix_spawn to
3582   deference a dangling pointer, or use an unexpected pathname argument if
3583   the string was modified after the posix_spawn_file_actions_addopen
3584   invocation.
3585
3586 * All supported architectures now use the main glibc sysdeps directory
3587   instead of some being in a separate "ports" directory (which was
3588   distributed separately before glibc 2.17).
3589
3590 * The NPTL implementation of POSIX pthreads is no longer an "add-on".
3591   On configurations that support it (all Linux configurations), it's now
3592   used regardless of the --enable-add-ons switch to configure.  It is no
3593   longer possible to build such configurations without pthreads support.
3594
3595 * Locale names, including those obtained from environment variables (LANG
3596   and the LC_* variables), are more tightly checked for proper syntax.
3597   setlocale will now fail (with EINVAL) for locale names that are overly
3598   long, contain slashes without starting with a slash, or contain ".." path
3599   components. (CVE-2014-0475)  Previously, some valid locale names were
3600   silently replaced with the "C" locale when running in AT_SECURE mode
3601   (e.g., in a SUID program).  This is no longer necessary because of the
3602   additional checks.
3603
3604 * On x86-64, the dynamic linker's lazy-binding support is now compatible
3605   with application code using Intel MPX instructions.  (With all previous
3606   versions, the MPX register state could be clobbered when making calls
3607   into or out of a shared library.)  Note that while the new dynamic
3608   linker is compatible with all known x86 hardware whether or not it
3609   supports Intel MPX, some x86 instruction-set emulators might fail to
3610   handle the new instruction encodings.  This is known to affect Valgrind
3611   versions up through 3.9 (but will be fixed in the forthcoming 3.10
3612   release), and might affect other tools that do instruction emulation.
3613
3614 * Support for loadable gconv transliteration modules has been removed.
3615   The support for transliteration modules has been non-functional for
3616   over a decade, and the removal is prompted by security defects.  The
3617   normal gconv conversion modules are still supported.  Transliteration
3618   with //TRANSLIT is still possible, and the //IGNORE specifier
3619   continues to be  supported. (CVE-2014-5119)
3620
3621 * Decoding a crafted input sequence in the character sets IBM933, IBM935,
3622   IBM937, IBM939, IBM1364 could result in an out-of-bounds array read,
3623   resulting a denial-of-service security vulnerability in applications which
3624   use functions related to iconv. (CVE-2014-6040)
3625 \f
3626 Version 2.19
3627
3628 * The following bugs are resolved with this release:
3629
3630   156, 387, 431, 762, 832, 926, 2801, 4772, 6786, 6787, 6807, 6810, 6981,
3631   7003, 9721, 9954, 10253, 10278, 11087, 11157, 11214, 12100, 12486, 12751,
3632   12986, 13028, 13982, 13985, 14029, 14032, 14120, 14143, 14155, 14286,
3633   14547, 14699, 14752, 14782, 14876, 14910, 15004, 15048, 15073, 15089,
3634   15128, 15218, 15268, 15277, 15308, 15362, 15374, 15400, 15425, 15427,
3635   15483, 15522, 15531, 15532, 15593, 15601, 15608, 15609, 15610, 15632,
3636   15640, 15670, 15672, 15680, 15681, 15723, 15734, 15735, 15736, 15748,
3637   15749, 15754, 15760, 15763, 15764, 15797, 15799, 15825, 15843, 15844,
3638   15846, 15847, 15849, 15850, 15855, 15856, 15857, 15859, 15867, 15886,
3639   15887, 15890, 15892, 15893, 15895, 15897, 15901, 15905, 15909, 15915,
3640   15917, 15919, 15921, 15923, 15939, 15941, 15948, 15963, 15966, 15968,
3641   15985, 15988, 15997, 16032, 16034, 16036, 16037, 16038, 16041, 16046,
3642   16055, 16071, 16072, 16074, 16077, 16078, 16103, 16112, 16143, 16144,
3643   16146, 16150, 16151, 16153, 16167, 16169, 16172, 16195, 16214, 16245,
3644   16271, 16274, 16283, 16289, 16293, 16314, 16316, 16330, 16337, 16338,
3645   16356, 16365, 16366, 16369, 16372, 16375, 16379, 16381, 16384, 16385,
3646   16386, 16387, 16390, 16394, 16398, 16400, 16407, 16408, 16414, 16430,
3647   16431, 16453, 16474, 16506, 16510, 16529
3648
3649 * Slovenian translations for glibc messages have been contributed by the
3650   Translation Project's Slovenian team of translators.
3651
3652 * The public headers no longer use __unused nor __block.  This change is to
3653   support compiling programs that are derived from BSD sources and use
3654   __unused internally, and to support compiling with Clang's -fblock
3655   extension which uses __block.
3656
3657 * CVE-2012-4412 The strcoll implementation caches indices and rules for
3658   large collation sequences to optimize multiple passes.  This cache
3659   computation may overflow for large collation sequences and may cause a
3660   stack or buffer overflow.  This is now fixed to use a slower algorithm
3661   which does not use a cache if there is an integer overflow.
3662
3663 * CVE-2012-4424 The strcoll implementation uses malloc to cache indices and
3664   rules for large collation sequences to optimize multiple passes and falls
3665   back to alloca if malloc fails, resulting in a possible stack overflow.
3666   The implementation now falls back to an uncached collation sequence lookup
3667   if malloc fails.
3668
3669 * CVE-2013-4788 The pointer guard used for pointer mangling was not
3670   initialized for static applications resulting in the security feature
3671   being disabled. The pointer guard is now correctly initialized to a
3672   random value for static applications. Existing static applications need
3673   to be recompiled to take advantage of the fix (bug 15754).
3674
3675 * CVE-2013-4237 The readdir_r function could write more than NAME_MAX bytes
3676   to the d_name member of struct dirent, or omit the terminating NUL
3677   character.  (Bugzilla #14699).
3678
3679 * CVE-2013-4332 The pvalloc, valloc, memalign, posix_memalign and
3680   aligned_alloc functions could allocate too few bytes or corrupt the
3681   heap when passed very large allocation size values (Bugzilla #15855,
3682   #15856, #15857).
3683
3684 * CVE-2013-4458 Stack overflow in getaddrinfo with large number of results
3685   for AF_INET6 has been fixed (Bugzilla #16072).
3686
3687 * New locales: ak_GH, anp_IN, ar_SS, cmn_TW, hak_TW, lzh_TW, nan_TW, pap_AW,
3688   pap_CW, quz_PE, the_NP.
3689
3690 * Substantially revised locales: gd_GB, ht_HT
3691
3692 * The LC_ADDRESS field was updated to support country_car for almost all
3693   supported locales.
3694
3695 * ISO 1427 definitions were updated.
3696
3697 * ISO 3166 definitions were updated.
3698
3699 * The localedef utility now supports --big-endian and --little-endian
3700   command-line options to generate locales for a different system from that
3701   for which the C library was built.
3702
3703 * Binary locale files now only depend on the endianness of the system for
3704   which they are generated and not on other properties of that system.  As a
3705   consequence, binary files generated with new localedef may be incompatible
3706   with old versions of the GNU C Library, and binary files generated with
3707   old localedef may be incompatible with this version of the GNU C Library,
3708   in the following circumstances:
3709
3710   + Locale files may be incompatible on m68k systems.
3711
3712   + Locale archive files (but not separate files for individual locales) may
3713     be incompatible on systems where plain "char" is signed.
3714
3715 * The configure option --disable-versioning has been removed.  Builds with
3716   --disable-versioning had not worked for several years.
3717
3718 * ISO 639 definitions were updated for Chiga (cgg) and Chinese (gan, hak, czh,
3719   cjy, lzh, cmn, mnp, cdo, czo, cpx, wuu, hsn, yue).
3720
3721 * SystemTap probes for malloc have been introduced.
3722
3723 * SystemTap probes for slow multiple precision fallback paths of
3724   transcendental functions have been introduced.
3725
3726 * Support for powerpc64le has been added.
3727
3728 * The soft-float powerpc port now supports e500 processors.
3729
3730 * Support for STT_GNU_IFUNC symbols added for ppc32/power4+ and ppc64.
3731
3732 * A new feature test macro _DEFAULT_SOURCE is available to enable the same
3733   set of header declarations that are enabled by default, even when other
3734   feature test macros or compiler options such as -std=c99 would otherwise
3735   disable some of those declarations.
3736
3737 * The _BSD_SOURCE feature test macro no longer enables BSD interfaces that
3738   conflict with POSIX.  The libbsd-compat library (which was a dummy library
3739   that did nothing) has also been removed.
3740
3741 * Preliminary documentation about Multi-Thread, Async-Signal and
3742   Async-Cancel Safety has been added.
3743
3744 * Change of ABI data structures for s390 and s390x:
3745   On s390 and s390x the size of struct ucontext and jmp_buf was increased to
3746   allow for future hardware extensions. All library functions that accept or
3747   return these structures were versioned in order to provide backwards
3748   compatibility with existing code. However, not all cases can be handled
3749   with interface versioning. If an application embeds either structure into
3750   another structure and that structure is passed to another compilation unit
3751   which expects the newer larger-sized object then any access to the new
3752   fields will result in undefined behaviour. Similarly any access to fields
3753   that were moved by the enlarging of the structures will cause undefined
3754   behaviour. To fix the undefined behaviour all objects that are part of the
3755   final in-memory image must agree on the size of structures, and this may
3756   require recompilation.
3757 \f
3758 Version 2.18
3759
3760 * The following bugs are resolved with this release:
3761
3762   2546, 2560, 5159, 6809, 7006, 10060, 10062, 10283, 10357, 10686, 11120,
3763   11561, 12310, 12387, 12492, 12515, 12723, 13550, 13889, 13951, 13988,
3764   14142, 14176, 14200, 14256, 14280, 14293, 14317, 14327, 14478, 14496,
3765   14582, 14686, 14812, 14888, 14894, 14907, 14908, 14909, 14920, 14941,
3766   14952, 14964, 14981, 14982, 14985, 14991, 14994, 14996, 15000, 15003,
3767   15006, 15007, 15014, 15020, 15022, 15023, 15036, 15054, 15055, 15062,
3768   15078, 15084, 15085, 15086, 15100, 15160, 15214, 15221, 15232, 15234,
3769   15283, 15285, 15287, 15304, 15305, 15307, 15309, 15327, 15330, 15335,
3770   15336, 15337, 15339, 15342, 15346, 15359, 15361, 15366, 15380, 15381,
3771   15394, 15395, 15405, 15406, 15409, 15416, 15418, 15419, 15423, 15424,
3772   15426, 15429, 15431, 15432, 15441, 15442, 15448, 15465, 15480, 15485,
3773   15488, 15490, 15492, 15493, 15497, 15506, 15529, 15536, 15553, 15577,
3774   15583, 15618, 15627, 15631, 15654, 15655, 15666, 15667, 15674, 15711,
3775   15755, 15759.
3776
3777 * CVE-2013-2207 Incorrectly granting access to another user's pseudo-terminal
3778   has been fixed by disabling the use of pt_chown (Bugzilla #15755).
3779   Distributions can re-enable building and using pt_chown via the new configure
3780   option `--enable-pt_chown'.  Enabling the use of pt_chown carries with it
3781   considerable security risks and should only be used if the distribution
3782   understands and accepts the risks.
3783
3784 * CVE-2013-0242 Buffer overrun in regexp matcher has been fixed (Bugzilla
3785   #15078).
3786
3787 * CVE-2013-1914 Stack overflow in getaddrinfo with many results has been
3788   fixed (Bugzilla #15330).
3789
3790 * Add support for calling C++11 thread_local object destructors on thread
3791   and program exit.  This needs compiler support for offloading C++11
3792   destructor calls to glibc.
3793
3794 * Improved worst case performance of libm functions with double inputs and
3795   output.
3796
3797 * Support for priority inherited mutexes in pthread condition variables on
3798   non-x86 architectures.
3799
3800 * Port to Xilinx MicroBlaze contributed by David Holsgrove.
3801
3802 * Optimized string functions for AArch64.  Implemented by Marcus Shawcroft.
3803
3804 * Optimized string functions for ARM.  Implemented by Will Newton and
3805   Richard Henderson.
3806
3807 * Optimized libm functions for SPARC.  Implemented by David S. Miller.
3808
3809 * Support for building more of ARM glibc as Thumb-2 code.  Implemented by
3810   Richard Henderson.
3811
3812 * Support for building most of MIPS glibc as MIPS16 code.  Implemented by
3813   Chung-Lin Tang, Maciej W. Rozycki and Maxim Kuvyrkov.
3814
3815 * Added a benchmark framework to track performance of functions in glibc.
3816
3817 * New <math.h> macro named issignaling to check for a signaling NaN (sNaN).
3818   It is based on draft TS 18661 and currently enabled as a GNU extension.
3819
3820 * On Linux, the clock function now uses the clock_gettime system call
3821   for improved precision, rather than old times system call.
3822
3823 * Added support for version-3 tz format files.  This is needed when using
3824   the tz database release 2013e or later, and affects a few unusual cases --
3825   currently only TZ='America/Godthab' for time stamps after 2037.
3826
3827 * Added new API functions pthread_getattr_default_np and
3828   pthread_setattr_default_np to get and set the default pthread
3829   attributes of a process.
3830
3831 * Added support for TSX lock elision for pthread mutexes on i386 and x86-64.
3832   This may improve lock scaling of existing programs on TSX capable systems.
3833   When the --enable-lock-elision=yes parameter is specified at configure
3834   time lock elision will be enabled by default for all PTHREAD_MUTEX_DEFAULT
3835   mutexes.
3836
3837 * Support added for AT_HWCAP2 (to coincide with Linux kernel 3.10
3838   availability).  Implemented by Ryan S. Arnold.
3839
3840 * Support added for POWER8 platform.  Implemented by Ryan S. Arnold.
3841 \f
3842 Version 2.17
3843
3844 * The following bugs are resolved with this release:
3845
3846   1349, 3439, 3479, 3665, 5044, 5246, 5298, 5400, 6530, 6677, 6778, 6808,
3847   9685, 9914, 10014, 10038, 10114, 10191, 10631, 10873, 11438, 11607, 11638,
3848   11741, 12140, 13013, 13412, 13542, 13601, 13603, 13604, 13629, 13679,
3849   13696, 13698, 13717, 13741, 13759, 13761, 13763, 13881, 13939, 13950,
3850   13952, 13966, 14042, 14047, 14090, 14150, 14151, 14152, 14154, 14157,
3851   14166, 14173, 14195, 14197, 14237, 14246, 14251, 14252, 14283, 14298,
3852   14303, 14307, 14328, 14331, 14336, 14337, 14347, 14349, 14368, 14376,
3853   14417, 14447, 14459, 14476, 14477, 14501, 14505, 14510, 14516, 14518,
3854   14519, 14530, 14532, 14538, 14543, 14544, 14545, 14557, 14562, 14568,
3855   14576, 14579, 14583, 14587, 14595, 14602, 14610, 14621, 14638, 14645,
3856   14648, 14652, 14660, 14661, 14669, 14672, 14683, 14694, 14716, 14719,
3857   14743, 14767, 14783, 14784, 14785, 14793, 14796, 14797, 14801, 14803,
3858   14805, 14807, 14811, 14815, 14821, 14822, 14824, 14828, 14831, 14833,
3859   14835, 14838, 14856, 14863, 14865, 14866, 14868, 14869, 14871, 14872,
3860   14879, 14889, 14893, 14898, 14914.
3861
3862 * Optimization of memcpy for MIPS.
3863
3864 * CVE-2011-4609 svc_run() produces high cpu usage when accept fails with
3865   EMFILE has been fixed (Bugzilla #14889).
3866
3867 * The add-on ports collection is now distributed in the "ports" subdirectory
3868   of the main GNU C Library distribution, rather than separately.
3869
3870 * Port to ARM AArch64 contributed by Linaro.
3871
3872 * Support for STT_GNU_IFUNC symbols added for s390 and s390x.
3873   Optimized versions of memcpy, memset, and memcmp added for System z10 and
3874   zEnterprise z196.
3875   Implemented by Andreas Krebbel.
3876
3877 * The new function secure_getenv allows secure access to the environment,
3878   returning NULL if running in a SUID/SGID process.  This function replaces
3879   the internal function __secure_getenv.
3880
3881 * SystemTap static probes have been added into the dynamic linker.
3882   Implemented by Gary Benson.
3883
3884 * Optimizations of string functions strstr, strcasestr and memmem.
3885   Implemented by Maxim Kuvyrkov.
3886
3887 * The minimum Linux kernel version that this version of the GNU C Library
3888   can be used with is 2.6.16.
3889
3890 * Optimizations of string functions memchr, wcschr, wcscpy, and wcsrchr for
3891   powerpc POWER7.  Implemented by Will Schmidt.
3892
3893 * New configure option --disable-nscd builds the C library such that it
3894   never attempts to contact the Name Service Caching Daemon (nscd).
3895   New configure option --disable-build-nscd avoids building nscd itself;
3896   this is the default if --disable-nscd is used.
3897
3898 * Improved support for cross-compilation, including cross-testing and
3899   bootstrap builds without a previously built glibc.
3900
3901 * Several testsuite tests are now able to test multiple IFUNC variants of an
3902   interface, rather than just testing the one that would be chooen by
3903   default.
3904
3905 * New configure options --with-bugurl and --with-pkgversion, for
3906   distributors to use to embed their bug-reporting and package version
3907   information in --help and --version output.
3908
3909 * The ttyname and ttyname_r functions on Linux now fall back to searching for
3910   the tty file descriptor in /dev/pts or /dev if /proc is not available.  This
3911   allows creation of chroots without the procfs mounted on /proc.
3912
3913 * The `crypt' function now fails if passed salt bytes that violate the
3914   specification for those values.  On Linux, the `crypt' function will
3915   consult /proc/sys/crypto/fips_enabled to determine if "FIPS mode" is
3916   enabled, and fail on encrypted strings using the MD5 or DES algorithm
3917   when the mode is enabled.
3918
3919 * The `clock_*' suite of functions (declared in <time.h>) is now available
3920   directly in the main C library.  Previously it was necessary to link with
3921   -lrt to use these functions.  This change has the effect that a
3922   single-threaded program that uses a function such as `clock_gettime' (and
3923   is not linked with -lrt) will no longer implicitly load the pthreads
3924   library at runtime and so will not suffer the overheads associated with
3925   multi-thread support in other code such as the C++ runtime library.
3926
3927 * New locales: ayc_PE, doi_IN, ia_FR, mni_IN, nhn_MX, niu_NU, niu_NZ,
3928   sat_IN, and szl_PL.
3929 \f
3930 Version 2.16
3931
3932 * The following bugs are resolved with this release:
3933
3934   174, 208, 350, 369, 411, 706, 766, 2074, 2541, 2547, 2548, 2550, 2551,
3935   2552, 2553, 2554, 2562, 2563, 2565, 2566, 2570, 2576, 2636, 2678, 3335,
3936   3440, 3748, 3768, 3866, 3868, 3906, 3976, 3992, 4026, 4108, 4596, 4822,
3937   5077, 5461, 5805, 5993, 6471, 6486, 6578, 6649, 6730, 6770, 6794, 6884,
3938   6890, 6894, 6895, 6907, 6911, 6959, 7064, 9739, 9902, 10110, 10135, 10140,
3939   10153, 10210, 10254, 10346, 10375, 10545, 10716, 10846, 10882, 11174,
3940   11261, 11322, 11365, 11451, 11494, 11521, 11677, 11837, 11959, 12047,
3941   12097, 12193, 12194, 12297, 12298, 12301, 12340, 12354, 12416, 12495,
3942   13058, 13223, 13361, 13525, 13526, 13527, 13528, 13529, 13530, 13531,
3943   13532, 13533, 13547, 13551, 13552, 13553, 13555, 13556, 13559, 13563,
3944   13566, 13576, 13579, 13583, 13592, 13594, 13613, 13618, 13637, 13656,
3945   13658, 13673, 13691, 13695, 13704, 13705, 13706, 13718, 13726, 13738,
3946   13739, 13743, 13750, 13758, 13760, 13761, 13775, 13786, 13787, 13792,
3947   13806, 13824, 13840, 13841, 13844, 13846, 13848, 13851, 13852, 13854,
3948   13871, 13872, 13873, 13879, 13882, 13883, 13884, 13885, 13886, 13892,
3949   13895, 13908, 13910, 13911, 13912, 13913, 13914, 13915, 13916, 13917,
3950   13918, 13919, 13920, 13921, 13922, 13923, 13924, 13926, 13927, 13928,
3951   13938, 13941, 13942, 13954, 13955, 13956, 13963, 13967, 13968, 13970,
3952   13973, 13979, 13983, 13986, 13996, 14012, 14027, 14033, 14034, 14036,
3953   14040, 14043, 14044, 14048, 14049, 14050, 14053, 14055, 14059, 14064,
3954   14075, 14080, 14083, 14103, 14104, 14109, 14112, 14117, 14122, 14123,
3955   14134, 14153, 14183, 14188, 14199, 14210, 14218, 14229, 14241, 14273,
3956   14277, 14278.
3957
3958 * Support for the x32 ABI on x86-64 added.  The x32 target is selected by
3959   configuring glibc with:
3960         BUILD_CC='gcc' CC='gcc -mx32' CXX='g++ -mx32'
3961   Visit <https://sites.google.com/site/x32abi/> for more x32 ABI info.
3962   Implemented by H.J. Lu.
3963
3964 * ISO C11 support:
3965
3966   + define static_assert
3967
3968   + do not declare gets
3969
3970   + declare at_quick_exit and quick_exit also for ISO C11
3971
3972   + aligned_alloc.  NB: The code is deliberately allows the size parameter
3973     to not be a multiple of the alignment.  This is a moronic requirement
3974     in the standard but it is only a requirement on the caller, not the
3975     implementation.
3976
3977   + timespec_get added
3978
3979   + uchar.h support added
3980
3981   + CMPLX, CMPLXF, CMPLXL added
3982
3983   Implemented by Ulrich Drepper.
3984
3985 * Support for the IA-64 has been moved to ports.
3986
3987 * Remove support for anything but ELF binary format
3988
3989 * Checking versions of poll, ppoll added.
3990   Implemented by Ulrich Drepper.
3991
3992 * More generic and 64-bit performance optimizations to math functions.
3993   Implemented by Ulrich Drepper.
3994
3995 * New configure option --enable-obsolete-rpc makes the deprecated RPC
3996   headers and functions available at compile time as they were before
3997   version 2.14.  This option will be removed at some time in the future
3998   after the TI-RPC library becomes fully sufficient for the needs of
3999   existing applications.
4000
4001 * Compatibility code for Linux kernel versions before 2.4 has been removed.
4002   Note that glibc is not expected to work with any Linux kernel version
4003   before 2.6.
4004
4005 * New header <sys/auxv.h> and function getauxval allowing easy access to
4006   the AT_* key-value pairs passed from the Linux kernel.  The header also
4007   defines the HWCAP_* bits associated with the AT_HWCAP key.
4008
4009 * New locales: mag_IN
4010
4011 * New configure option --enable-systemtap builds SystemTap static probes
4012   into libc for setjmp and longjmp and into libpthread for various operations.
4013   So far the setjmp/longjmp probes and some of the libpthread probes are
4014   provided only for i*86 and x86_64.
4015   Implemented by Roland McGrath and Rayson Ho.
4016
4017 * Optimized expf for x86-32 and x86-64.  Implemented by Liubov Dmitrieva.
4018
4019 * More optimized functions for PowerPC.  Implemented by Adhemerval Zanella
4020   and Will Schmidt.
4021
4022 * More optimized functions for SPARC.  Implemented by David S. Miller.
4023
4024 * Improved support for cross-compilation, especially bootstrap builds
4025   without a previously built glibc.
4026
4027 * Ports for the TILE-Gx and TILEPro families of processors.  Contributed by
4028   Chris Metcalf from Tilera.
4029
4030 * Support for the old ARM ABI has been removed from ports.  Only the EABI is
4031   now supported for ARM processors.
4032
4033 * The hard-float variant of the ARM EABI now uses /lib/ld-linux-armhf.so.3
4034   as the name of the dynamic linker, to distinguish it from the
4035   /lib/ld-linux.so.3 dynamic linker used for the base EABI.
4036
4037 * Support for CRIS has been removed from ports.
4038
4039 * A new class of installed header has been documented for low-level
4040   platform-specific functionality.  PowerPC added the first instance with a
4041   function to provide time base register access.  Contributed by Tulio
4042   Magno Quites Machado Filho.
4043
4044 * ix86 configurations now install header files that are consistent with
4045   what x86-64 configurations install.  These same header files can be used
4046   for -m32, -m64, or -mx32 builds.
4047   Contributed by H.J. Lu.
4048
4049 * Math library bug fixes.  A thorough audit of all open math library bugs was
4050   conducted by Joseph Myers.  Significant progress was made on many math
4051   library bugs resulting in more accurate exceptions and function results.
4052   Many thanks to all those that contributed including Andreas Jaeger for his
4053   patch review and work on the x87 trigonometric instruction issues.
4054
4055 * Timezone data is no longer installed.  Timezone-related binaries and scripts
4056   will continue to be installed.  Users should obtain their timezone data from
4057   their distribution provider or from the tzdata package at
4058   <ftp://munnari.oz.au/pub/>.
4059 \f
4060 Version 2.15
4061
4062 * The following bugs are resolved with this release:
4063
4064   6779, 6783, 9696, 10103, 10709, 11589, 11929, 12403, 12786, 12840, 12847,
4065   12868, 12852, 12874, 12885, 12892, 12906, 12907, 12922, 12935, 12962,
4066   13007, 13021, 13061, 13062, 13067, 13068, 13085, 13088, 13090, 13092,
4067   13096, 13114, 13118, 13123, 13134, 13138, 13147, 13150, 13166, 13179,
4068   13185, 13189, 13192, 13268, 13276, 13282, 13291, 13305, 13328, 13335,
4069   13337, 13344, 13358, 13367, 13413, 13416, 13423, 13439, 13446, 13472,
4070   13484, 13506, 13515, 13523, 13524, 13538, 13540
4071
4072 * New program pldd to list loaded object of a process
4073   Implemented by Ulrich Drepper.
4074
4075 * Add nss_db support back to glibc.  No more dependency on Berkeley db
4076   and support for initgroups lookups.
4077   Implemented by Ulrich Drepper.
4078
4079 * Optimized strcpy, strncpy, stpcpy, stpncpy for SSE2 and SSSE3 on x86-32.
4080   Contributed by HJ Lu.
4081
4082 * Improved strcpy, strncpy, stpcpy, stpncpy for SSE2 and SSSE3 on x86-64.
4083   Contributed by HJ Lu.
4084
4085 * Optimized strcat, strncat on x86-64 and optimized wcscmp, wcslen, strnlen
4086   on x86-32 and x86-64.
4087   Contributed by Liubov Dmitrieva.
4088
4089 * Optimized strchr and strrchr for SSE on x86-32.
4090   Contributed by Liubov Dmitrieva.
4091
4092 * Optimized memchr, memrchr, rawmemchr, memcmp, wmemcmp, wcschr, wcscpy
4093   for x86-64 and x86-32.
4094   Contributed by Liubov Dmitrieva.
4095
4096 * New interfaces: scandirat, scandirat64
4097   Implemented by Ulrich Drepper.
4098
4099 * Checking versions of FD_SET, FD_CLR, and FD_ISSET added.
4100   Implemented by Ulrich Drepper.
4101
4102 * nscd now also caches the netgroup database.
4103   Implemented by Ulrich Drepper.
4104
4105 * Integrate libm with gcc's -ffinite-math-only option.
4106   Implemented by Ulrich Drepper.
4107
4108 * Lots of generic, 64-bit, and x86-64-specific performance optimizations
4109   to math functions.  Implemented by Ulrich Drepper.
4110
4111 * Optimized strcasecmp and strncasecmp for AVX on x86-64.
4112   Implemented by Ulrich Drepper.
4113
4114 * New Linux interfaces: process_vm_readv, process_vm_writev
4115
4116 * Optimized strcasecmp and strncasecmp for SSSE3 and SSE4.2 on x86-32.
4117   Implemented by Ulrich Drepper.
4118
4119 * Optimized nearbyint and strcasecmp for PPC.
4120   Implemented by Adhemerval Zanella.
4121
4122 * New locales: bho_IN, unm_US, es_CU, ta_LK
4123 \f
4124 Version 2.14
4125
4126 * The following bugs are resolved with this release:
4127
4128   386, 6420, 7101, 9730, 9732, 9809, 10138, 10149, 10157, 11099, 11257,
4129   11258, 11487, 11532, 11558, 11578, 11634, 11653, 11668, 11697, 11724,
4130   11781, 11799, 11820, 11837, 11857, 11884, 11892, 11895, 11901, 11945,
4131   11947, 11952, 11987, 12052, 12083, 12158, 12178, 12200, 12346, 12350,
4132   12393, 12420, 12432, 12445, 12449, 12453, 12454, 12460, 12469, 12489,
4133   12509, 12510, 12511, 12518, 12527, 12541, 12545, 12551, 12582, 12583,
4134   12587, 12597, 12601, 12611, 12625, 12626, 12631, 12650, 12653, 12655,
4135   12660, 12671, 12681, 12684, 12685, 12711, 12713, 12714, 12717, 12723,
4136   12724, 12734, 12738, 12746, 12766, 12775, 12777, 12782, 12788, 12792,
4137   12795, 12811, 12813, 12814, 12841
4138
4139 * The RPC implementation in libc is obsoleted.  Old programs keep working
4140   but new programs cannot be linked with the routines in libc anymore.
4141   Programs in need of RPC functionality must be linked against TI-RPC.
4142   The TI-RPC implementation is IPv6 enabled and there are other benefits.
4143
4144   Visible changes of this change include (obviously) the inability to link
4145   programs using RPC functions without referencing the TI-RPC library and the
4146   removal of the RPC headers from the glibc headers.
4147   Implemented by Ulrich Drepper.
4148
4149 * New Linux interfaces: clock_adjtime, name_to_handle_at, open_by_handle_at,
4150   syncfs, setns, sendmmsg
4151
4152 * New locales: os_RU, bem_ZA, en_ZA, ff_SN, sw_KE, sw_TZ, lb_LU, wae_CH,
4153   yue_HK, lij_IT, mhr_RU
4154
4155 * New encodings: CP770, CP771, CP772, CP773, CP774
4156
4157 * New program sotruss to trace calls through PLTs
4158   Implemented by Ulrich Drepper.
4159
4160 * The malloc hook implementation is marked deprecated and will be removed
4161   from the default implementation in the next version.  The design never
4162   worked ever since the introduction of threads.  Even programs which do
4163   not create threads themselves can use multiple threads created internally.
4164 \f
4165 Version 2.13
4166
4167 * The following bugs are resolved with this release:
4168
4169   3268, 6812, 7066, 10085, 10484, 10563, 10851, 11149, 11155, 11577, 11611,
4170   11640, 11655, 11701, 11840, 11856, 11883, 11903, 11904, 11968, 11979,
4171   12005, 12037, 12067, 12077, 12078, 12092, 12093, 12107, 12108, 12113,
4172   12140, 12159, 12167, 12191, 12194, 12201, 12204, 12205, 12207, 12348,
4173   12378, 12394, 12397
4174
4175 * New Linux interfaces: prlimit, prlimit64, fanotify_init, fanotify_mark
4176
4177 * POWER7 optimizations: memset, memcmp, strncmp
4178
4179 * New optimized string functions for x86-64: strnlen (SSE2),
4180   strcasecmp (SSE2, SSSE3, SSE4.2), strncasecmp (SSE2, SSSE3, SSE4.2)
4181   Implemented by Ulrich Drepper.
4182 \f
4183 Version 2.12
4184
4185 * The following bugs are resolved with this release:
4186
4187   3662, 4457, 5553, 10162, 10401, 10414, 10554, 10824, 10864, 10915,
4188   10918, 10936, 10939, 10958, 10968, 10969, 10972, 10992, 11000, 11001,
4189   11007, 11010, 11027, 11039, 11040, 11041, 11043, 11046, 11056, 11070,
4190   11093, 11115, 11125, 11126, 11127, 11134, 11141, 11149, 11183, 11184,
4191   11185, 11186, 11187, 11188, 11189, 11190, 11191, 11192, 11193, 11194,
4192   11200, 11230, 11235, 11242, 11254, 11258, 11271, 11272, 11276, 11279,
4193   11287, 11292, 11319, 11332, 11333, 11387, 11389, 11390, 11394, 11397,
4194   11410, 11438, 11449, 11470, 11471, 11520, 11537, 11538, 11571
4195
4196 * New interfaces: pthread_getname_np, pthread_setname_np
4197
4198 * New Linux interface: recvmmsg
4199
4200 * STT_GNU_IFUNC implemented for Sparc by David Miller.
4201
4202 * The dynamic linker now recognizes supported ABI versions from the
4203   EI_ABIVERSION field in the ELF header.
4204   Implemented by Ulrich Drepper.
4205
4206 * New NIS mode selector ADJUNCT_AS_SHADOW.  The passwd.adjunct.byname table
4207   will not be used to fill in password fields in the passwd.byname replies.
4208   Instead it is used to synthesize the shadow.byname table, should it be
4209   missing.  This is a useful mode in some installations involving Solaris.
4210   Implemented by Ulrich Drepper.
4211
4212 * New locales: kok_IN, sq_MK, cv_RU
4213 \f
4214 Version 2.11
4215
4216 * The following bugs are resolved with this release:
4217
4218   3270, 7094, 9924, 9986, 10011, 10085, 10107, 10159, 10162, 10166, 10183,
4219   10195, 10196, 10200, 10203, 10207, 10211, 10213, 10217, 10221, 10229,
4220   10262, 10286, 10312, 10315, 10319, 10349, 10360, 10391, 10402, 10416,
4221   10418, 10422, 10425, 10446, 10448, 10452, 10540, 10553, 10560, 10564,
4222   10609, 10643, 10692, 10713, 10717, 10730, 10731, 10742, 10780, 10784,
4223   10789, 10817, 10823, 10840, 10847
4224
4225 * New interfaces: execvpe, pthread_sigqueue, mkstemps, mkstemps64, mkostemps,
4226   mkostemps64
4227   Implemented by Ulrich Drepper.
4228
4229 * Checking version of longjmp added that fails if an uninitialized stack
4230   frame would be created.  Implemented by Ulrich Drepper.
4231
4232 * STT_GNU_IFUNC is now supported in static executables.
4233   Implemented by H.J. Lu.
4234
4235 * STT_GNU_IFUNC implemented for PPC by Alan Modra.
4236
4237 * New optimized string functions for x86-64: strstr, strcasestr, memcmp,
4238   strcspn, strpbrk, strspn, strcpy, stpcpy, strncpy, strcmp (SSE2, SSE4.2),
4239   strncmp (SSE2, SSE4.2), strchr (SSE4.2), strrchr (SSE4.2).
4240   Contributed by H.J. Lu.
4241
4242   strlen, rawmemchr, strcmp (SSSE3), strncmp (SSSE3).
4243   Implemented by Ulrich Drepper.
4244
4245 * New optimized string functions for x86: strlen, strcspn, strspn, strpbrk,
4246   strstr, strcasestr.
4247   Contributed by H.J. Lu.
4248
4249 * Support for fma instruction in AVX on x86-64.
4250   Implemented by H.J. Lu and Ulrich Drepper.
4251
4252 * AVX support in x86-64 auditing support in ld.so.
4253   Implemented by H.J. Lu.
4254
4255 * STB_GNU_UNIQUE support added.
4256   Implemented by Ulrich Drepper.
4257
4258 * Implement second fallback mode for optimized DNS lookup for even more
4259   broken environments.  If two requests from the same port are not
4260   handled correctly close the socket and open a new one before sending
4261   the second request.  The 'single-request-reopen' option in /etc/resolv.conf
4262   can be used to select this mode right away, instead of rediscovering the
4263   necessity is every process again.
4264   Implemented by Ulrich Drepper.
4265
4266 * New resolver flag RES_USE_DNSSEC to enable use of verified lookup.
4267   Implemented by Adam Tkac.
4268
4269 * Optimized iconv conversions for S390x.
4270   Implemented by Andreas Krebbel.
4271
4272 * Using condvars with PI mutexes is now more efficient due to kernel
4273   support for requeueing to PI futexes.  NPTL support added for x86-64.
4274   Implemented by Ulrich Drepper.
4275
4276 * New locales: ps_AF, my_MM
4277 \f
4278 Version 2.10
4279
4280 * The following bugs are resolved with this release:
4281
4282   697, 5381, 5807, 6411, 6545, 7040, 7058, 7067, 7080, 7083, 7095, 7098,
4283   9677, 9694, 9697, 9701, 9704, 9705, 9706, 9720, 9726, 9730, 9733, 9736,
4284   9741, 9750, 9753, 9759, 9781, 9791, 9793, 9823, 9833, 9844, 9880, 9881,
4285   9891, 9893, 9895, 9913, 9916, 9920, 9948, 9955, 9957, 9963, 9985, 10052,
4286   10069, 10086, 10087, 10090, 10092, 10093, 10100, 10118, 10128
4287
4288 * New interfaces: preadv, preadv64, pwritev, pwritev64, malloc_info
4289   Implemented by Ulrich Drepper.
4290
4291 * New Linux interfaces: accept4, fallocate, fallocate64.
4292   Implemented by Ulrich Drepper.
4293
4294 * Correct declarations of string function when used in C++ code.  This
4295   could lead to compile errors for invalid C++ code.
4296
4297 * XPG7/POSIX 2008 compilation environment.  Many GNU-specific functions are
4298   now in POSIX.
4299
4300 * New POSIX 2008 interface: psiginfo
4301   Implemented by Ulrich Drepper.
4302
4303 * New ISO C++1x interfaces: quick_exit, at_quick_exit
4304   Implemented by Ulrich Drepper.
4305
4306 * Support for selecting between multiple function definitions at runtime
4307   using STT_GNU_IFUNC symbols.  Implemented by Ulrich Drepper.
4308
4309 * The libcrypt library can now use the hash function implementations in
4310   NSS.  Implemented by Ulrich Drepper.
4311
4312 * The malloc implementation can be compiled to be less memory efficient
4313   but higher performing in multi-threaded programs.
4314   Implemented by Ulrich Drepper.
4315
4316 * New locales: nan_TW@latin, ks_IN
4317
4318 * Faster strlen, strchr, strchrnul, strrchr, memchr, and rawmemchr for x86-64.
4319   Implemented by Ulrich Drepper.
4320
4321 * Extended printf hook support.  It is possible to use user-defined types
4322   and extend existing format specifiers.
4323   Implemented by Ulrich Drepper.
4324
4325 * Handling for group shadow files has been added.
4326   Implemented by Ulrich Drepper.
4327
4328 * DNS IPv4-IPv6 parallel lookup now deals better with broken DNS
4329   servers (the case, e.g., for some people using the built-in DNS
4330   server in ADSL modems/routers).  There is a once-per-process timeout
4331   in case of a broken server.  To avoid it, users can run nscd or put
4332   'options single-request' in /etc/resolv.conf.
4333   Implemented by Ulrich Drepper.
4334 \f
4335 Version 2.9
4336
4337 * The following bugs are resolved with this release:
4338
4339   3406, 5209, 5210, 5381, 5794, 5814, 5911, 6428, 6438, 6442, 6447, 6461,
4340   6472, 6505, 6544, 6589, 6612, 6634, 6653, 6654, 6657, 6698, 6712, 6713,
4341   6719, 6723, 6724, 6740, 6763, 6771, 6790, 6791, 6817, 6824, 6839, 6843,
4342   6845, 6856, 6857, 6860, 6867, 6875, 6919, 6920, 6942, 6947, 6955, 6966,
4343   6968, 6974, 6980, 6995, 7008, 7009, 7029
4344
4345 * Unified lookup for getaddrinfo: IPv4 and IPv6 addresses are now looked
4346   up at the same time.  Implemented by Ulrich Drepper.
4347
4348 * TLS descriptors for LD and GD on x86 and x86-64.
4349   Implemented by Alexandre Oliva.
4350
4351 * getaddrinfo now handles DCCP and UDPlite.
4352   Implemented by Ulrich Drepper.
4353
4354 * New fixed-size conversion macros: htobe16, htole16, be16toh, le16toh,
4355   htobe32, htole32, be32toh, le32toh, htobe64, htole64, be64toh, le64toh.
4356   Implemented by Ulrich Drepper.
4357
4358 * New implementation of memmem, strstr, and strcasestr which is O(n).
4359   Implemented by Eric Blake.
4360
4361 * New Linux interfaces: inotify_init1, dup3, epoll_create1, pipe2
4362
4363 * Implement "e" option for popen to open file descriptor with the
4364   close-on-exec flag set.  Implemented by Ulrich Drepper.
4365
4366 * Implement "b" mode for fmemopen.  In this mode writes writes don't
4367   implicitly add a NUL byte and seeks from the end of the buffer really
4368   use the buffer end, not the string length as the basis.
4369   Implemented by Ulrich Drepper.
4370
4371 * Many functions, exported and internal, now atomically set the close-on-exec
4372   flag when run on a sufficiently new kernel.  Implemented by Ulrich Drepper.
4373
4374 * Sorting rules for some Indian languages (Kannada, Gurumukhi, Telugu,
4375   Sinhala)
4376   Implemented by Pravin Satpute.
4377
4378 * New locales: sd_IN, sd_IN@devanagari, ks_IN@devanagari, ht_HT, en_AG, nl_AW.
4379 \f
4380 Version 2.8
4381
4382 * The following bugs are resolved with this release:
4383
4384   2549, 3112, 4314, 4407, 4997, 5012, 5040, 5112, 5204, 5208, 5209, 5220,
4385   5222, 5224, 5225, 5237, 5238, 5240, 5245, 5277, 5346, 5375, 5378, 5382,
4386   5424, 5427, 5428, 5435, 5436, 5439, 5441, 5442, 5443, 5451, 5452, 5454,
4387   5455, 5463, 5464, 5465, 5475, 5477, 5478, 5520, 5541, 5545, 5553, 5600,
4388   5602, 5607, 5614, 5627, 5628, 5736, 5737, 5741, 5753, 5760, 5762, 5768,
4389   5774, 5777, 5778, 5779, 5786, 5790, 5818, 5854, 5857, 5903, 5939, 5979,
4390   5983, 5995, 5998, 6004, 6007, 6020, 6021, 6024, 6040, 6042
4391
4392 * New locales: bo_CN, bo_IN, shs_CA.
4393
4394 * New encoding: HP-ROMAN9, HP-GREEK8, HP-THAI8, HP-TURKISH8.
4395
4396 * Sorting rules for some Indian languages (Devanagari and Gujarati).
4397   Implemented by Pravin Satpute.
4398
4399 * IPV6 addresses in /etc/resolv.conf can now have a scope ID
4400
4401 * nscd caches now all timeouts for DNS entries
4402   Implemented by Ulrich Drepper.
4403
4404 * nscd is more efficient and wakes up less often.
4405   Implemented by Ulrich Drepper.
4406
4407 * More checking functions: asprintf, dprintf, obstack_printf, vasprintf,
4408   vdprintf, and obstack_vprintf.
4409   Implemented by Jakub Jelinek.
4410
4411 * Faster memset for x86-64.
4412   Implemented by Harsha Jagasia and H.J. Lu.
4413
4414 * Faster memcpy on x86.
4415   Implemented by Ulrich Drepper.
4416
4417 * ARG_MAX is not anymore constant on Linux.  Use sysconf(_SC_ARG_MAX).
4418   Implemented by Ulrich Drepper.
4419
4420 * Faster sqrt and sqrtf implemention for some PPC variants.
4421   Implemented by Steven Munroe.
4422 \f
4423 Version 2.7
4424
4425 * The following bugs are resolved with this release:
4426
4427   4125, 4126, 4178, 4359, 4407, 4512, 4514, 4525, 4554, 4556, 4557, 4566,
4428   4582, 4586, 4588, 4599, 4610, 4647, 4702, 4705, 4726, 4745, 4772, 4773,
4429   4775, 4776, 4792, 4813, 4814, 4816, 4833, 4858, 4860, 4896, 4905, 4925,
4430   4936, 4937, 4938, 4941, 4946, 4963, 4972, 5010, 5028, 5043, 5058, 5063,
4431   5071, 5103, 5104, 5112, 5113, 5184, 5186
4432
4433 * More checking functions: fread, fread_unlocked, open*, mq_open.
4434   Implemented by Jakub Jelinek and Ulrich Drepper.
4435
4436 * Extend fortification to C++.  Implemented by Jakub Jelinek.
4437
4438 * Implement 'm' modifier for scanf.  Add stricter C99/SUS compliance
4439   by not recognizing 'a' as a modifier when those specs are requested.
4440   Implemented by Jakub Jelinek.
4441
4442 * PPC optimizations to math and string functions.
4443   Implemented by Steven Munroe.
4444
4445 * New interfaces: mkostemp, mkostemp64.  Like mkstemp* but allow additional
4446   options to be passed.  Implemented by Ulrich Drepper.
4447
4448 * More CPU set manipulation functions.  Implemented by Ulrich Drepper.
4449
4450 * New Linux interfaces: signalfd, eventfd, eventfd_read, and eventfd_write.
4451   Implemented by Ulrich Drepper.
4452
4453 * Handle private futexes in the NPTL implementation.
4454   Implemented by Jakub Jelinek and Ulrich Drepper.
4455
4456 * Add support for O_CLOEXEC.  Implement in Hurd.  Use throughout libc.
4457   Implemented by Roland McGrath and Ulrich Drepper.
4458
4459 * Linux/x86-64 vDSO support.  Implemented by Ulrich Drepper.
4460
4461 * SHA-256 and SHA-512 based password encryption.
4462   Implemented by Ulrich Drepper.
4463
4464 * New locales: ber_DZ, ber_MA, en_NG, fil_PH, fur_IT, fy_DE, ha_NG, ig_NG,
4465   ik_CA, iu_CA, li_BE, li_NL, nds_DE, nds_NL, pap_AN, sc_IT, tk_TM, ug_CN,
4466   yo_NG.
4467
4468 + New iconv modules: MAC-CENTRALEUROPE, ISO-8859-9E, KOI8-RU.
4469   Implemented by Ulrich Drepper.
4470 \f
4471 Version 2.6
4472
4473 * The following bugs are resolved with this release:
4474
4475   3156, 3213, 3285, 3291, 3306, 3313, 3320, 3322, 3325, 3326, 3334, 3348,
4476   3352, 3363, 3369, 3426, 3427, 3429, 3451, 3458, 3465, 3480, 3483, 3493,
4477   3514, 3515, 3559, 3632, 3664, 3673, 3674, 3745, 3747, 3818, 3840, 3842,
4478   3851, 3855, 3884, 3885, 3902, 3905, 3919, 3944, 3954, 3955, 3957, 3991,
4479   3995, 3996, 4024, 4040, 4069, 4070, 4074, 4076, 4096, 4101, 4102, 4114,
4480   4130, 4131, 4181, 4276, 4306, 4342, 4344, 4349, 4364, 4368, 4381, 4392,
4481   4403, 4405, 4406, 4411, 4438, 4439, 4455, 4456, 4465, 4512, 4514, 4586,
4482   4702, 4858
4483
4484 * New Linux interfaces: epoll_pwait, sched_getcpu.
4485
4486 * New generic interfaces: strerror_l.
4487
4488 * nscd can now cache the services database.   Implemented by Ulrich Drepper.
4489 \f
4490 Version 2.5
4491
4492 * The following bugs are resolved with this release:
4493
4494   39, 68, 192, 352, 388, 531, 935, 1006, 1201, 1203, 1386, 1782, 1783, 1784,
4495   1785, 1786, 1787, 1951, 1974, 1996, 2072, 2098, 2125, 2134, 2158, 2182,
4496   2349, 2376, 2386, 2389, 2415, 2418, 2420, 2423, 2450, 2451, 2466, 2472,
4497   2473, 2477, 2498, 2499, 2501, 2502, 2505, 2507, 2508, 2509, 2517, 2526,
4498   2569, 2571, 2592, 2611, 2625, 2632, 2644, 2662, 2680, 2683, 2684, 2693,
4499   2695, 2703, 2734, 2751, 2764, 2766, 2775, 2792, 2821, 2823, 2832, 2841,
4500   2843, 2883, 2892, 2908, 2914, 2926, 2961, 2978, 2980, 2987, 2997, 2998,
4501   3013, 3018, 3034, 3040, 3044, 3123, 3124, 3137, 3138, 3143, 3155, 3189,
4502   3225, 3251, 3252, 3253, 3273
4503
4504 * For Linux, the sorting of addresses returned by getaddrinfo now also
4505   handles rules 3, 4, and 7 from RFC 3484.  I.e., all rules are handled.
4506   Implemented by Ulrich Drepper.
4507
4508 * Allow system admin to configure getaddrinfo with the /etc/gai.conf file.
4509   Implemented by Ulrich Drepper.
4510
4511 * New Linux interfaces: splice, tee, sync_file_range, vmsplice.
4512
4513 * New iconv module for MIK.  Contributed by Alexander Shopov.
4514
4515 * For sites with broken group and/or passwd database, the auto-propagate
4516   option of nscd can prevent creating ID lookup entries from the results
4517   of a name lookup and vice versa.   This usually is no problem but some
4518   site might have problems with the default behavior.
4519   Implemented by Ulrich Drepper.
4520
4521 * Iterating over entire database in NIS can be slow.  With the
4522   SETENT_BATCH_READ option in /etc/default/nss a system admin can decide
4523   to trade time for memory.  The entire database will be read at once.
4524   Implemented by Ulrich Drepper.
4525
4526 * The interfaces introduced in RFC 3542 have been implemented by
4527   Ulrich Drepper.
4528
4529 * Support for the new ELF hash table format was added by Ulrich Drepper.
4530
4531 * Support for priority inheritance mutexes added by Jakub Jelinek and
4532   Ulrich Drepper.
4533
4534 * Support for priority protected mutexes added by Jakub Jelinek.
4535
4536 * New locales: nr_ZA, pa_PK, ca_AD, ca_FR, ca_IT, el_CY, tr_CY, as_IN,
4537   or_IN, csb_PL, fy_NL, sr_ME.
4538 \f
4539 Version 2.4
4540
4541 * More overflow detection functions.
4542
4543 * New iconv converters for IBM1025, IBM1122, IBM1137, IBM1153,
4544   IBM1154, IBM1155, IBM1156, IBM1157, and IBM1158 contributed by Jiro Sekiba.
4545
4546   More converters for IBM803, IBM901, IBM902, IBM921, IBM1008, IBM1097,
4547   IBM1112, IBM1123, IBM1130, IBM1140, IBM1141, IBM1142, IBM1143, IBM1144,
4548   IBM1145, IBM1146, IBM1147, IBM1148, IBM1149, IBM1166, IBM1167, IBM4517,
4549   IBM4899, IBM4909, IBM4971, IBM5347, IBM9030, IBM9066, IBM9448, IBM12712,
4550   IBM16804, IBM1364, IBM1371, IBM1388, IBM1390, and IBM1399 contributed
4551   by Masahide Washizawa.
4552
4553 * It is now possible to install audit libraries for the dynamic linker using
4554   LD_AUDIT.  Implemented by Ulrich Drepper.
4555
4556 * The LinuxThreads add-on, providing pthreads on Linux 2.4 kernels, is no
4557   longer supported.  The new NPTL implementation requires Linux 2.6 kernels.
4558   For a libc and libpthread that works well on Linux 2.4 kernels, we
4559   recommend using the stable 2.3 branch.
4560
4561 * The new function open_wmemstream acts like open_memstream,
4562   but uses a wchar_t wide character buffer.
4563
4564 * The new function ppoll is an improved version of poll, similar to pselect.
4565
4566 * New interfaces: fdopendir, openat, fstatat, fchmodat, fchownat,
4567   futimesat, faccessat, mkdirat, mkfifoat, mknodat,
4568   renameat, unlinkat, linkat, symlinkat, readlinkat.
4569
4570 * New Linux kernel system calls: unshare,
4571   inotify_init, inotify_add_watch, inotify_rm_watch.
4572
4573 * The euidaccess function is now also known by the alias eaccess,
4574   for compatibility with some other systems.
4575
4576 * Timezone data updated to 2006b version.
4577 \f
4578 Version 2.3.6
4579
4580 * The following bugs are resolved with this release:
4581
4582   38, 253, 549, 622, 653, 721, 758, 851, 877, 915, 934, 955, 961,
4583   1016, 1037, 1076, 1079, 1080, 1081, 1082, 1083, 1084, 1085, 1086,
4584   1087, 1088, 1090, 1091, 1092, 1093, 1094, 1095, 1096, 1097, 1098,
4585   1099, 1100, 1101, 1102, 1103, 1104, 1105, 1106, 1107, 1108, 1109,
4586   1110, 1111, 1112, 1113, 1125, 1137, 1138, 1249, 1250, 1251, 1252,
4587   1253, 1254, 1350, 1358, 1394, 1438, 1498, 1534
4588
4589   Visit <https://sourceware.org/bugzilla/> for the details of each bug.
4590
4591 * As of this release, GCC 4 can be used to compile the C Library.
4592
4593 * Timezone data updated to 2005m version.
4594 \f
4595 Version 2.3.5
4596
4597 * The following bugs are resolved with this release:
4598
4599   284, 592, 602, 626, 633, 640, 650, 661, 671, 681, 693, 700, 710, 719,
4600   722, 723, 725, 726, 727, 728, 729, 730, 731, 732, 733, 734, 735, 736,
4601   737, 738, 739, 740, 741, 742, 743, 744, 745, 765, 767, 768, 769, 776,
4602   777, 787, 821, 822, 823, 825
4603
4604   Visit <https://sourceware.org/bugzilla/> for the details of each bug.
4605 \f
4606 Version 2.3.4
4607
4608 * Support for RFC 3678.  Real implementations exist only for Linux so far.
4609   Implemented by Ulrich Drepper.
4610
4611 * nscd can now cache entries persistently.  Expiring entries are reloaded.
4612   For speedups the cache can be shared in memory with client processes.
4613   Implemented by Ulrich Drepper.
4614
4615 * nscd can now perform SELinux checks.
4616   Implemented by Matthew Rickard <mjricka@epoch.ncsc.mil>.
4617
4618 * getaddrinfo queries are now cached.  Canonical name lookup is performed
4619   efficiently.
4620   Implemented by Ulrich Drepper.
4621
4622 * The nothrow function attribute is used when headers are used by gcc when
4623   compiling C code.  This can avoid significant amounts of exception
4624   handling data.
4625
4626 * The malloc functions perform more error checking and are stricter when
4627   it comes to reacting on errors.  The default action is to terminate
4628   the process after showing an error message.  Implemented by Ulrich Drepper.
4629
4630 * Reverse lookups of IPv6 addresses does not use bit string or .ip6.int
4631   lookups anymore unless explicitly requested.  Implemented by Ulrich Drepper.
4632
4633 * Namespaces in ld.so are implemented.  DSOs can be loaded in separate
4634   namespaces using the new function dlmopen().  This feature is of course,
4635   like most other dynamic loading functionality, not available in statically
4636   linked applications.  Implemented by Ulrich Drepper.
4637
4638 * Low-overhead boundary checking variants of string and some stdio functions
4639   were added.  These are to be used in conjunction with a gcc patch by
4640   Jakub Jelinek which adds calls to these functions if possible.
4641   Implemented by Jakub Jelinek and Ulrich Drepper.
4642
4643 * Old code for several operating systems and machine architectures that
4644   have not been in working condition in a long time have been removed from
4645   the main source tree maintained by the GNU C Library's maintainers.
4646   These files are now reside in the separate `ports' source module
4647   that is usable as an add-on when building the library.
4648 \f
4649 Version 2.3.3
4650
4651 * New functions `dladdr1' and `dlinfo' in <dlfcn.h> provide more ways to
4652   interrogate the dynamic linker, compatible with the Solaris interface.
4653
4654 * ELF thread-local storage support (TLS) now works on PowerPC and PowerPC64;
4655   implemented by Paul Mackerras, Steven Munroe, and Roland McGrath.
4656
4657 * getifaddrs now uses the netlink interface on Linux to get its information.
4658   Implemented by Thorsten Kukuk.
4659
4660 * getaddrinfo now implements AI_V4MAPPED, AI_ALL, and AI_ADDRCONF.
4661   Implemented by Ulrich Drepper.
4662
4663 * support for non-executable stacks on x86 has been added.  Changes mostly
4664   by Roland McGrath.
4665
4666 * regex is now much faster for multibyte locales.  Changes by Jakub Jelinek
4667   and Ulrich Drepper.
4668
4669 * getaddrinfo now performs destination address selection according to
4670   RFC 3484.
4671 \f
4672 Version 2.3.2
4673
4674 * Thread-safe interfaces for many functions that access locale data
4675   were added in version 2.3, but these features were omitted from NEWS.
4676   Many functions have variants with an `_l' suffix that take a `locale_t'
4677   object as a parameter rather than consulting the current locale.
4678   The new functions `newlocale', `duplocale', and `freelocale' in <locale.h>
4679   create and maintain `locale_t' objects.  Additionally, the new function
4680   `uselocale' sets "the current locale" (as used by functions not so
4681   parameterized) set for an individual thread.  These features were added
4682   in version 2.3, implemented by Ulrich Drepper and Roland McGrath.
4683
4684 * The functions getresuid, getresgid, setresuid, and setresgid, which
4685   have long been available on Linux, are now declared in <unistd.h>
4686   and are now also available on the Hurd.
4687
4688 * ELF thread-local storage support (TLS) now works on x86-64.
4689
4690 * The new dynamic string token $LIB is expanded in shared library names.
4691   This normally expands to lib, but on some 64-bit platforms to lib64 instead.
4692
4693 * Aldy Hernandez contributed complete software floating point support for
4694   PowerPC machines with no FPU.
4695
4696 * fexecve is implemented on Linux.
4697
4698 * The `btowc' function should work at least twice as fast due to
4699   specialized callbacks in the iconv modules.  Implemented by Bruno Haible.
4700
4701 * With approriate thread add-ons cancelable functions are now implemented
4702   in libc.so as well.  No need to call the function in libpthread.  This
4703   change allowed to finally disable the incorrect and expensive handling
4704   of weak definition in ld.so.
4705
4706 * Yet more PLT entries in libc.so have been removed.  We finally arrived
4707   at the bare minimum.  Startup times improved appropriately.
4708
4709 * Support for the new Linux/x86 system call interface was added.  The
4710   AT_SYSINFO auxiliary vector entry is recognized and handled.
4711 \f
4712 Version 2.3
4713
4714 * Masahide Washizawa contributed iconv modules for IBM1163 and IBM1164
4715   charsets.
4716
4717 * iconv (the program and the interface) now accepts empty names (excluding
4718   options like //TRANSLIT) to mean "use charset of current locale".
4719
4720 * localedef can now transliterate characters in strings which are not in
4721   the provided charmap.  The information from the input locale is used.
4722
4723 * Prelinking support was added for ELF targets.  This requires additional
4724   tools and recent versions of the GNU binutils.  Contributed by Jakub Jelinek.
4725
4726 * Read-only stdio streams now use mmap to speed up operation by eliminating
4727   copying and buffer underflows.  To use add 'm' to the mode string of
4728   the fopen/fdopen/freopen call.  Implemented by Ulrich Drepper.
4729
4730 * The malloc functions were completely rewritten by Wolfram Gloger based
4731   on Doug Lea's malloc-2.7.0.c.
4732
4733 * Isamu Hasegawa contributed a completely new and POSIX-conformant
4734   implementation of regex.
4735
4736 * Bruno Haible upgraded the iconv and locale implementation to support
4737   Unicode 3.2.
4738
4739 * Contents of the LC_* and LANG environment variables in the CEN style are
4740   not recognized anymore.   It never was used.  Change by Ulrich Drepper.
4741
4742 * The runtime (ld.so, libc, libpthread for Linux) now can handle the ELF
4743   thread-local storage (TLS) ABI on some platforms.
4744   Changes by Ulrich Drepper.  SH support by Kaz Kojima.
4745
4746 * Bruno Haible contributed iconv converters for ISO-2022-JP-3, SHIFT JIS-X0213,
4747   EUC-JISX0213, and TSCII.
4748
4749 * New header <ifaddrs.h> with functions `getifaddrs' and `freeifaddrs':
4750   BSD-compatible interface for getting all network interface addresses.
4751   Implementation for IPv4 by Roland McGrath.
4752
4753 * Loading of locale data is faster due to the introduction of a locale
4754   archive.  Implemented by Roland McGrath and Ulrich Drepper.
4755
4756 * Startup times are significantly reduced by not using exported functions
4757   inside the library itself.  Changes by Jakub Jelinek, Roland McGrath,
4758   and Ulrich Drepper.
4759
4760 * Steven Munroe contributed a port to PowerPC64/Linux.
4761 \f
4762 Version 2.2.6
4763
4764 * The Hurd now uses the GNU libio implementation of stdio rather than the
4765   old GNU stdio implementation, and uses a new ABI (libc.so.0.3).
4766
4767 * The Hurd on x86 now has the `ioperm' function and <sys/io.h> header file
4768   with the same behavior as the Linux system call of the same name.
4769 \f
4770 Version 2.2.5
4771
4772 * Stephen Moshier implemented log2, log10, powl and cbrtl for the
4773   128-bit long double format.
4774
4775 * Masahide Washizawa contributed iconv modules for IBM1132, IBM1133, IBM1160,
4776   IBM1161, and IBM1162 charsets.
4777
4778 * Andreas Jaeger contributed a port to x86-64/Linux.
4779
4780 * Peter Bruin contributed a port to PowerPC/Hurd.
4781
4782 * libc functions using I/O streams now can handle wide-oriented streams
4783   as well.
4784
4785 * optimizations in the dynamic linker.  Binaries created by recent binutils
4786   versions start up quicker due to reduced time spent on relocations.
4787
4788 * Support for use of gcc3 added by Jakub Jelinek and HJ Lu.
4789 \f
4790 Version 2.2.4
4791
4792 * Stephen Moshier implemented cosh, expm1, log1p, acos, sinh, tanh,
4793   asinh, atanh, j0 for the 128-bit long double format.
4794
4795 * Bruno Haible updated all the code handling Unicode in some form to
4796   support Unicode 3.1.
4797
4798 * Speed of regex for single-byte locales is back to previous levels.
4799   Patch by Isamu Hasegawa.
4800
4801 * Alpha, SPARC, and IA-64 now also using floating stacks.
4802
4803 * Startup time of internationalized applications greatly improved through
4804   iconv cache.  Use iconvconfig to generate the cache file.
4805   Contributed by Ulrich Drepper.
4806
4807 * The IA-64 specific part of ld.so was rewritten to eliminate some pretty
4808   severe performance problems.  Patch by David Mosberger.
4809
4810 * The Hurd port got a lot more functionality like AIO, various stdio
4811   extensions, etc.  Mainly done by Roland McGrath.
4812
4813 * mtrace can now lookup symbols in shared libraries.
4814 \f
4815 Version 2.2.3
4816
4817 * Intel's IA-64 math library is largely integrated.  It provides fast and
4818   accurate implementatations for most basic and standard math functions
4819   in float, double, and long double format.
4820
4821 * Stephen Moshier implemented j0, j1, jn, y0, y1, yn, lgamma, erf, erfc,
4822   and asin for the 96-bit long double format and asin, log, tan for the
4823   128-bit long double format.
4824
4825 * The beginning of a last-bit accurate math library by IBM Haifa were added.
4826   The basic double functions exist today.  Contributed by Abraham Ziv
4827   <ziv@il.ibm.com>, Moshe Olshansky <olshansk@il.ibm.com>, Ealan Henis
4828   <ealan@il.ibm.com>, and Anna Reitman <reitman@il.ibm.com>.
4829
4830 * An asynchronous name lookup library was added.  The interface is designed
4831   after POSIX AIO.  The proposal was circulated beforehand to get comments.
4832   No negative ones came in.  Implemented by Ulrich Drepper.
4833
4834 * Port to S390/64bit contributed by Martin Schwidefsky
4835   <schwidefsky@de.ibm.com>.
4836
4837 * David Mosberger <davidm@hpl.hp.com> implemented the setcontext family
4838   of functions for Linux/IA-64.
4839
4840 * The RPC code is now thread safe.  Threads can now use the same service
4841   of different services at the same time.  Patch by Eric Norum
4842   <eric.norum@usask.ca> with some help by Ulrich Drepper.
4843
4844 * Martin Schwidefsky <schwidefsky@de.ibm.com> implemented the setcontext
4845   family of functions for Linux/S390.
4846
4847 * Ulrich Drepper <drepper@redhat.com> implemented the setcontext family
4848   of functions for Linux/x86.
4849
4850 * Port to Linux/CRIS contributed by Axis Communications.
4851 \f
4852 Version 2.2.2
4853
4854 * Lots of headers were cleaned up.  Using the tool in the conform/ subdir
4855   we can now check for namespace violations and missing declarations.  The
4856   result is that almost all headers are now Unix-compliant (as defined in
4857   the upcoming XPG6).  The negative side is that some programs might need
4858   corrections, too, if they depend on the incorrect form of the headers in
4859   previous versions which defined too many symbols and included too many
4860   other headers.
4861
4862 * regex now handles multibyte character sets correctly.
4863   Contributed by Isamu Hasegawa <isamu@yamato.ibm.com>.
4864
4865 * iconv (the program) does now conform to the upcoming XPG6 and handles
4866   charmaps.  Instead of the charset names the path of charmaps can be
4867   provided and the conversion happens based on this data.
4868   Contributed by Ulrich Drepper.
4869
4870 * The locale program now provides detailed information about the installed
4871   locales.  While
4872
4873     locale -a
4874
4875   only lists the names of the supported locales
4876
4877     locale -a --verbose
4878
4879   provides details such as country, language, and codeset name.
4880   Contributed by Ulrich Drepper.
4881 \f
4882 Version 2.2.1
4883
4884 * The gencat program now parses the input file according to the charset
4885   selected by the LC_CTYPE category.  This is important for stateful
4886   character sets.  To make generating catalogs easier there is a way
4887   to overwrite the charset selected by the locale: before the first
4888   message or $ quote line the catalog can contain a line like
4889
4890     $ codeset=ISO-8859-2
4891
4892   to select the charset (ISO-8859-2 in this case).
4893
4894   Implemented by Shinya Hanataka and Ulrich Drepper.
4895
4896 * New codeset conversion modules: IBM-922  (Estonia PC codeset),
4897   IBM-1124 (Ukraine PC codeset), IBM-1129 (Vietnamese PC codeset).
4898   Contributed by Masahide Washizawa <washi@jp.ibm.com>.
4899
4900 * Optimized string functions for Alpha ev6 and ev67 by Richard Henderson
4901   <rth@redhat.com> and Rick Gorton <rick.gorton@alpha-processor.com>.
4902
4903 * The LANGUAGE environment variable is now ignored unless the locale is
4904   changed from the default "C" locale.
4905
4906 * The usual bug fixes.
4907 \f
4908 Version 2.2
4909
4910 * Greg McGary added runtime support for bounds checking using gcc's
4911   new -fbounded-pointers option.  ix86 target is complete.  PowerPC
4912   is in progress.
4913
4914 * Thorsten Kukuk added secure mode support to nscd.
4915
4916 * The Berkeley db libraries have been removed.
4917
4918   Related, the nss_db module is now in a separate package since it
4919   obviously requires a database library being available.
4920
4921 * Wide character I/O streams implemented by Ulrich Drepper.
4922
4923 * Functions from the extended socket API added by Ulrich Drepper.
4924
4925 * Functions feenableexcept and fedisableexcept to control the
4926   behaviour of individual exceptions have been added by Andreas Jaeger.
4927
4928 * ldconfig program added by Andreas Jaeger and Jakub Jelinek.
4929
4930 * The resolver code has been updated from bind 8.2.3-T5B which supports
4931   threads.  The integration was done by Andreas Jaeger, Adam D. Bradley,
4932   and Mark Kettenis.
4933
4934   This change could in some situations effect backward compatibility.  Since
4935   now `_res' is a thread-local instead of a global variable, modifying it
4936   in one thread does not have any effect in other threads.
4937
4938   The resolver library was also extended to allow IPv6 as the transport
4939   protocol for the requests.  This work was done by Stig Venaas.
4940
4941 * Compatibility code for K&R C compilers has been removed from the
4942   header files.  A ISO C compiler is needed to use the library
4943   (conforming to either C89 or C99 standard).
4944
4945 * Complete rewrite of the localedef program to support multibyte character
4946   sets.  Implement handling of ISO 14651 and ISO 14652.  Rewrite strcoll,
4947   strxfrm, wcscoll, and wcsxfrm functions.  Make isw*() functions work.
4948   Implemented by Ulrich Drepper.
4949
4950   Bruno Haible significantly improved the generation and use of the data
4951   structures for the wide character tables.
4952
4953 * Plural handling in gettext implemented by Ulrich Drepper.
4954
4955 * The utmp daemon has been removed.
4956
4957 * The port to MIPS-Linux has been finished by Andreas Jaeger.
4958
4959 * A port to Hitachi SH3 and SH4 has been contributed by Kazumoto Kojima
4960   and Yutaka Niibe.
4961
4962 * POSIX clocks and timers implemented by Kaz Kylheku and Ulrich Drepper.
4963
4964 * POSIX barriers implemented by Kaz Kylheku.
4965
4966 * POSIX spawn function family implemented by Ulrich Drepper.
4967
4968 * POSIX spinlocks are now available.
4969
4970 * Timed wait functions for mutex, rwlock, and semaphores are implemented.
4971
4972 * the configure option --enable-kernel=X.Y.Z allows to strip out
4973   compatibility for kernel versions before X.Y.Z.  This is currently only
4974   implemented for Linux.
4975
4976 * the sockaddr_in6 structure changed.  The IPv6 working group added a new
4977   field sin6_scope_id.  This means that all programs using IPv6 should be
4978   recompiled.  Don't expect binary compatibility with previous glibc
4979   versions.
4980
4981 * various conversion modules for IBM character sets contributed by
4982   Masahide Washizawa.
4983
4984 * IA-64 port by Jes Sorensen and HJ Lu.
4985 \f
4986 Version 2.1.3
4987
4988 * bug fixes
4989
4990 \f
4991 Version 2.1.2
4992
4993 * bug fixes
4994
4995 \f
4996 Version 2.1.1
4997
4998 * New ISO C 9x function _Exit, imaxabs, and imaxdiv are added.
4999
5000 * New xdr functions are added; some rpc functions are now 64bit clean.
5001
5002 * Fixed a number of bugs and memory leaks (especially in NIS+ code).
5003
5004 * Fixed known incompatibilities with glibc 2.0.
5005
5006 * New functions lock64, strchrnul, rawmemchr, getutmp and getutmpx.
5007
5008 * Optimized a number of functions (especially the ELF dynamic loader).
5009
5010 * Update timezone data files.
5011
5012 * lots of charmaps corrections
5013
5014 * some new locale definitions and charmaps
5015
5016 \f
5017 Version 2.1
5018
5019 * Richard Henderson corrected size of struct timeval on Linux/Alpha to
5020   conform to POSIX member type requirements.  Symbol versions have been
5021   adjusted as needed within the library, and for direct use by applications,
5022   but there is potential for problems if third-party libraries use
5023   struct timeval as part of their interface.  This does not present
5024   a problem for X and other "essential" system libraries.
5025
5026 * An additional locale model to support C++ Standard Library locale
5027   model and probably more was implemented by Ulrich Drepper.
5028
5029 * Eric Youngdale and Ulrich Drepper implemented versioning of objects on
5030   symbol level.
5031
5032 * Miles Bader provided the `argp' function family to support hierachical
5033   command line argument parsing, layered on top of getopt.
5034
5035 * strtod accepts new hexadecimal floating-point format from ISO C 9X.
5036
5037 * printf has two new specifiers %a and %A to print hexadecimal flaoting-point
5038   numbers.
5039
5040 * scanf recognizes the %a and %A format for scanning floating point numbers.
5041
5042 * the new headers <stdint.h> and <inttypes.h> from ISO C 9X provides
5043   information and interfaces for the available integer types.
5044
5045 * about 130 new math functions were added to implement the ISO C9x math
5046   library.
5047
5048 * the new header <complex.h> contains definitions of the complex math
5049   functions from ISO C 9X.
5050
5051 * the new header <tgmath.h> defines generic macros to use complex or
5052   real valued functions.
5053
5054 * Thorsten Kukuk provided an implementation for NIS+, securelevel 0, 1 and 2.
5055
5056 * Andreas Jaeger provided a test suite for the math library.
5057
5058 * Mark Kettenis implemented the utmpx interface and an utmp daemon.
5059
5060 * Ulrich Drepper added character set conversion functions (iconv).
5061
5062 * Optimized string functions have been added.
5063
5064 * The localedata addon is now part of glibc.
5065
5066 * An implementation of profiling shared libraries was added by Ulrich Drepper.
5067
5068 * Thorsten Kukuk and Ulrich Drepper provided an implementation for a caching
5069   daemon for NSS (nscd).
5070
5071   Missing a better place here are some numbers on improvements.  Under
5072   Linux 2.1.125 un-tar-ing the kernel sources takes
5073
5074                                   user  system     wall
5075
5076     using local files           12.19s   6.88s   22.91s
5077
5078     using NIS                   13.92s   8.91s   26.34s
5079
5080     using NIS & nscd            10.37s   7.34s   25.30s
5081
5082     using NIS+                  27.57s  30.37s  640.46s
5083
5084     using NIS+ & nscd           10.25s   7.83s   26.51s
5085
5086     using NIS & old nscd [1]    13.83s   8.32s   29.60s
5087
5088   Keep in mind that non-namelookup related operations dominate above times.
5089   It was just a common complain that using NIS+ unpacking the kernel is
5090   horribly slow.
5091
5092   [1] The old nscd implementation is not available anymore since it was
5093   distributed with glibc up to version 2.0.98 and thus is now replaced.
5094
5095 * Tim Waugh provided an implementation of the POSIX.2 wordexp function family.
5096
5097 * Mark Kettenis provided a Hesiod NSS module.
5098
5099 * The ELF dynamic loader knows how to process dynamic string tokens ($ORIGIN
5100   and $PLATFORM) in RPATHs and similar strings (Ulrich Drepper).
5101
5102 * rcmd can now handle netgroups (Dick Streefland).
5103
5104 * A port to the ARM was contributed by Phil Blundell, Pat Beirne and Scott
5105   Bambrough.
5106
5107 * Support for the IPv6 protocol has been added to the socket API, as per the
5108   latest draft standards.
5109
5110 * Support for Linux 2.2 has been added.
5111
5112 * Interface changes relative to the latest 2.0.x release:
5113 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
5114 addseverity                     NEW: Unix98
5115 alphasort64                     NEW: LFS
5116 argp_err_exit_status            NEW: argp, GNU ext
5117 argp_error                      NEW: argp, GNU ext
5118 argp_failure                    NEW: argp, GNU ext
5119 argp_help                       NEW: argp, GNU ext
5120 argp_parse                      NEW: argp, GNU ext
5121 argp_program_bug_address        NEW: argp, GNU ext
5122 argp_program_version            NEW: argp, GNU ext
5123 argp_program_version_hook       NEW: argp, GNU ext
5124 argp_state_help                 NEW: argp, GNU ext
5125 argp_usage                      NEW: argp, GNU ext
5126 authdes_create                  NEW: Secure RPC
5127 authdes_getucred                NEW: Secure RPC
5128 authdes_pk_create               NEW: Secure RPC
5129 backtrace                       NEW: GNU ext.
5130 backtrace_symbols               NEW: GNU ext.
5131 backtrace_symbols_fd            NEW: GNU ext.
5132 cacos                           NEW: ISO C 9x
5133 cacosf                          NEW: ISO C 9x
5134 cacosh                          NEW: ISO C 9x
5135 cacoshf                         NEW: ISO C 9x
5136 cacoshl                         NEW: ISO C 9x
5137 cacosl                          NEW: ISO C 9x
5138 capget                          NEW: kernel
5139 capset                          NEW: kernel
5140 carg                            NEW: ISO C 9x
5141 cargf                           NEW: ISO C 9x
5142 cargl                           NEW: ISO C 9x
5143 casin                           NEW: ISO C 9x
5144 casinf                          NEW: ISO C 9x
5145 casinh                          NEW: ISO C 9x
5146 casinhf                         NEW: ISO C 9x
5147 casinhl                         NEW: ISO C 9x
5148 casinl                          NEW: ISO C 9x
5149 catan                           NEW: ISO C 9x
5150 catanf                          NEW: ISO C 9x
5151 catanh                          NEW: ISO C 9x
5152 catanhf                         NEW: ISO C 9x
5153 catanhl                         NEW: ISO C 9x
5154 catanl                          NEW: ISO C 9x
5155 cbc_crypt                       NEW: Secure RPC
5156 ccos                            NEW: ISO C 9x
5157 ccosf                           NEW: ISO C 9x
5158 ccosh                           NEW: ISO C 9x
5159 ccoshf                          NEW: ISO C 9x
5160 ccoshl                          NEW: ISO C 9x
5161 ccosl                           NEW: ISO C 9x
5162 cexp                            NEW: ISO C 9x
5163 cexpf                           NEW: ISO C 9x
5164 cexpl                           NEW: ISO C 9x
5165 cimag                           NEW: ISO C 9x
5166 cimagf                          NEW: ISO C 9x
5167 cimagl                          NEW: ISO C 9x
5168 clearerr_locked                 REMOVED
5169 clntunix_create                 NEW: sunrpc ext
5170 clog                            NEW: ISO C 9x
5171 clog10                          NEW: ISO C 9x
5172 clog10f                         NEW: ISO C 9x
5173 clog10l                         NEW: ISO C 9x
5174 clogf                           NEW: ISO C 9x
5175 clogl                           NEW: ISO C 9x
5176 conj                            NEW: ISO C 9x
5177 conjf                           NEW: ISO C 9x
5178 conjl                           NEW: ISO C 9x
5179 cpow                            NEW: ISO C 9x
5180 cpowf                           NEW: ISO C 9x
5181 cpowl                           NEW: ISO C 9x
5182 cproj                           NEW: ISO C 9x
5183 cprojf                          NEW: ISO C 9x
5184 cprojl                          NEW: ISO C 9x
5185 creal                           NEW: ISO C 9x
5186 crealf                          NEW: ISO C 9x
5187 creall                          NEW: ISO C 9x
5188 creat64                         NEW: LFS
5189 csin                            NEW: ISO C 9x
5190 csinf                           NEW: ISO C 9x
5191 csinh                           NEW: ISO C 9x
5192 csinhf                          NEW: ISO C 9x
5193 csinhl                          NEW: ISO C 9x
5194 csinl                           NEW: ISO C 9x
5195 csqrt                           NEW: ISO C 9x
5196 csqrtf                          NEW: ISO C 9x
5197 csqrtl                          NEW: ISO C 9x
5198 ctan                            NEW: ISO C 9x
5199 ctanf                           NEW: ISO C 9x
5200 ctanh                           NEW: ISO C 9x
5201 ctanhf                          NEW: ISO C 9x
5202 ctanhl                          NEW: ISO C 9x
5203 ctanl                           NEW: ISO C 9x
5204 des_setparity                   NEW: Secure RPC
5205 ecb_crypt                       NEW: Secure RPC
5206 endutxent                       NEW: Unix98
5207 exp10                           NEW: ISO C 9x
5208 exp10f                          NEW: ISO C 9x
5209 exp10l                          NEW: ISO C 9x
5210 exp2                            NEW: ISO C 9x
5211 exp2f                           NEW: ISO C 9x
5212 exp2l                           NEW: ISO C 9x
5213 fattach                         NEW: STREAMS
5214 fdetach                         NEW: STREAMS
5215 fdim                            NEW: ISO C 9x
5216 fdimf                           NEW: ISO C 9x
5217 fdiml                           NEW: ISO C 9x
5218 feclearexcept                   NEW: ISO C 9x
5219 fegetenv                        NEW: ISO C 9x
5220 fegetexceptflag                 NEW: ISO C 9x
5221 fegetround                      NEW: ISO C 9x
5222 feholdexcept                    NEW: ISO C 9x
5223 feof_locked                     REMOVED
5224 feraiseexcept                   NEW: ISO C 9x
5225 ferror_locked                   REMOVED
5226 fesetenv                        NEW: ISO C 9x
5227 fesetexceptflag                 NEW: ISO C 9x
5228 fesetround                      NEW: ISO C 9x
5229 fetestexcept                    NEW: ISO C 9x
5230 feupdateenv                     NEW: ISO C 9x
5231 fflush_locked                   REMOVED
5232 ffsl                            NEW: GNU ext.
5233 ffsll                           NEW: GNU ext.
5234 fgetpos64                       NEW: LFS
5235 fgets_unlocked                  NEW: GNU ext.
5236 fileno_locked                   REMOVED
5237 fma                             NEW: ISO C 9x
5238 fmaf                            NEW: ISO C 9x
5239 fmal                            NEW: ISO C 9x
5240 fmax                            NEW: ISO C 9x
5241 fmaxf                           NEW: ISO C 9x
5242 fmaxl                           NEW: ISO C 9x
5243 fmin                            NEW: ISO C 9x
5244 fminf                           NEW: ISO C 9x
5245 fminl                           NEW: ISO C 9x
5246 fmtmsg                          NEW: Unix98
5247 fopen64                         NEW: LFS
5248 fputc_locked                    REMOVED
5249 fputs_unlocked                  NEW: GNU ext.
5250 fread_unlocked                  NEW: GNU ext.
5251 freopen64                       NEW: LFS
5252 fseeko                          NEW: Unix98
5253 fsetpos64                       NEW: LFS
5254 fstatfs64                       NEW: LFS
5255 fstatvfs                        NEW: Unix98
5256 fstatvfs64                      NEW: LFS
5257 ftello                          NEW: Unix98
5258 ftello64                        NEW: LFS
5259 ftruncate64                     NEW: LFS
5260 ftw64                           NEW: LFS
5261 fwrite_unlocked                 NEW: GNU ext.
5262 gai_strerror                    NEW: IPv6
5263 gamma_r                         REMOVED
5264 gammaf_r                        REMOVED
5265 gammal_r                        REMOVED
5266 getchar_locked                  REMOVED
5267 getdate                         NEW: Unix98
5268 getdate_err                     NEW: Unix98
5269 getdate_r                       NEW: GNU ext.
5270 getmsg                          NEW: STREAMS
5271 getnameinfo                     NEW: IPv6
5272 getnetname                      NEW: Secure RPC
5273 getpmsg                         NEW: STREAMS
5274 getpt                           NEW: Unix98 PTY
5275 getrlimit64                     NEW: LFS
5276 getutxent                       NEW: Unix98
5277 getutxid                        NEW: Unix98
5278 getutxline                      NEW: Unix98
5279 glob64                          NEW: GNU ext.
5280 globfree64                      NEW: GNU ext.
5281 gnu_get_libc_release            NEW: GNU ext.
5282 gnu_get_libc_version            NEW: GNU ext.
5283 grantpt                         NEW: Unix98 PTY
5284 host2netname                    NEW: Secure RPC
5285 iconv                           NEW: iconv
5286 iconv_close                     NEW: iconv
5287 iconv_open                      NEW: iconv
5288 if_freenameindex                NEW: IPv6
5289 if_indextoname                  NEW: IPv6
5290 if_nameindex                    NEW: IPv6
5291 if_nametoindex                  NEW: IPv6
5292 in6addr_any                     NEW: IPv6
5293 in6addr_loopback                NEW: IPv6
5294 inet6_isipv4mapped              NEW: IPv6
5295 isastream                       NEW: STREAMS
5296 iswblank                        NEW: GNU ext.
5297 key_decryptsession              NEW: Secure RPC
5298 key_decryptsession_pk           NEW: Secure RPC
5299 key_encryptsession              NEW: Secure RPC
5300 key_encryptsession_pk           NEW: Secure RPC
5301 key_gendes                      NEW: Secure RPC
5302 key_get_conv                    NEW: Secure RPC
5303 key_secretkey_is_set            NEW: Secure RPC
5304 key_setnet                      NEW: Secure RPC
5305 key_setsecret                   NEW: Secure RPC
5306 llrint                          NEW: ISO C 9x
5307 llrintf                         NEW: ISO C 9x
5308 llrintl                         NEW: ISO C 9x
5309 llround                         NEW: ISO C 9x
5310 llroundf                        NEW: ISO C 9x
5311 llroundl                        NEW: ISO C 9x
5312 log2                            NEW: ISO C 9x
5313 log2f                           NEW: ISO C 9x
5314 log2l                           NEW: ISO C 9x
5315 lrint                           NEW: ISO C 9x
5316 lrintf                          NEW: ISO C 9x
5317 lrintl                          NEW: ISO C 9x
5318 lround                          NEW: ISO C 9x
5319 lroundf                         NEW: ISO C 9x
5320 lroundl                         NEW: ISO C 9x
5321 lseek64                         NEW: LFS
5322 makecontext                     NEW: Unix98
5323 mempcpy                         NEW: GNU ext.
5324 mmap64                          NEW: LFS
5325 moncontrol                      REMOVED
5326 modify_ldt                      NEW: kernel
5327 nan                             NEW: ISO C 9x
5328 nanf                            NEW: ISO C 9x
5329 nanl                            NEW: ISO C 9x
5330 nearbyint                       NEW: ISO C 9x
5331 nearbyintf                      NEW: ISO C 9x
5332 nearbyintl                      NEW: ISO C 9x
5333 netname2host                    NEW: Secure RPC
5334 netname2user                    NEW: Secure RPC
5335 nexttoward                      NEW: ISO C 9x
5336 nexttowardf                     NEW: ISO C 9x
5337 nexttowardl                     NEW: ISO C 9x
5338 nftw                            NEW: Unix98
5339 nftw64                          NEW: LFS
5340 open64                          NEW: LFS
5341 passwd2des                      NEW: Secure RPC
5342 pow10                           NEW: GNU ext.
5343 pow10f                          NEW: GNU ext.
5344 pow10l                          NEW: GNU ext.
5345 pread                           NEW: Unix98
5346 pread64                         NEW: LFS
5347 printf_size                     NEW: GNU ext.
5348 printf_size_info                NEW: GNU ext.
5349 profil_counter                  REMOVED
5350 pthread_mutexattr_getkind_np    REPLACED
5351 pthread_mutexattr_setkind_np    REPLACED
5352 ptsname                         NEW: Unix98 PTY
5353 ptsname_r                       NEW: Unix98 PTY
5354 putc_locked                     REMOVED
5355 putchar_locked                  REMOVED
5356 putgrent                        NEW: GNU ext.
5357 putmsg                          NEW: STREAMS
5358 putpmsg                         NEW: STREAMS
5359 pututxline                      NEW: Unix98
5360 pwrite                          NEW: Unix98
5361 pwrite64                        NEW: LFS
5362 readdir64                       NEW: LFS
5363 readdir64_r                     NEW: LFS
5364 remquo                          NEW: ISO C 9x
5365 remquof                         NEW: ISO C 9x
5366 remquol                         NEW: ISO C 9x
5367 round                           NEW: ISO C 9x
5368 roundf                          NEW: ISO C 9x
5369 roundl                          NEW: ISO C 9x
5370 rtime                           NEW: GNU ext.
5371 scalbln                         NEW: ISO C 9x
5372 scalblnf                        NEW: ISO C 9x
5373 scalblnl                        NEW: ISO C 9x
5374 scandir64                       NEW: LFS
5375 sendfile                        NEW: kernel
5376 setcontext                      NEW: Unix98
5377 setrlimit64                     NEW: LFS
5378 setutxent                       NEW: Unix98
5379 sighold                         NEW: Unix98
5380 sigignore                       NEW: Unix98
5381 sigqueue                        NEW: POSIX.1b
5382 sigrelse                        NEW: Unix98
5383 sigset                          NEW: POSIX.1b
5384 sigtimedwait                    NEW: POSIX.1b
5385 sigwaitinfo                     NEW: POSIX.1b
5386 sincos                          NEW: GNU ext.
5387 sincosf                         NEW: GNU ext.
5388 sincosl                         NEW: GNU ext.
5389 statfs64                        NEW: LFS
5390 statvfs                         NEW: Unix98
5391 statvfs64                       NEW: LFS
5392 strcasestr                      NEW: GNU ext.
5393 strtoimax                       NEW: ISO C 9x
5394 strtoumax                       NEW: ISO C 9x
5395 strverscmp                      NEW: GNU ext.
5396 svcauthdes_stats                NEW: Secure RPC
5397 svcunix_create                  NEW: sunrpc etx
5398 svcunixfd_create                NEW: sunrpc ext
5399 swapcontext                     NEW: Unix98
5400 tcgetsid                        NEW: Unix98 PTY
5401 tdestroy                        NEW: GNU ext.
5402 tgamma                          NEW: ISO C 9x
5403 tgammaf                         NEW: ISO C 9x
5404 tgammal                         NEW: ISO C 9x
5405 tmpfile64                       NEW: LFS
5406 trunc                           NEW: ISO C 9x
5407 truncate64                      NEW: LFS
5408 truncf                          NEW: ISO C 9x
5409 truncl                          NEW: ISO C 9x
5410 umount2                         NEW: kernel
5411 unlockpt                        NEW: Unix98 PTY
5412 updwtmpx                        NEW: Unix98
5413 user2netname                    NEW: Secure RPC
5414 utmpxname                       NEW: Unix98
5415 versionsort                     NEW: GNU ext.
5416 versionsort64                   NEW: GNU ext.
5417 waitid                          NEW: Unix98
5418 wcscasecmp                      NEW: GNU ext.
5419 wcsncasecmp                     NEW: GNU ext.
5420 wcsnlen                         NEW: GNU ext.
5421 wcstoimax                       NEW: ISO C 9x
5422 wcstoll                         NEW: ISO C 9x
5423 wcstoull                        NEW: ISO C 9x
5424 wcstoumax                       NEW: ISO C 9x
5425 wcswcs                          NEW: Unix98
5426 wordexp                         NEW: POSIX.2
5427 wordfree                        NEW: POSIX.2
5428 write_profiling                 REMOVED
5429 xdecrypt                        NEW: Secure RPC
5430 xdr_authdes_cred                NEW: Secure RPC
5431 xdr_authdes_verf                NEW: Secure RPC
5432 xdr_cryptkeyarg                 NEW: Secure RPC
5433 xdr_cryptkeyarg2                NEW: Secure RPC
5434 xdr_cryptkeyres                 NEW: Secure RPC
5435 xdr_getcredres                  NEW: Secure RPC
5436 xdr_key_netstarg                NEW: Secure RPC
5437 xdr_key_netstres                NEW: Secure RPC
5438 xdr_keybuf                      NEW: Secure RPC
5439 xdr_keystatus                   NEW: Secure RPC
5440 xdr_netnamestr                  NEW: Secure RPC
5441 xdr_sizeof                      NEW: Secure RPC
5442 xdr_unixcred                    NEW: sunrpc ext
5443 xencrypt                        NEW: Secure RPC
5444 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
5445 \f
5446 Version 2.0.6
5447
5448 * more bug fixes
5449
5450 \f
5451 Version 2.0.5
5452
5453 * more bug fixes
5454
5455 * inet_ntoa is thread-safe
5456
5457 * updwtmp is moved from libutil to libc
5458
5459 * rewrite of cbrt function
5460
5461 * update of timezone data
5462 \f
5463 Version 2.0.4
5464
5465 * more bug fixes
5466 \f
5467 Version 2.0.3
5468
5469 * more bug fixes
5470 \f
5471 Version 2.0.2
5472
5473 * more bug fixes
5474
5475 * add atoll function
5476
5477 * fix complex problems in Berkeley DB code
5478
5479 * fix math functions
5480 \f
5481 Version 2.0.1
5482
5483 * fixed lots of header problems (especially Linux/GNU specific)
5484
5485 * dynamic loader preserves all registers
5486
5487 * Roland McGrath provided support for handling of auxiliary objects in
5488   the ELF dynamic loader.
5489
5490 * support for parallel builds is improved
5491 \f
5492 Version 2.0
5493
5494 * GNU extensions are no longer declared by default.  To enable them you
5495   must define the macro `_GNU_SOURCE' in your program or compile with
5496   `-D_GNU_SOURCE'.
5497
5498 * The library has changed from using GNU ld symbol aliases to using weak
5499   symbols where available.  The ELF object file format supports weak
5500   symbols; GNU ld also supports weak symbols in the a.out format.  (There
5501   is also now support for other GNU ld extensions in ELF.  Use the
5502   `--with-elf' option to configure to indicate you have ELF, and
5503   `--with-gnu-ld' if using GNU ld.)  This change resulted in the deletion
5504   of many files which contained only symbol aliases, reducing the size of
5505   the source and the compiled library; many other files were renamed to
5506   less cryptic names previously occupied by the symbol alias files.
5507   There is a new header file <elf.h> for programs which operate on
5508   files in the ELF format.
5509
5510 * Converted to Autoconf version 2, so `configure' has more options.
5511   Run `configure --help' to see the details.
5512
5513 * The library can now be configured to build profiling, highly-optimized
5514   (but undebuggable), and/or shared libraries (ELF with GNU ld only).  The
5515   `--enable-profile', `--enable-omitfp', and `--enable-shared' options to
5516   `configure' enable building these extra libraries.  The shared library is
5517   built by default when using both ELF and GNU ld.  When shared libraries
5518   are enabled, the new library `-ldl' is available for arbitrary run-time
5519   loading of shared objects; its interface is defined in <dlfcn.h>.  The
5520   new header file <link.h> gives access to the internals of the run-time
5521   dynamic linker, `ld.so'.  The shell script `ldd' is similar to the
5522   application of same name on other systems and it provides information
5523   about dynamically linked binaries.
5524
5525 * The C library now provides the run-time support code for profiling
5526   executables compiled with `-pg'.  Programs can control the profiling code
5527   through the interface in <sys/gmon.h>.  The `gmon.out' files written by
5528   the GNU C library can be read only by GNU `gprof' (from GNU binutils);
5529   the support for this file format was contributed by David Mosberger-Tang.
5530
5531 * The math code has been replaced with a math library based on fdlibm from
5532   Sun, and modified by JT Conklin and Ulrich Drepper with i387 support, by
5533   Ian Taylor with `float' functions and by Ulrich Drepper with `long double'
5534   functions.  The math functions now reside in a separate library,  so
5535   programs using them will need to use `-lm' their linking commands.
5536
5537 * John C. Bowman contributed optimized ix87 assembler inline functions.
5538
5539 * Ulrich Drepper has contributed support for an `/etc/nsswitch.conf'
5540   mechanism similar to that found in Solaris 2.  This is now used for the
5541   group, passwd, hosts, networks, services, protocols, rpc, ethers,
5542   shadow, netgroup, publickey, and alias databases.  The `nsswitch.conf'
5543   file controls what services are used for each individual database.  This
5544   works by loading shared libraries with names specified in `nsswitch.conf',
5545   so service modules can be changed or added at any time without even
5546   relinking any program.  Currently there are the file, db, and NIS based
5547   NSS services available.
5548
5549 * The new functions `strtoq' and `strtouq' parse integer values from
5550   strings, like `strtol' and `strtoul', but they return `long long int' and
5551   `unsigned long long int' values, respectively (64-bit quantities).
5552
5553 * The new functions `strtof' and `strtold' parse floating-point values from
5554   strings, like `strtod', but they return `float' and `long double' values,
5555   respectively (on some machines `double' and `long double' are the same).
5556
5557 * Ulrich Drepper has contributed new implementations of the floating-point
5558   printing and reading code used in the `printf' family of functions and
5559   `strtod', `strtof', and `strtold'.  These new functions are perfectly
5560   accurate, and much faster than the old ones.
5561
5562 * The implementation of the POSIX locale model was completely rewritten by
5563   Ulrich Drepper.  This includes the new programs `localedef' and `locale'
5564   to compile the POSIX locale definition.
5565
5566 * The former dummy implementations of the strcoll and strxfrm function are
5567   now replaced by fully functional code contributed by Ulrich Drepper.  The
5568   collation information comes from the POSIX locale definitions.
5569
5570 * The new header <langinfo.h> defines an interface for accessing
5571   various locale-dependent data (using the locale chosen with `setlocale').
5572
5573 * Ulrich Drepper has contributed a new suite of functions for operation on
5574   wide-character and multibyte-character strings, in <wchar.h>;
5575   and classification and case conversion of wide characters, in <wctype.h>.
5576   These new functions are conforming to the ISO C, Amendement 1 specification.
5577
5578 * There is now a second implementation of the standard I/O library available.
5579   It comes from GNU libg++ as was written by Per Bothner, heavily modified
5580   by Hongjiu Lu and made thread safe by Ulrich Drepper.
5581
5582 * You can now use positional parameter specifications in format strings
5583   for the `printf' and `scanf' families of functions.  For example,
5584   `printf ("Number %2$d, Mr %1$s\n", "Jones", 6);'' prints
5585   ``Number 6, Mr Jones''.  This is mainly useful when providing different
5586   format strings for different languages, whose grammars may dictate
5587   different orderings of the values being printed.  To support this
5588   feature, the interface for `register_printf_handler' has changed; see
5589   the header file <printf.h> for details.
5590
5591 * The `printf' and `scanf' families of functions now understand a new
5592   formatting flag for numeric conversions: the ' flag (e.g. %'d or %'f) says
5593   to group numbers as indicated by the locale; for `scanf' and friends, this
5594   says to accept as valid only a number with all the proper grouping
5595   separators in the right places.  In the default "C" locale, numbers are
5596   not grouped; but locales for specific countries will define the usual
5597   conventions (i.e. separate thousands with `,' in the US locale).
5598
5599 * The pgrp functions have been regularized, slightly incompatibly but much
5600   less confusingly.  The core functions are now `getpgid' and `setpgid',
5601   which take arguments for the PID to operate on; the POSIX.1 `getpgrp' (no
5602   argument) and BSD `setpgrp' (identical to `setpgid') functions are
5603   provided for compatibility.  There is no longer an incompatible `getpgrp'
5604   with an argument declared under _BSD_SOURCE; no BSD code uses it.
5605
5606 * The new header file <fts.h> and suite of functions simplify programs that
5607   operate on directory trees.  This code comes from 4.4 BSD.
5608
5609 * The resolver code has been updated from the BIND 4.9.5-P1 release.
5610   Parts of the code were heavily modified by Ulrich Drepper to fit in the
5611   NSS scheme used in glibc.
5612
5613 * There is a new malloc debugging hook `__memalign_hook'.
5614
5615 * There are new typedefs `ushort' for `unsigned short int' and `uint' for
5616   `unsigned int' in <sys/types.h>.  These are for compatibility only and
5617   their use is discouraged.
5618
5619 * The `-lmcheck' library to enable standard malloc debugging hooks is now
5620   done differently, so that it works even without GNU ld.
5621
5622 * New function `euidaccess' checks allowed access to a file like `access',
5623   but using the effective IDs instead of the real IDs.
5624
5625 * The time zone data files have been updated for the latest and greatest
5626   local time conventions of the countries of the world.
5627
5628 * The new function `dirfd' extracts the file descriptor used by a DIR stream;
5629   see <dirent.h>.
5630
5631 * The new functions `ecvt', `fcvt', and `gcvt' provide an obsolete interface
5632   for formatting floating-point numbers.  They are provided only for
5633   compatibility; new programs should use `sprintf' instead.  There are
5634   also equivalent function for the `long double' floating-point type and
5635   all functions also exist in a reentrant form.
5636
5637 * The new auxiliary library `-lutil' from 4.4 BSD contains various
5638   functions for maintaining the login-record files (primarily of use to
5639   system programs such as `login'), and convenient functions for
5640   allocating and initializing a pseudo-terminal (pty) device.
5641
5642 * Ulrich Drepper has contributed new support for System V style
5643   shared memory and IPC on systems that support it.
5644
5645 * Ulrich Drepper has contributed several miscellaneous new functions found
5646   in System V: The `hsearch' family of functions provide an effective
5647   implementation of hash tables; `a64l' and `l64a' provide a very simple
5648   binary to ASCII mapping; `drand48' and friends provide a 48-bit random
5649   number generator.
5650
5651 * Ulrich Drepper has contributed new reentrant counterparts for the
5652   `random' and `hsearch' families of functions; `random_r', `hsearch_r', etc.
5653
5654 * Ulrich Drepper has contributed new, highly-optimized versions of several
5655   string functions for the i486/Pentium family of processors.
5656
5657 * Ulrich Drepper has updated the Linux-specific code, based largely
5658   on work done in Hongjiu Lu's version of GNU libc for Linux.
5659   The GNU library now supports Linux versions 2.0.10 and later,
5660   using the ELF object file format (i[3456]86-*-linux).
5661
5662 * Andreas Schwab has ported the C library to Linux/m68k (m68k-*-linux).
5663
5664 * David Mosberger-Tang and Richard Henderson have ported the C library
5665   to Linux/Alpha (alpha-*-linux).  Richard Henderson contributed the
5666   dynamic linking support for ELF/Alpha.
5667
5668 * Richard Henderson contributed several Alpha optimized assembler function
5669   for arithmetic and string handling.
5670
5671 * Ulrich Drepper has contributed a new set of message catalog functions to
5672   support multiple languages using the <libintl.h> interface, for use with
5673   his new package GNU gettext.  Translation volunteers have contributed
5674   catalogs of the library's messages in Spanish, German, and Korean.
5675
5676 * For compatibility with XPG4, Ulrich Drepper has contributed the `gencat'
5677   program and the `catgets' function for reading the catalog files it
5678   creates.  (The <libintl.h> interface is preferred; we include the
5679   <nl_types.h> interface using `catgets' only for source compatibility with
5680   programs already written to use it.)
5681
5682 * New header file <values.h> gives SVID-compatible names for <limits.h>
5683   constants.
5684
5685 * Various new macros, declarations, and small header files for compatibility
5686   with 4.4 BSD.
5687
5688 * New function `group_member' is a convenient way to check if a process has
5689   a given effective group ID.
5690
5691 * When using GCC 2.7 and later, the socket functions are now declared in a
5692   special way so that passing an argument of type `struct sockaddr_in *',
5693   `struct sockaddr_ns *', or `struct sockaddr_un *' instead of the generic
5694   `struct sockaddr *' type, does not generate a type-clash warning.
5695
5696 * New function `error' declared in header file <error.h> is a convenient
5697   function for printing error messages and optionally exiting; this is the
5698   canonical function used in GNU programs.  The new functions `err', `warn',
5699   and friends in header file <err.h> are the canonical 4.4 BSD interface for
5700   doing the same thing.
5701
5702 * The <glob.h> interface has several new flags from 4.4 BSD that extend the
5703   POSIX.2 `glob' function to do ~ and {...} expansion.
5704
5705 * New function `unsetenv' complements `setenv' for compatibility with 4.4 BSD.
5706   `clearenv' which is used in POSIX.9 is also available.
5707
5708 * New function `getsid' returns session ID number on systems that support it.
5709
5710 * We have incorporated the 4.4 BSD `db' library (version 1.85).  New header
5711   files <db.h> and <mpool.h> provide a rich set of functions for several
5712   types of simple databases stored in memory and in files, and <ndbm.h> is
5713   an old `ndbm'-compatible interface using the `db' functions.  Link with
5714   `-ldb' to get these functions.
5715
5716 * New macro `strdupa' copies a string like `strdup', but uses local stack
5717   space from `alloca' instead of dynamic heap space from `malloc'.
5718
5719 * New function `strnlen' is like `strlen' but searches only a given maximum
5720   number of characters for the null terminator.  `stpncpy', `strndup' and
5721   `strndupa' are similar variants for the `stpcpy', `strdup' and `strdupa'
5722   function.
5723
5724 * New function `statfs' in header <sys/statfs.h>.
5725
5726 * The new <argz.h> and <envz.h> interfaces contributed by Miles Bader
5727   provide convenient functions for operating on blocks of null-terminated
5728   strings.
5729
5730 * A new suite of functions in <utmp.h> handle all the details of reading
5731   and writing the utmp file.
5732
5733 * An implementation of the NIS/YP(tm) based NSS service was contributed by
5734   Thorsten Kukuk.
5735
5736 * Paul Eggert and Ulrich Drepper modified the `strftime' function to be
5737   completely POSIX compliant and also implemented the extended functionality
5738   to handle alternate digit representation and alternate era date formats.
5739
5740 * Ulrich Drepper provided an implementation of the `strptime' function
5741   defined in XPG4.2 which transforms a string into a `struct tm' value.
5742
5743 * Paul Eggert provided the tzselect shell script as part of the timezone
5744   code.  The shell script makes it easy to select the correct timezone
5745   specification.
5746
5747 * The implementation of the malloc family of functions is completely replaced
5748   by a new implementation by Doug Lea with many improvements by Wolfram Gloger.
5749   The implementation uses the mmap function (if available) and it is
5750   optimized for the use in multi threaded programs.
5751
5752 * Ulrich Drepper contributed a MD5 "encryption" for the crypt family of
5753   functions.  This new functionality is usable by specifying a special
5754   salt string and it is compatible with implementation on *BSD systems.
5755
5756 * Lots of functions from the XPG4.2 standard were added by Ulrich Drepper:
5757   `getsubopt' to handle second level command line options, `bsd_signal'
5758   to access BSD style `signal' functionality, the obsolete `regexp' style
5759   expression matcher.
5760
5761 * the `lchown' function is available on system which support this
5762   functionality.
5763
5764 * The implementation of the shadow password handling function was contributed
5765   by Ulrich Drepper.
5766
5767 * David Mosberger-Tang changed the SunRPC implementation to be 64bit safe.
5768
5769 * POSIX.1g support was added.  The <sys/select.h> header is available,
5770   `isfdtype' and `pselect' are implemented.  Craig Metz contributed an
5771   implementation of `getaddrinfo'.
5772 \f
5773 Version 1.09
5774
5775 * For cross-compilation you should now set `BUILD_CC' instead of `HOST_CC'.
5776
5777 * New header file <fstab.h> and new functions `getfsspec', `getfsent' and
5778   friends, for parsing /etc/fstab.  This code comes from 4.4 BSD.
5779
5780 * The new function `daemon' from 4.4 BSD is useful for server programs that
5781   want to put themselves in the background.
5782
5783 * Joel Sherrill has contributed support for several standalone boards that
5784   run without an operating system.
5785
5786 * `printf', `scanf' and friends now accept a `q' type modifier for long
5787   long int as well as `ll'.  Formats using these might be `%qu' or `%lld'.
5788
5789 * All of the code taken from BSD (notably most of the math and networking
5790   routines) has been updated from the BSD 4.4-Lite release.
5791
5792 * The resolver code has been updated from the BIND-4.9.3-BETA9 release.
5793
5794 * The new functions `getdomainname' and `setdomainname' fetch or change the
5795   YP/NIS domain name.  These are system calls which exist on systems which
5796   have YP (aka NIS).
5797
5798 * The time zone data files have been updated for the latest international
5799   conventions.
5800
5801 * The SunRPC programs `portmap' and `rpcinfo' are now installed in
5802   $(sbindir) (usually /usr/local/sbin) instead of $(bindir).
5803 \f
5804 Version 1.08
5805
5806 * The C library now includes support for Sun RPC, from Sun's free
5807   RPCSRC-4.0 distribution.  The `portmap', `rpcinfo', and `rpcgen' programs
5808   are included.  (There is still no support for YP.)
5809
5810 * Tom Quinn has contributed a port of the C library to SGI machines running
5811   Irix 4 (mips-sgi-irix4).
5812
5813 * The new `lockf' function is a simplified interface to the locking
5814   facilities of `fcntl', included for compatibility.
5815
5816 * New time functions `timegm', `timelocal', and `dysize' for compatibility.
5817
5818 * New header file <sys/timeb.h> and new function `ftime' for compatibility.
5819
5820 * New header files <poll.h> and <sys/poll.h> and new function `poll' for
5821   compatibility.
5822
5823 * The error message printed by `assert' for a failed assertion now includes
5824   the name of the program (if using GNU ld) and the name of the calling
5825   function (with versions of GCC that support this).
5826
5827 * The `psignal' function is now declared in <signal.h>, not <stdio.h>.
5828
5829 * The library now includes the <sys/mman.h> header file and memory
5830   management functions `mmap', `munmap', `mprotect', `msync', and
5831   `madvise', on systems that support those facilities.
5832
5833 * The interface for `mcheck' has changed slightly: the function called to
5834   abort the program when an allocation inconsistency is detected now takes
5835   an argument that indicates the type of failure.  The new function
5836   `mprobe' lets you request a consistency check for a particular block at
5837   any time (checks are normally done only when you call `free' or `realloc'
5838   on a block).
5839
5840 * It is now possible to easily cross-compile the C library, building on one
5841   system a library to run on another machine and/or operating system.  All
5842   you need to do is set the variable `HOST_CC' in `configparms' to the
5843   native compiler for programs to run on the machine you are building on (a
5844   few generator programs are used on Unix systems); set `CC' to the
5845   cross-compiler.
5846
5847 * The new function `fexecve' (only implemented on the GNU system) executes
5848   a program file given a file descriptor already open on the file.
5849 \f
5850 Version 1.07
5851
5852 * Brendan Kehoe has contributed most of a port to the DEC Alpha
5853   running OSF/1 (alpha-dec-osf1).  He says it is 75% complete.
5854
5855 * You can set the variable `libprefix' in `configparms' to specify a prefix
5856   to be prepended to installed library files; this makes it easy to install
5857   the GNU C library to be linked as `-lgnuc' or whatever.
5858
5859 * The new `stpncpy' is a cross between `stpcpy' and `strncpy': It
5860   copies a limited number of characters from a string, and returns the
5861   address of the last character written.
5862
5863 * You no longer need to check for whether the installed `stddef.h' is
5864   compatible with the GNU C library.  configure now checks for you.
5865
5866 * You can now define a per-stream `fileno' function to convert the
5867   stream's cookie into an integral file descriptor.
5868
5869 * ``malloc (0)'' no longer returns a null pointer.  Instead, it
5870   allocates zero bytes of storage, and returns a unique pointer which
5871   you can pass to `realloc' or `free'.  The behavior is undefined if
5872   you dereference this pointer.
5873
5874 * The C library now runs on Sony NEWS m68k machines running either
5875   NewsOS 3 or NewsOS 4.
5876
5877 * The new `syscall' function is a system-dependent primitive function
5878   for invoking system calls.  It has the canonical behavior on Unix
5879   systems, including unreliable return values for some calls (such as
5880   `pipe', `fork' and `getppid').
5881
5882 * The error code `EWOULDBLOCK' is now obsolete; it is always defined
5883   to `EAGAIN', which is the preferred name.  On systems whose kernels
5884   use two distinct codes, the C library now translates EWOULDBLOCK to
5885   EAGAIN in every system call function.
5886 \f
5887 Version 1.06
5888
5889 * The GNU C Library Reference Manual is now distributed with the library.
5890   `make dvi' will produce a DVI file of the printed manual.
5891   `make info' will produce Info files that you can read on line using C-h i
5892   in Emacs or the `info' program.
5893   Please send comments on the manual to bug-glibc-manual@gnu.org.
5894
5895 * The library now supports SVR4 on i386s (i386-unknown-sysv4).
5896
5897 * Brendan Kehoe has contributed a port to Sun SPARCs running Solaris 2.
5898
5899 * Jason Merrill has contributed a port to the Sequent Symmetry running
5900   Dynix version 3 (i386-sequent-dynix).
5901
5902 * The library has been ported to i386s running SCO 3.2.4 (also known as SCO
5903   ODT 2.0; i386-unknown-sco3.2.4) or SCO 3.2 (i386-unknown-sco3.2).
5904
5905 * New function `memory_warnings' lets you arrange to get warnings when
5906   malloc is running out of memory to allocate, like Emacs gives you.
5907
5908 * The C library now contains the relocating allocator used in Emacs 19 for
5909   its editing buffers.  This allocator (ralloc) minimizes allocation
5910   overhead and fragmentation by moving allocated regions around whenever it
5911   needs to.  You always refer to a ralloc'd region with a "handle" (a
5912   pointer to a pointer--an object of type `void **').
5913
5914 * There is a new `printf' format: `%m' gives you the string corresponding
5915   to the error code in `errno'.
5916
5917 * In `scanf' formats, you can now use `%as' or `%a[' to do the normal `%s'
5918   or `%[' conversion, but instead of filling in a fixed-sized buffer you
5919   pass, the `a' modifier says to fill in a `char **' you pass with a
5920   malloc'd string.
5921
5922 * The `fnmatch' function supports the new flag bits `FNM_LEADING_DIR' and
5923   `FNM_CASEFOLD'.  `FNM_LEADING_DIR' lets a pattern like `foo*' match a
5924   name like `foo/bar'.  `FNM_CASEFOLD' says to ignore case in matching.
5925
5926 * `mkstemp' is a traditional Unix function to atomically create and open a
5927   uniquely-named temporary file.
5928 \f
5929 Version 1.05
5930
5931 * The standard location for the file that says what the local timezone is
5932   has changed again.  It is now `/usr/local/etc/localtime' (or more
5933   precisely, `${prefix}/etc/localtime') rather than `/etc/localtime'.
5934
5935 * The distribution no longer contains any files with names longer than 14
5936   characters.
5937
5938 * `struct ttyent' has two new flag bits: TTY_TRUSTED and TTY_CONSOLE.
5939   These are set by the new `trusted' and `console' keywords in `/etc/ttys'.
5940
5941 * New functions `ttyslot' and `syslog' from 4.4 BSD.
5942 \f
5943 Version 1.04
5944
5945 * The configuration process has changed quite a bit.  The `configure'
5946   script is now used just like the configuration scripts for other GNU
5947   packages.  The `sysdeps' directory hierarchy is much rearranged.
5948   The file `INSTALL' explains the new scheme in detail.
5949
5950 * The header files no longer need to be processed into ANSI C and
5951   traditional C versions.  There is just one set of files to install, and
5952   it will work with ANSI or old C compilers (including `gcc -traditional').
5953
5954 * Brendan Kehoe and Ian Lance Taylor have ported the library to the
5955   MIPS DECStation running Ultrix 4.
5956
5957 * The Sun 4 startup code (crt0) can now properly load SunOS 4 shared libraries.
5958   Tom Quinn contributed the initial code.  The GNU C library can NOT yet be
5959   made itself into a shared library.
5960
5961 * Yet further improved support for the i386, running 4.3 BSD-like systems
5962   (such as Mach 3 with the Unix single-server), or System V.
5963
5964 * New function `strncasecmp' to do case-insensitive string comparison
5965   with limited length.
5966
5967 * New function `strsep' is a reentrant alternative to `strtok'.
5968
5969 * New functions `scandir' and `alphasort' for searching directories.
5970
5971 * New function `setenv' is a better interface to `putenv'.
5972
5973 * Ian Lance Taylor has contributed an implementation of the SVID `ftw'
5974   function for traversing a directory tree.
5975
5976 * The GNU obstack package is now also part of the C library.
5977   The new function `open_obstack_stream' creates a stdio stream that
5978   writes onto an obstack; `obstack_printf' and `obstack_vprintf' do
5979   formatted output directly to an obstack.
5980
5981 * Miscellaneous new functions: reboot, nice, sigaltstack (4.4 BSD only),
5982   cfmakeraw, getusershell, getpass, swab, getttyent, seteuid, setegid.
5983
5984 * `FNM_FILE_NAME' is another name for `FNM_PATHNAME', used with `fnmatch'.
5985
5986 * The new functions `strfry' and `memfrob' do mysterious and wonderful
5987   things to your strings.
5988
5989 * There are some new test programs: test-fseek, testmb, and testrand.
5990
5991 * Some work has been done to begin porting the library to 4.4 BSD and Linux.
5992   These ports are not finished, but are a good starting place for really
5993   supporting those systems.
5994
5995 * `/etc/localtime' is now the standard location for the file that says what
5996   the local timezone is, rather than `/usr/local/lib/zoneinfo/localtime'.
5997   This follows the general principle that `/etc' is the place for all local
5998   configuration files.
5999
6000 * The C library header files now use `extern "C"' when used by the C++
6001   compiler, so the C library should now work with C++ code.
6002
6003 * The header file <bstring.h> is gone.  <string.h> now declares bcopy,
6004   bcmp, bzero, and ffs.  (Update: nowadays these functions are declared
6005   in <strings.h>.)
6006
6007 * Mike Haertel (of GNU e?grep and malloc fame) has written a new sorting
6008   function which uses the `merge sort' algorithm, and is said to be
6009   significantly faster than the old GNU `qsort' function.  Merge sort is
6010   now the standard `qsort' function.  The new algorithm can require a lot
6011   of temporary storage; so, the old sorting function is called when the
6012   required storage is not available.
6013
6014 * The C library now includes Michael Glad's Ultra Fast Crypt, which
6015   provides the Unix `crypt' function, plus some other entry points.
6016
6017 * The code and header files taken from 4.4 BSD have been updated with the
6018   latest files released from Berkeley.
6019 \f
6020 ----------------------------------------------------------------------
6021 Copyright information:
6022
6023 Copyright (C) 1992-2020 Free Software Foundation, Inc.
6024
6025    Permission is granted to anyone to make or distribute verbatim copies
6026    of this document as received, in any medium, provided that the
6027    copyright notice and this permission notice are preserved,
6028    thus giving the recipient permission to redistribute in turn.
6029
6030    Permission is granted to distribute modified versions
6031    of this document, or of portions of it,
6032    under the above conditions, provided also that they
6033    carry prominent notices stating who last changed them.
6034 \f
6035 Local variables:
6036 version-control: never
6037 fill-column: 72
6038 End: