On Fri, Feb 21, 2025 at 11:17 AM Melanie Plageman <melanieplage...@gmail.com> wrote: > [v31-0001-Delay-extraction-of-TIDBitmap-per-page-offsets.patch]
Nice patch, seems like a straightforward win with the benefits you explained: less work done under a lock, less work done in the second iterator if the rest of this stuff doesn't make it in yet, and less space used assuming it does. My only comment is that I'm not sure about this type: +/* + * The tuple OffsetNumbers extracted from a single page in the bitmap. + */ +typedef OffsetNumber TBMOffsets[TBM_MAX_TUPLES_PER_PAGE]; It's used for a stack object, but it's also used as a degraded pointer here: +extern void tbm_extract_page_tuple(TBMIterateResult *iteritem, + TBMOffsets offsets); Maybe a personal style question but degraded pointers aren't my favourite C feature. A couple of alternatives, I am not sure how good they are: Would this output variable be better wrapped up in a new struct for better API clarity? If so, shouldn't such a struct also hold ntuples itself, since that really goes with the offsets it's holding? If so, could iteritem->ntuples then be replaced with a boolean iteritem->lossy, since all you really need to be able to check is whether it has offsets to give you, instead of using -1 and -2 for that? Or as a variation without a new struct, would it be better to take that output array as a plain pointer to OffsetNumber and max_offsets, and return ntuples (ie how many were filled in, cf commit f6bef362), for the caller to use in a loop or stash somewhere, with an additional comment that TBM_MAX_TUPLES_PER_PAGE is guaranteed to be enough, for convenience eg for arrays on the stack?