Re: Buffer locking is special (hints, checksums, AIO writes) - Mailing list pgsql-hackers
| From | Melanie Plageman |
|---|---|
| Subject | Re: Buffer locking is special (hints, checksums, AIO writes) |
| Date | |
| Msg-id | CAAKRu_ZJXU8UoN+T1AjgT_qnRNoOWfw4O-C+6FYryvKj9DHO5A@mail.gmail.com Whole thread Raw |
| In response to | Re: Buffer locking is special (hints, checksums, AIO writes) (Andres Freund <andres@anarazel.de>) |
| Responses |
Re: Buffer locking is special (hints, checksums, AIO writes)
|
| List | pgsql-hackers |
On Mon, Jan 12, 2026 at 12:45 PM Andres Freund <andres@anarazel.de> 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 = 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 != BUFFER_LOCK_UNLOCK)
+ {
+ BufferDesc *buf = 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 be 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
pgsql-hackers by date: