From: Simon Riggs Date: Sun, 7 Apr 2013 21:37:39 +0000 (+0100) Subject: Tune BufferGetLSNAtomic() when checksums !enabled X-Git-Tag: XL9_5_R1BETA1~313^2~1^2~1804 X-Git-Url: http://git.postgresql.org/gitweb/static/gitweb.js?a=commitdiff_plain;h=1be203519ac4da238bf6dfe8f7015d5780723e0f;p=postgres-xl.git Tune BufferGetLSNAtomic() when checksums !enabled From performance analysis by Heikki Linnakangas --- diff --git a/src/backend/storage/buffer/bufmgr.c b/src/backend/storage/buffer/bufmgr.c index 1cd0ac806a..c2ef53f461 100644 --- a/src/backend/storage/buffer/bufmgr.c +++ b/src/backend/storage/buffer/bufmgr.c @@ -2079,8 +2079,10 @@ BufferGetLSNAtomic(Buffer buffer) char *page = BufferGetPage(buffer); XLogRecPtr lsn; - /* Local buffers don't need a lock. */ - if (BufferIsLocal(buffer)) + /* + * If we don't need locking for correctness, fastpath out. + */ + if (!DataChecksumsEnabled() || BufferIsLocal(buffer)) return PageGetLSN(page); /* Make sure we've got a real buffer, and that we hold a pin on it. */