pgsql: Always use the caller-provided context for radix tree leaves

From: John Naylor <john(dot)naylor(at)postgresql(dot)org>
To: pgsql-committers(at)lists(dot)postgresql(dot)org
Subject: pgsql: Always use the caller-provided context for radix tree leaves
Date: 2025-01-06 06:31:27
Message-ID: E1tUge7-0006bJ-FK@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers

Always use the caller-provided context for radix tree leaves

Previously, it would not have worked for a caller to pass a slab
context, since it would have been used for other things which likely
had incompatible size. In an attempt to be helpful and avoid possible
space wastage due to aset's power-of-two rounding, RT_CREATE would
create an additional slab context if the value type was fixed-length
and larger than pointer size. The problem was, we have since added
the bump context type, and the generation context was a possibility as
well, so silently overriding the caller's choice may actually be worse.

Commit e8a6f1f908d arranged so that the caller-provided context is
used only for leaves, so it's safe for the caller to use slab here
if they wish. As demonstration, use slab in one of the radix tree
regression tests.

Reviewed by Masahiko Sawada

Discussion: https://postgr.es/m/CANWCAZZDCo4k5oURg_pPxM6+WZ1oiG=sqgjmQiELuyP0Vtrwig@mail.gmail.com

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/3e70da2781e86d07cd88f568ebeb38ddf7da8e8e

Modified Files
--------------
src/include/lib/radixtree.h | 14 --------------
src/test/modules/test_radixtree/test_radixtree.c | 7 ++++---
2 files changed, 4 insertions(+), 17 deletions(-)

Browse pgsql-committers by date

  From Date Subject
Next Message Fujii Masao 2025-01-06 08:25:41 pgsql: doc: Clarify log level for VERBOSE messages in maintenance comma
Previous Message John Naylor 2025-01-06 04:46:09 pgsql: Get rid of radix tree's general purpose memory context