Hello, While adding parallel scan support to the Biscuit <https://github.com/CrystallineCore/Biscuit> index access method, I ran into a question about the pre-PG18 parallel scan API.
Biscuit partitions scan work into a fixed number of segments at estimation time and assigns those segments to parallel participants via a shared-memory descriptor in the DSM segment. Because the segment layout depends on the number of participants, we need the planned worker count during amestimateparallelscan() — the only callback that both sizes the DSM allocation and runs in the same process immediately before aminitparallelscan(). The callback signatures across versions are: - - PG16: Size (*)(void) - PG17: Size (*)(int nkeys, int norderbys) - PG18+: Size (*)(Relation, int *nworkers*, int nchunks) In PG18+, nworkers is available directly. In PG16 and PG17 it is not. My question: prior to PG18, was there any supported mechanism by which an index AM could determine the planner's intended parallel worker count during scan estimation? Thanks, Sivaprasad Murali Biscuit index access method
