Received: from malur.postgresql.org ([217.196.149.56]) by arkaria.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.96) (envelope-from ) id 1vfQO4-001nBu-1q for pgsql-hackers@arkaria.postgresql.org; Mon, 12 Jan 2026 22:27:49 +0000 Received: from localhost ([127.0.0.1] helo=malur.postgresql.org) by malur.postgresql.org with esmtp (Exim 4.96) (envelope-from ) id 1vfQO3-001irc-1n for pgsql-hackers@arkaria.postgresql.org; Mon, 12 Jan 2026 22:27:47 +0000 Received: from magus.postgresql.org ([2a02:c0:301:0:ffff::29]) by malur.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.96) (envelope-from ) id 1vfQO3-001irT-0l for pgsql-hackers@lists.postgresql.org; Mon, 12 Jan 2026 22:27:47 +0000 Received: from mail-ed1-x530.google.com ([2a00:1450:4864:20::530]) by magus.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 (Exim 4.96) (envelope-from ) id 1vfQO1-0006NM-1R for pgsql-hackers@postgresql.org; Mon, 12 Jan 2026 22:27:47 +0000 Received: by mail-ed1-x530.google.com with SMTP id 4fb4d7f45d1cf-64b9d01e473so11583016a12.2 for ; Mon, 12 Jan 2026 14:27:44 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1768256862; x=1768861662; darn=postgresql.org; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=3cHUTPyqMytRWKIj4Iz+wGfJoNC5suY4rU3hmKblgNU=; b=JdgEY29UzmC/FzxpQ+4mJmHgMzvnnVoag+zE6MuOpsd/gQmsSlhRu/9/SZ+dprLX4H crxLR2kQNqdRBeiQHypsCf+NbSaoJYWgrdP3B8HCY/jhh00SYto4MM2EH2rPLtLExjwD cK4sJREdxLBzZqhkER3k00KGjyCasetB7OXMSVMAFt6SMg7+wCnpW3jV8A+OTOPRS5Vd oc+L4E0gL4h6JRTORz/bmNyDBlyk7wHi8jWpjZeOx/qWUpk0/eHPCGMmzBDqpg6WcEWt SNgSKEKpPFmIy4JQhrGBN74Uvlx2N9Q8nUmYewOLP+cKrKthGemQ3N1blmHfqQeRnQHA fmLw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1768256862; x=1768861662; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=3cHUTPyqMytRWKIj4Iz+wGfJoNC5suY4rU3hmKblgNU=; b=m0tUmsAQqc35v49JIH+YJaXyq1ZODuBosF39roqr5jAWYgBZXrvAyukF1SIZGRGDPX YFfF/vSO4mfGQBw5jvX85ddhzVaFrE7qdXSvMaETwpN9RRfx02VH64sj8ChyiL4/KjZN P1OSZ0ZeTJzlzzj5oaK/RLkyFObex2eE2hEW8nfSkJpP+3bzu4yQ8u4xQ7OESoQdABqs fyLGBzq4nxC0n4l3h0sQsEEnDOpOJKFSIth8vbIsNu3ZnoGESYKZq5ys5Wa5WW+XjAY3 BQUnVZtWlpZO4q0mTEHwHf46V72pbGGm38ebHAXheOmz1+SKqO7SIkJAhf2UdIxuB5KE djag== X-Forwarded-Encrypted: i=1; AJvYcCXUo33S352+EQfxSrRFk/osM3XU3LsyF0Oqe+Cte3Wz4Ue3agfxr1MtSJpph2fv3lGiMLgQ9awxdWNzD43H@postgresql.org X-Gm-Message-State: AOJu0YyJ6cwPs9sJQcmvUMbaCXzDmCoz0ACmTBe/3QWWiUZUzqHQrhKR UXKpPPv9ipcRNNP1fqzXuj7/W/Faqr/KPfs2RkI5m3WWG5l3ncFwwpBfIHar7i5Tm3M6ePsmkIp GBLa5vTUFIWh5Z+XhZ9K38u81g0XyAnQ= X-Gm-Gg: AY/fxX6xGaWU+J2hRBzRqz55YY5J0JRjsK3QDaryAbdDiTPxx+e9xaL6brMyc/8JO/a 7iTLHGhyt614UKueYtyaylvMDH7+MkTRXfHRPvlYSWNxuN0orFQ7pIUqa6Dm+WsICtysdzHOAtX F3ue8rP5sxgx4hLXT+helYnBB/O5yrcif9dx44Xap7EpdpyrZNh4bqZ8JzgLgkbxhy1CcLEbxXo 6CBCoPehj2xIwaQsKIEIPLetmOV8gKuK1W5yQC+aTI4lJ2fiZjH5ifHhmeVsNStyQo8InzDKDPr QSlatHCxL8tRL3SUDnOS993G9nH8 X-Google-Smtp-Source: AGHT+IH7B9qQSvViDjxzjyYjF2m8XMScVCxARN3vpeDyWRzT9AiMRSVrDKhEeXdwHThxrTBSXUvH4z3Cd4v4WgmaMXc= X-Received: by 2002:a05:6402:42c7:b0:64d:1a0f:6969 with SMTP id 4fb4d7f45d1cf-65097dc5ed9mr19529242a12.5.1768256861417; Mon, 12 Jan 2026 14:27:41 -0800 (PST) MIME-Version: 1.0 References: <3nce7i72ayzkunai6mkz24ckbxk74jodz4ua2chcdrwppxlxcd@w6x5kfkjrkru> <1108f18d-cf7c-4f17-b29c-a119fe42f7e5@iki.fi> <5dwlfu2jyzkyf3nrlzxxblxctb6xio5es73ptgsahjnmfu5miu@772rc764hfhi> <4csodkvvfbfloxxjlkgsnl2lgfv2mtzdl7phqzd4jxjadxm4o5@usw7feyb5bzf> In-Reply-To: From: Melanie Plageman Date: Mon, 12 Jan 2026 17:27:30 -0500 X-Gm-Features: AZwV_QjshlIrDRs0HpUFmYBk-KtxI75m1jhrlNeWm7VtJDXBtYqZjXLytkKuBgs Message-ID: Subject: Re: Buffer locking is special (hints, checksums, AIO writes) To: Andres Freund Cc: Kirill Reshke , Heikki Linnakangas , Matthias van de Meent , pgsql-hackers@postgresql.org, Thomas Munro , Noah Misch , Robert Haas , Michael Paquier Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable List-Id: List-Help: List-Subscribe: List-Post: List-Owner: List-Archive: Archived-At: Precedence: bulk On Mon, Jan 12, 2026 at 12:45=E2=80=AFPM Andres Freund = wrote: > > Also working on doing comment polishing of the later patches, found a few > things, but not quite enough to be worth reposting yet. I looked at 0004 and 0005 and re-looked at 0006 - 0007. For 0004, I think you should clarify the commit message a bit. I had trouble understanding when WAKE_IN_PROGRESS is set. So, before RELEASE_OK was set all the time except when a process woke up and hadn't run yet. Now, WAKE_IN_PROGRESS is only set when a process is woken up but hasn't run yet. Personally, I just needed a bit more specificity (maybe even a bit more formality and grammatically correctness) from the commit message to get it. I agree that separating 0005 is helpful. 0007 looks basically fine to me. I'd comb through it with an AI tool to catch a few nits I saw like an outdated reference to RELEASE_OK and a missing word in the commit message, etc. Otherwise, I mostly looked to see if the wakeup semantics seemed right and if anything jumped out at me while skimming (i.e. I didn't go through every line with a fine-toothed comb). The two things I came up with were: I wondered why this was needed (i.e. why it wasn't needed before) @@ -6688,7 +7428,25 @@ ResOwnerReleaseBufferPin(Datum res) if (BufferIsLocal(buffer)) UnpinLocalBufferNoOwner(buffer); else + { + PrivateRefCountEntry *ref; + + ref =3D GetPrivateRefCountEntry(buffer, false); + + /* + * If the buffer was locked at the time of the resowner release, + * release the lock now. This should only happen after errors. + */ + if (ref->data.lockmode !=3D BUFFER_LOCK_UNLOCK) + { + BufferDesc *buf =3D GetBufferDescriptor(buffer - 1); + + HOLD_INTERRUPTS(); /* match the upcoming RESUME_INTERRUPTS = */ + BufferLockUnlock(buffer, buf); + } + UnpinBufferNoOwner(GetBufferDescriptor(buffer - 1)); + } } is it related to your comment in the commit message 2) Error recovery for content locks is implemented as part of the already existing private-refcount tracking mechanism in combination with resowners? As for your FIXMEs, + /* + * FIXME: This is reusing the lwlock fields. That's not a correctness + * issue, a backend can't wait for both an lwlock and a buffer content + * lock at the same time. However, it seems pretty ugly, particularly + * given that the field names have an lw* prefix. But duplicating the + * fields also seems somewhat superfluous. + */ personally I can live with reusing the lwlock fields now that it's fairly well documented. + /* XXX: combine with fetch_and above? */ + UnlockBufHdr(buf_hdr); Are you thinking about adding a helper that stops waiting and unlocks? > Perhaps move the locking code into a buffer_locking.h or such? Needs to b= e inline functions for efficiency unfortunately. So you mean put all of the static buffer locking functions you added to bufmgr.c inline into a header file? bufmgr.c is super long anyway, so it's not like making it separate makes the file manageable. On the other hand, it's probably better to not keep making it worse. For example, I find it really annoying that the helper function prototypes for res owner and ref count related functions are grouped before their implementations and then below that there is another seemingly arbitrary group of prototypes and then their implementations. Like, what is the logic there? - Melanie