Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
openSUSE:Leap:15.5:Update
util-linux-systemd.31379
util-linux-ipcs-shmall-overflow-1.patch
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File util-linux-ipcs-shmall-overflow-1.patch of Package util-linux-systemd.31379
From 7a08784ab053d6aa30db990cbec1fd35b34ed00a Mon Sep 17 00:00:00 2001 From: Vasilis Liaskovitis <vliaskovitis@suse.com> Date: Fri, 15 Jan 2021 15:00:11 +0100 Subject: [PATCH 1/2] ipcs: Avoid shmall overflows Avoid computing the number of bytes in shmall, by only computing and printing the number of Kbytes. This avoids some overflows, e.g. $ echo "4503599627370496" > /proc/sys/kernel/shmall $ ipcs -l | grep 'max total shared memory' Before: max total shared memory (kbytes) = 18014398509481980 After: max total shared memory (kbytes) = 18014398509481984 $ echo "99993599627370500" > /proc/sys/kernel/shmall 99993599627370500 $ ipcs -l | grep 'max total shared memory' Before: max total shared memory (kbytes) = 18014398509481980 After: max total shared memory (kbytes) = 399974398509482000 v1->v2: Print the non-overflow KB value only for IPC_UNIT_KB and IPC_UNIT_DEFAULT. This way --bytes and --human options will still get an expected output (but not avoiding the overflow). Signed-off-by: Vasilis Liaskovitis <vliaskovitis@suse.com> Signed-off-by: Karel Zak <kzak@redhat.com> --- sys-utils/ipcs.c | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/sys-utils/ipcs.c b/sys-utils/ipcs.c index fc6fba4a6..79a6516e6 100644 --- a/sys-utils/ipcs.c +++ b/sys-utils/ipcs.c @@ -216,13 +216,19 @@ static void do_shm (char format, int unit) ipc_print_size(unit == IPC_UNIT_DEFAULT ? IPC_UNIT_KB : unit, _("max seg size"), lim.shmmax, "\n", 0); - tmp = (uint64_t) lim.shmall * pgsz; - /* overflow handling, at least we don't print ridiculous small values */ - if (lim.shmall != 0 && tmp / lim.shmall != pgsz) { - tmp = UINT64_MAX - (UINT64_MAX % pgsz); + if (unit == IPC_UNIT_KB || unit == IPC_UNIT_DEFAULT) { + ipc_print_size(IPC_UNIT_DEFAULT, + _("max total shared memory (kbytes)"), (pgsz / 1024) * + (uint64_t) lim.shmall, "\n", 0); + } + else { + tmp = (uint64_t) lim.shmall * pgsz; + /* overflow handling, at least we don't print ridiculous small values */ + if (lim.shmall != 0 && tmp / lim.shmall != pgsz) + tmp = UINT64_MAX - (UINT64_MAX % pgsz); + + ipc_print_size(unit, _("max total shared memory"), tmp, "\n", 0); } - ipc_print_size(unit == IPC_UNIT_DEFAULT ? IPC_UNIT_KB : unit, - _("max total shared memory"), tmp, "\n", 0); ipc_print_size(unit == IPC_UNIT_DEFAULT ? IPC_UNIT_BYTES : unit, _("min seg size"), lim.shmmin, "\n", 0); return; -- 2.30.1
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor