[Bugs] [Bug 1734423] New: interrupts leak memory
bugzilla at redhat.com
bugzilla at redhat.com
Tue Jul 30 14:00:51 UTC 2019
https://bugzilla.redhat.com/show_bug.cgi?id=1734423
Bug ID: 1734423
Summary: interrupts leak memory
Product: Red Hat Gluster Storage
Version: rhgs-3.5
Status: NEW
Component: fuse
Assignee: atumball at redhat.com
Reporter: csaba at redhat.com
QA Contact: rhinduja at redhat.com
CC: bugs at gluster.org, rhs-bugs at redhat.com,
sankarshan at redhat.com, storage-qa-internal at redhat.com
Depends On: 1728047
Target Milestone: ---
Classification: Red Hat
+++ This bug was initially created as a clone of Bug #1728047 +++
Description of problem:
When the glusterfs fuse client gets an INTERRUPT message (ie. a process gets
SIGINT while in a syscall to the filesystem), not all data allocated by the
handler code is freed.
Version-Release number of selected component (if applicable):
>= 6.0
The issue appears with the introduction of the interrupt handling framework.
How reproducible:
Always
Steps to Reproduce:
1. Compile the test helper of the tests/features/interrupt.t test,
open_and_sleep.c:
$ gcc -o open_and_sleep tests/features/open_and_sleep.c
2. Mount a glusterfs volume
3. Run the command used in tests/features/interrupt.t in a loop against some
file in the mount:
$ while :; do ./open_and_sleep <SOME-FILE> | { sleep 0.1; xargs -n1 kill
-INT; }
3. Take statedumps at regular intervals and check gf_fuse_mt_iov_base memusage:
# grep -A5 gf_fuse_mt_iov_base <STATEDUMP>
Actual results:
Values of size and num_alloc fields monotonously grow with time across
statedumps.
Expected results:
Values of size and num_alloc fields stay low across statedumps.
--- Additional comment from Csaba Henk on 2019-07-09 00:11:10 CEST ---
Command in reproduction step 3. is incomplete. It should be:
$ while :; do ./open_and_sleep <SOME-FILE> | { sleep 0.1; xargs -n1 kill
-INT; }; done
Improved version which also displays a counter:
$ i=1; while :; do echo -en "\r$i "; ./open_and_sleep <SOME-FILE> | { sleep
0.1; xargs -n1 kill -INT; }; i=$(($i+1)); done
--- Additional comment from Worker Ant on 2019-07-09 11:10:00 CEST ---
REVIEW: https://review.gluster.org/23016 (fuse: add missing GF_FREE to
fuse_interrupt) posted (#1) for review on master by Csaba Henk
--- Additional comment from Worker Ant on 2019-07-25 18:46:43 CEST ---
REVIEW: https://review.gluster.org/23016 (fuse: add missing GF_FREE to
fuse_interrupt) merged (#4) on master by Amar Tumballi
Referenced Bugs:
https://bugzilla.redhat.com/show_bug.cgi?id=1728047
[Bug 1728047] interrupts leak memory
--
You are receiving this mail because:
You are on the CC list for the bug.
More information about the Bugs
mailing list