From cef01c3355975bdc6724fbc226e85d55316162a3 Mon Sep 17 00:00:00 2001 From: Tom Lane Date: Fri, 18 Mar 2005 05:25:23 +0000 Subject: [PATCH] Avoid infinite loop in InvalidateBuffer if we ourselves are holding a pin on the victim buffer. --- src/backend/storage/buffer/bufmgr.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/backend/storage/buffer/bufmgr.c b/src/backend/storage/buffer/bufmgr.c index 59dec8f9ea..bda4544b27 100644 --- a/src/backend/storage/buffer/bufmgr.c +++ b/src/backend/storage/buffer/bufmgr.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/storage/buffer/bufmgr.c,v 1.186 2005/03/04 20:21:06 tgl Exp $ + * $PostgreSQL: pgsql/src/backend/storage/buffer/bufmgr.c,v 1.187 2005/03/18 05:25:23 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -551,6 +551,9 @@ retry: { UnlockBufHdr_NoHoldoff(buf); LWLockRelease(BufMappingLock); + /* safety check: should definitely not be our *own* pin */ + if (PrivateRefCount[buf->buf_id] != 0) + elog(ERROR, "buffer is pinned in InvalidateBuffer"); WaitIO(buf); goto retry; } -- 2.40.0