Go to file
Simon Kissane bde1218720 gmon: fix memory corruption issues [BZ# 30101]
V2 of this patch fixes an issue in V1, where the state was changed to ON not
OFF at end of _mcleanup. I hadn't noticed that (counterintuitively) ON=0 and
OFF=3, hence zeroing the buffer turned it back on. So set the state to OFF
after the memset.

1. Prevent double free, and reads from unallocated memory, when
   _mcleanup is (incorrectly) called two or more times in a row,
   without an intervening call to __monstartup; with this patch, the
   second and subsequent calls effectively become no-ops instead.
   While setting tos=NULL is minimal fix, safest action is to zero the
   whole gmonparam buffer.

2. Prevent memory leak when __monstartup is (incorrectly) called two
   or more times in a row, without an intervening call to _mcleanup;
   with this patch, the second and subsequent calls effectively become
   no-ops instead.

3. After _mcleanup, treat __moncontrol(1) as __moncontrol(0) instead.
   With zeroing of gmonparam buffer in _mcleanup, this stops the
   state incorrectly being changed to GMON_PROF_ON despite profiling
   actually being off. If we'd just done the minimal fix to _mcleanup
   of setting tos=NULL, there is risk of far worse memory corruption:
   kcount would point to deallocated memory, and the __profil syscall
   would make the kernel write profiling data into that memory,
   which could have since been reallocated to something unrelated.

4. Ensure __moncontrol(0) still turns off profiling even in error
   state. Otherwise, if mcount overflows and sets state to
   GMON_PROF_ERROR, when _mcleanup calls __moncontrol(0), the __profil
   syscall to disable profiling will not be invoked. _mcleanup will
   free the buffer, but the kernel will still be writing profiling
   data into it, potentially corrupted arbitrary memory.

Also adds a test case for (1). Issues (2)-(4) are not feasible to test.

Signed-off-by: Simon Kissane <skissane@gmail.com>
Reviewed-by: DJ Delorie <dj@redhat.com>
2023-02-22 21:03:30 -05:00
argp Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
assert Use __builtin_FILE instead of __FILE__ in assert in C++. 2023-02-10 17:12:40 +00:00
benchtests Replace rawmemchr (s, '\0') with strchr 2023-02-06 16:16:19 +00:00
bits [hurd] Add MTU_DISCOVER values 2023-02-15 15:14:06 +01:00
catgets Update copyright dates not handled by scripts/update-copyrights 2023-01-06 21:45:36 +00:00
ChangeLog.old Create ChangeLog.old/ChangeLog.26. 2023-01-31 22:27:45 -05:00
conform Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
crypt Use uintptr_t instead of performing pointer subtraction with a null pointer 2023-02-17 17:07:44 -03:00
csu elf: Fix GL(dl_phdr) and GL(dl_phnum) for static builds [BZ #29864] 2023-01-12 13:54:34 -03:00
ctype Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
debug stdio-common: Handle -1 buffer size in __sprintf_chk & co (bug 30039) 2023-01-25 08:01:00 +01:00
dirent Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
dlfcn Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
elf gmon: improve mcount overflow handling [BZ# 27576] 2023-02-22 21:00:14 -05:00
gmon gmon: fix memory corruption issues [BZ# 30101] 2023-02-22 21:03:30 -05:00
gnulib Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
grp Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
gshadow Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
hesiod Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
htl Fix typos in comments 2023-02-12 16:34:28 +01:00
hurd hurd: Use proper integer types 2023-02-20 00:33:47 +01:00
iconv iconv: Remove _STRING_ARCH_unaligned usage 2023-02-17 15:56:54 -03:00
iconvdata iconv: Remove _STRING_ARCH_unaligned usage for get/set macros 2023-02-17 15:56:54 -03:00
include string: Remove string_private.h 2023-02-17 15:56:54 -03:00
inet C2x strtol binary constant handling 2023-02-16 23:02:40 +00:00
intl Replace rawmemchr (s, '\0') with strchr 2023-02-06 16:16:19 +00:00
io Replace rawmemchr (s, '\0') with strchr 2023-02-06 16:16:19 +00:00
libio stdio: Do not ignore posix_spawn error on popen (BZ #29016) 2023-02-14 15:30:35 -03:00
locale C2x strtol binary constant handling 2023-02-16 23:02:40 +00:00
localedata Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
login Update copyright dates not handled by scripts/update-copyrights 2023-01-06 21:45:36 +00:00
mach mach: Use PAGE_SIZE 2023-02-20 00:46:36 +01:00
malloc malloc: remove redundant check of unsorted bin corruption 2023-02-22 16:56:45 -05:00
manual gmon: improve mcount overflow handling [BZ# 27576] 2023-02-22 21:00:14 -05:00
math update auto-libm-test-out-hypot 2023-02-14 16:18:21 +01:00
mathvec Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
misc Use uintptr_t instead of performing pointer subtraction with a null pointer 2023-02-17 17:07:44 -03:00
nis Replace rawmemchr (s, '\0') with strchr 2023-02-06 16:16:19 +00:00
nptl Remove pthread-pi-defines.sym 2023-02-03 17:59:55 +01:00
nptl_db Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
nscd Use uintptr_t instead of performing pointer subtraction with a null pointer 2023-02-17 17:07:44 -03:00
nss Use uintptr_t instead of performing pointer subtraction with a null pointer 2023-02-17 17:07:44 -03:00
po Update all PO files in preparation for release. 2023-01-31 17:51:40 -05:00
posix __glob64_time64: Fix typo for stub_warning call (BZ #30146) 2023-02-20 13:44:48 +01:00
pwd Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
resolv C2x strtol binary constant handling 2023-02-16 23:02:40 +00:00
resource Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
rt hurd: Implement SHM_ANON 2023-02-01 23:36:11 +01:00
scripts Use Linux 6.2 in build-many-glibcs.py 2023-02-22 21:37:03 +00:00
setjmp Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
shadow Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
signal Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
socket Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
soft-fp Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
stdio-common stdio: Do not ignore posix_spawn error on popen (BZ #29016) 2023-02-14 15:30:35 -03:00
stdlib stdlib: Undo post review change to 16adc58e73 [BZ #27749] 2023-02-20 09:32:43 -03:00
string string: Disable stack protector in early static initialization 2023-02-08 17:14:03 -03:00
sunrpc sunrpc: Suppress GCC -O1 warning on user2netname [BZ #19444] 2023-01-11 17:50:25 -03:00
support Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
sysdeps Ignore MAP_VARIABLE in tst-mman-consts.py 2023-02-22 21:36:34 +00:00
sysvipc Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
termios Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
time Use 64-bit time_t interfaces in strftime and strptime (bug 30053) 2023-02-07 10:15:09 +01:00
timezone Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
wcsmbs C2x strtol binary constant handling 2023-02-16 23:02:40 +00:00
wctype Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
.clang-format Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
.gitattributes Assume __NR_openat is always defined 2016-03-23 23:35:08 +01:00
.gitignore Add *.pyc to .gitignore 2015-05-18 15:26:26 +05:30
abi-tags Remove the bulk of the NaCl port. 2017-05-20 08:09:10 -04:00
aclocal.m4 configure: Move nm, objdump, and readelf to LIBC_PROG_BINUTILS 2023-01-12 09:05:09 -03:00
config.h.in C-SKY: Strip hard float abi from hard float feature. 2023-02-07 16:34:24 +08:00
config.make.in Revert "Detect ld.so and libc.so version inconsistency during startup" 2022-08-25 18:46:43 +02:00
configure configure: Move nm, objdump, and readelf to LIBC_PROG_BINUTILS 2023-01-12 09:05:09 -03:00
configure.ac configure: Move nm, objdump, and readelf to LIBC_PROG_BINUTILS 2023-01-12 09:05:09 -03:00
CONTRIBUTED-BY Remove "Contributed by" lines 2021-09-03 22:06:44 +05:30
COPYING
COPYING.LIB
extra-lib.mk Rename cppflags-iterator.mk to libof-iterator.mk, remove extra-modules.mk. 2017-05-09 07:06:29 -04:00
gen-locales.mk Improve gen-locales.mk and gen-locale.sh to make test files with @ options work 2018-02-27 17:01:57 +01:00
INSTALL Update install.texi, and regenerate INSTALL. 2023-01-31 17:51:40 -05:00
libc-abis riscv: support GNU indirect function 2021-01-10 21:25:13 -05:00
libof-iterator.mk Rename cppflags-iterator.mk to libof-iterator.mk, remove extra-modules.mk. 2017-05-09 07:06:29 -04:00
LICENSES arc4random: simplify design for better safety 2022-07-27 08:58:27 -03:00
MAINTAINERS Add MAINTAINERS 2017-05-11 13:38:30 -04:00
Makeconfig Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
Makefile Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
Makefile.help Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
Makefile.in New make target to only build benchmark binaries 2016-04-20 10:23:28 +05:30
Makerules Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
NEWS C2x strtol binary constant handling 2023-02-16 23:02:40 +00:00
o-iterator.mk
README LoongArch: Update NEWS and README for the LoongArch port. 2022-07-26 12:35:12 -03:00
Rules Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
SHARED-FILES Mention today's regex merge in SHARED-FILES 2021-09-21 18:00:10 -07:00
shlib-versions nss: Do not mention NSS test modules in <gnu/lib-names.h> 2022-03-11 08:24:04 +01:00
test-skeleton.c Update copyright dates with scripts/update-copyrights 2023-01-06 21:14:39 +00:00
version.h Open master branch for glibc 2.38 development 2023-01-31 22:39:21 -05:00

This directory contains the sources of the GNU C Library.
See the file "version.h" for what release version you have.

The GNU C Library is the standard system C library for all GNU systems,
and is an important part of what makes up a GNU system.  It provides the
system API for all programs written in C and C-compatible languages such
as C++ and Objective C; the runtime facilities of other programming
languages use the C library to access the underlying operating system.

In GNU/Linux systems, the C library works with the Linux kernel to
implement the operating system behavior seen by user applications.
In GNU/Hurd systems, it works with a microkernel and Hurd servers.

The GNU C Library implements much of the POSIX.1 functionality in the
GNU/Hurd system, using configurations i[4567]86-*-gnu.

When working with Linux kernels, this version of the GNU C Library
requires Linux kernel version 3.2 or later.

Also note that the shared version of the libgcc_s library must be
installed for the pthread library to work correctly.

The GNU C Library supports these configurations for using Linux kernels:

	aarch64*-*-linux-gnu
	alpha*-*-linux-gnu
	arc*-*-linux-gnu
	arm-*-linux-gnueabi
	csky-*-linux-gnuabiv2
	hppa-*-linux-gnu
	i[4567]86-*-linux-gnu
	x86_64-*-linux-gnu	Can build either x86_64 or x32
	ia64-*-linux-gnu
	loongarch64-*-linux-gnu Hardware floating point, LE only.
	m68k-*-linux-gnu
	microblaze*-*-linux-gnu
	mips-*-linux-gnu
	mips64-*-linux-gnu
	or1k-*-linux-gnu
	powerpc-*-linux-gnu	Hardware or software floating point, BE only.
	powerpc64*-*-linux-gnu	Big-endian and little-endian.
	s390-*-linux-gnu
	s390x-*-linux-gnu
	riscv32-*-linux-gnu
	riscv64-*-linux-gnu
	sh[34]-*-linux-gnu
	sparc*-*-linux-gnu
	sparc64*-*-linux-gnu

If you are interested in doing a port, please contact the glibc
maintainers; see https://www.gnu.org/software/libc/ for more
information.

See the file INSTALL to find out how to configure, build, and install
the GNU C Library.  You might also consider reading the WWW pages for
the C library at https://www.gnu.org/software/libc/.

The GNU C Library is (almost) completely documented by the Texinfo manual
found in the `manual/' subdirectory.  The manual is still being updated
and contains some known errors and omissions; we regret that we do not
have the resources to work on the manual as much as we would like.  For
corrections to the manual, please file a bug in the `manual' component,
following the bug-reporting instructions below.  Please be sure to check
the manual in the current development sources to see if your problem has
already been corrected.

Please see https://www.gnu.org/software/libc/bugs.html for bug reporting
information.  We are now using the Bugzilla system to track all bug reports.
This web page gives detailed information on how to report bugs properly.

The GNU C Library is free software.  See the file COPYING.LIB for copying
conditions, and LICENSES for notices about a few contributions that require
these additional notices to be distributed.  License copyright years may be
listed using range notation, e.g., 1996-2015, indicating that every year in
the range, inclusive, is a copyrightable year that would otherwise be listed
individually.