Hi,

On Mon, Apr 07, 2025 at 10:09:26AM +0200, Jakub Wartak wrote:
> Bertrand noticed this first in
> https://www.postgresql.org/message-id/Z/FhOOCmTxuB2h0b%40ip-10-97-1-34.eu-west-3.compute.internal
> :
> 
> -               startptr = (char *) BufferGetBlock(1);
> +               startptr = (char *) TYPEALIGN_DOWN(os_page_size, (char
> *) BufferGetBlock(1));
> 
> With the above I'm also not getting wonky (-1) results anymore. The
> rest of reply assumes we are using this.

yeah, I can see that you added it in v25-0007. In the same message I mentioned
to "use the actual buffer address when pg_numa_touch_mem_if_required()
is called?"

So, to be extra cautious we could do something like:

@@ -474,7 +474,7 @@ pg_buffercache_numa_pages(PG_FUNCTION_ARGS)

                                /* Only need to touch memory once per backend 
process lifetime */
                                if (firstNumaTouch)
-                                       pg_numa_touch_mem_if_required(touch, 
os_page_ptrs[idx]);
+                                       pg_numa_touch_mem_if_required(touch, 
buffptr + (j * os_page_size));


what do you think?

Regards,

-- 
Bertrand Drouvot
PostgreSQL Contributors Team
RDS Open Source Databases
Amazon Web Services: https://aws.amazon.com


Reply via email to