aboutsummaryrefslogtreecommitdiff
path: root/src/backend
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2024-09-13 16:16:47 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2024-09-13 16:16:47 -0400
commitb49013f2e86ad2cf01953f79992574e7ec2cdf02 (patch)
tree20a14cf76b9f1eea42066f2f606468cd3602b5e0 /src/backend
parent0970889e352ccef7d1b5f32855b3db02a9946e90 (diff)
downloadpostgresql-b49013f2e86ad2cf01953f79992574e7ec2cdf02.tar.gz
postgresql-b49013f2e86ad2cf01953f79992574e7ec2cdf02.zip
Allow _h_indexbuild() to be interrupted.
When we are building a hash index that is large enough to need pre-sorting (larger than either maintenance_work_mem or NBuffers), the initial sorting phase is interruptible, but the insertion phase wasn't. Add the missing CHECK_FOR_INTERRUPTS(). Per bug #18616 from Alexander Lakhin. Back-patch to all supported branches. Pavel Borisov Discussion: https://postgr.es/m/18616-acbb9e5caf41e964@postgresql.org
Diffstat (limited to 'src/backend')
-rw-r--r--src/backend/access/hash/hashsort.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/backend/access/hash/hashsort.c b/src/backend/access/hash/hashsort.c
index 3ce42483ed1..f7e140cb930 100644
--- a/src/backend/access/hash/hashsort.c
+++ b/src/backend/access/hash/hashsort.c
@@ -146,6 +146,9 @@ _h_indexbuild(HSpool *hspool, Relation heapRel)
_hash_doinsert(hspool->index, itup, heapRel);
+ /* allow insertion phase to be interrupted, and track progress */
+ CHECK_FOR_INTERRUPTS();
+
pgstat_progress_update_param(PROGRESS_CREATEIDX_TUPLES_DONE,
++tups_done);
}