diff options
| author | Thomas Munro <tmunro@postgresql.org> | 2023-07-04 15:16:34 +1200 | 
|---|---|---|
| committer | Thomas Munro <tmunro@postgresql.org> | 2023-07-04 15:28:29 +1200 | 
| commit | a0003572f214c0e4b40374aefa46c818ad92d999 (patch) | |
| tree | 4cef16ea4f149740062fdf42afaee477a48a45a2 /src/backend/access/gist/gistbuildbuffers.c | |
| parent | fc15473840bcccecb10030ae9a900171d2371027 (diff) | |
Re-bin segment when memory pages are freed.
It's OK to be lazy about re-binning memory segments when allocating,
because that can only leave segments in a bin that's too high.  We'll
search higher bins if necessary while allocating next time, and
also eventually re-bin, so no memory can become unreachable that way.
However, when freeing memory, the largest contiguous range of free pages
might go up, so we should re-bin eagerly to make sure we don't leave the
segment in a bin that is too low for get_best_segment() to find.
The re-binning code is moved into a function of its own, so it can be
called whenever free pages are returned to the segment's free page map.
Back-patch to all supported releases.
Author: Dongming Liu <ldming101@gmail.com>
Reviewed-by: Robert Haas <robertmhaas@gmail.com> (earlier version)
Reviewed-by: Thomas Munro <thomas.munro@gmail.com>
Discussion: https://postgr.es/m/CAL1p7e8LzB2LSeAXo2pXCW4%2BRya9s0sJ3G_ReKOU%3DAjSUWjHWQ%40mail.gmail.com
Diffstat (limited to 'src/backend/access/gist/gistbuildbuffers.c')
0 files changed, 0 insertions, 0 deletions
