source:
trunk/server/common/patches/openafs-afs_conn-overcounts.patch
@
2659
Last change on this file since 2659 was 2659, checked in by andersk, 8 years ago | |
---|---|
File size: 2.7 KB |
-
src/afs/afs_bypasscache.c
From 54c0ee608f4afd2b178c9b60eabfc3564293d996 Mon Sep 17 00:00:00 2001 From: Andrew Deason <adeason@sinenomine.net> Date: Sun, 14 Sep 2014 14:10:11 -0500 Subject: [PATCH] afs: Fix some afs_conn overcounts The usual pattern of using afs_Conn looks like this: do { tc = afs_Conn(...); if (tc) { code = /* ... */ } else { code = -1; } } while (afs_Analyze(...)); The afs_Analyze call, amongst other things, puts back the reference to the connection obtained from afs_Conn. If anything inside the do/while block exits that block without calling afs_Analyze or afs_PutConn, we will leak a reference to the conn. A few places currently do this, by jumping out of the loop with 'goto's. Specifically, in afs_dcache.c and afs_bypasscache.c. These locations currently leak references to our connection object (and to the underlying Rx connection object), which can cause problems over time. Specifically, this can cause a panic when the refcount overflows and becomes negative, causing a panic message that looks like: afs_PutConn: refcount imbalance 0xd34db33f -32768 To avoid this, make sure we afs_PutConn in these cases where we 'goto' out of the afs_Conn/afs_Analyze loop. Perhaps ideally we should cause afs_Analyze itself to be called in these situations, but for now just fix the problem with the least amount of impact possible. FIXES 131885 Change-Id: I3a52f8ccef24f01d04c02db0a4b711405360e323 Reviewed-on: http://gerrit.openafs.org/11464 Reviewed-by: Benjamin Kaduk <kaduk@mit.edu> Reviewed-by: Daria Brashear <shadow@your-file-system.com> Tested-by: Benjamin Kaduk <kaduk@mit.edu> Reviewed-by: Jeffrey Altman <jaltman@your-file-system.com> --- src/afs/afs_bypasscache.c | 1 + src/afs/afs_dcache.c | 7 +++++++ 2 files changed, 8 insertions(+) diff --git a/src/afs/afs_bypasscache.c b/src/afs/afs_bypasscache.c index f452638..4c6fb9a 100644
a b afs_PrefetchNoCache(struct vcache *avc, 621 621 } else { 622 622 afs_warn("BYPASS: StartRXAFS_FetchData failed: %d\n", code); 623 623 unlock_and_release_pages(auio); 624 afs_PutConn(tc, rxconn, SHARED_LOCK); 624 625 goto done; 625 626 } 626 627 if (code == 0) { -
src/afs/afs_dcache.c
diff --git a/src/afs/afs_dcache.c b/src/afs/afs_dcache.c index 4a9edbd..338e8db 100644
a b afs_GetDCache(struct vcache *avc, afs_size_t abyte, 2398 2398 afs_PutDCache(tdc); 2399 2399 tdc = 0; 2400 2400 ReleaseReadLock(&avc->lock); 2401 2402 if (tc) { 2403 /* If we have a connection, we must put it back, 2404 * since afs_Analyze will not be called here. */ 2405 afs_PutConn(tc, rxconn, SHARED_LOCK); 2406 } 2407 2401 2408 slowPass = 1; 2402 2409 goto RetryGetDCache; 2403 2410 }
Note: See TracBrowser
for help on using the repository browser.