Re: Better shared data structure management and resizable shared data structures - Mailing list pgsql-hackers

From Heikki Linnakangas
Subject Re: Better shared data structure management and resizable shared data structures
Date
Msg-id b15a8fb8-5b59-4349-859c-07e7f070a21e@iki.fi
Whole thread Raw
In response to Re: Better shared data structure management and resizable shared data structures  (Ashutosh Bapat <ashutosh.bapat.oss@gmail.com>)
Responses Re: Better shared data structure management and resizable shared data structures
List pgsql-hackers
On 07/04/2026 17:46, Ashutosh Bapat wrote:
> Here are patches with the test modules merged.
> 
> The merged module looks a bit rough to me and so does 0006. For
> example, I am not sure whether calling ShmemStructProtect() from
> init_fn is a good idea. See [1] for example. But init_fn is the last
> chance for the subsystem to touch and setup the resizable structure
> before it's opened to the wild. So, in the current infrastructure, I
> don't see any better place to call ShmemStructProtect() either. If you
> run tests after applying patch 0006, you will need to apply patch
> attached to [1] as well; otherwise the test will hang.

I haven't really looked at these resizeable patches before, except for 
how they would fit with the new shmem allocation API, so I have some 
very basic, high-level design questions:

> +/*
> + * ShmemResizeStruct() --- resize a resizable shared memory structure.
> + *
> + * The new size must be within [minimum_size, maximum_size].  If the structure
> + * is being shrunk, the memory pages that are no longer needed are freed. If
> + * the structure is being expanded, the memory pages that are needed for the
> + * new size are allocated. See EstimateAllocatedSize() for explanation of which
> + * pages are allocated for a resizable structure.
> + */
> +void
> +ShmemResizeStruct(const char *name, Size new_size)

This interface only allows shrinking and growing the allocated region at 
the end, but the underlying mechanism is madvise(MADV_REMOVE) and 
madvise(MADV_WRITE_POPULATE), which supports also "punching holes", i.e. 
freeing memory in the middle of a region. Do we gain anything by 
restricting ourselves to changing the size at the end? It seems to me 
that it could be handy to punch holes for some use cases.

What's the portability story? I understand that this is Linux-only at 
the moment, but what platforms can we support in the future, and what's 
the effort? I think BSD's have similar capabilities with plain mmap() 
and MADV_FREE if I read the man pages right. What about macOS and 
Windows? This doesn't necessarily need to be fully portable, if some 
OS's don't have the capabilities we need, but would be nice to know 
what's possible.

- Heikki




pgsql-hackers by date:

Previous
From: Robert Treat
Date:
Subject: Re: Adding REPACK [concurrently]
Next
From: Daniil Davydov
Date:
Subject: Re: test_autovacuum/001_parallel_autovacuum is broken