| From: | Andres Freund <andres(at)anarazel(dot)de> | 
|---|---|
| To: | Antonin Houska <ah(at)cybertec(dot)at> | 
| Cc: | pgsql-hackers(at)lists(dot)postgresql(dot)org | 
| Subject: | Re: Atomics in localbuf.c | 
| Date: | 2020-03-05 20:59:55 | 
| Message-ID: | B1C20859-A267-4A9C-A212-10DC66CD08AA@anarazel.de | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
Hi
On March 5, 2020 12:42:06 PM PST, Antonin Houska <ah(at)cybertec(dot)at> wrote:
>Andres Freund <andres(at)anarazel(dot)de> wrote:
>
>> On March 5, 2020 9:21:55 AM PST, Antonin Houska <ah(at)cybertec(dot)at>
>wrote:
>> >What's the reason to use pg_atomic...read_...() and
>> >pg_atomic...write_...()
>> >functions in localbuf.c?
>> >
>> >It looks like there was an intention not to use them
>> >
>>
>>https://www.postgresql.org/message-id/CAPpHfdtfr3Aj7xJonXaKR8iY2p8uXOQ%2Be4BMpMDAM_5R4OcaDA%40mail.gmail.com
>> >
>> >but the following discussion does not explain the decision to use
>them.
>> 
>> Read/write don't trigger locked/atomic operations. They just
>guarantee that
>> you're not gonna read/write a torn value. Or a cached one. Since
>> local/shared buffers share the buffer header definition, we still
>have to
>> use proper functions to access the atomic variables.
>
>Sure, the atomic operations are necessary for shared buffers, but I
>still
>don't understand why they are needed for *local* buffers - local
>buffers their
>headers (BufferDesc) in process local memory, so there should be no
>concerns
>about concurrent access.
>
>Another thing that makes me confused is this comment in
>InitLocalBuffers():
>
>	/*
>	 * Intentionally do not initialize the buffer's atomic variable
>	 * (besides zeroing the underlying memory above). That way we get
>	 * errors on platforms without atomics, if somebody (re-)introduces
>	 * atomic operations for local buffers.
>	 */
>
>That sounds like there was an intention not to use the atomic functions
>in
>localbuf.c, but eventually they ended up there. Do I still miss
>something?
Again, the read/write functions do not imply atomic instructions.
Ants
-- 
Sent from my Android device with K-9 Mail. Please excuse my brevity.
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Aleksei Ivanov | 2020-03-05 21:02:02 | Proposal: PqSendBuffer removal | 
| Previous Message | Tom Lane | 2020-03-05 20:57:00 | Re: Retiring support for pre-7.3 FK constraint triggers |