diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2013-03-15 12:26:26 -0400 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2013-03-15 12:26:26 -0400 |
commit | dcafdbcde1baf256891be6af77868b84889b435d (patch) | |
tree | f1c13fc6189af0d2df6270bb0a8f770183daeba4 /src/backend/storage/buffer/bufmgr.c | |
parent | 73e7025bd8eed941a068f0a7a71e02dca8d38d1c (diff) | |
download | postgresql-dcafdbcde1baf256891be6af77868b84889b435d.tar.gz postgresql-dcafdbcde1baf256891be6af77868b84889b435d.zip |
Improve error reporting in code that checks for buffer refcount leaks.
Formerly we just Assert'ed that each refcount was zero, which was quick
and easy but failed to provide a good overview of what was wrong.
Change the code so that we'll call PrintBufferLeakWarning() for each
buffer with a nonzero refcount, and then Assert at the end of the loop.
This costs nothing in runtime and might ease diagnosis of some bugs.
Greg Smith, reviewed by Satoshi Nagayasu, further tweaked by me
Diffstat (limited to 'src/backend/storage/buffer/bufmgr.c')
-rw-r--r-- | src/backend/storage/buffer/bufmgr.c | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/src/backend/storage/buffer/bufmgr.c b/src/backend/storage/buffer/bufmgr.c index ea7d469f2f4..0b4c2ed0a01 100644 --- a/src/backend/storage/buffer/bufmgr.c +++ b/src/backend/storage/buffer/bufmgr.c @@ -1699,12 +1699,18 @@ AtEOXact_Buffers(bool isCommit) #ifdef USE_ASSERT_CHECKING if (assert_enabled) { - int i; + int RefCountErrors = 0; + Buffer b; - for (i = 0; i < NBuffers; i++) + for (b = 1; b <= NBuffers; b++) { - Assert(PrivateRefCount[i] == 0); + if (PrivateRefCount[b - 1] != 0) + { + PrintBufferLeakWarning(b); + RefCountErrors++; + } } + Assert(RefCountErrors == 0); } #endif @@ -1739,12 +1745,18 @@ AtProcExit_Buffers(int code, Datum arg) #ifdef USE_ASSERT_CHECKING if (assert_enabled) { - int i; + int RefCountErrors = 0; + Buffer b; - for (i = 0; i < NBuffers; i++) + for (b = 1; b <= NBuffers; b++) { - Assert(PrivateRefCount[i] == 0); + if (PrivateRefCount[b - 1] != 0) + { + PrintBufferLeakWarning(b); + RefCountErrors++; + } } + Assert(RefCountErrors == 0); } #endif |