This is an automated email from the ASF dual-hosted git repository.

reshke pushed a commit to branch REL_2_STABLE
in repository https://gitbox.apache.org/repos/asf/cloudberry.git

commit 944f7898d98504368a2d4e3991ec7b14a13da3a9
Author: Michael Paquier <[email protected]>
AuthorDate: Wed Oct 26 09:41:18 2022 +0900

    Fix ordering issue with WAL operations in GIN fast insert path
    
    Contrary to what is documented in src/backend/access/transam/README,
    ginHeapTupleFastInsert() had a few ordering issues with the way it does
    its WAL operations when inserting items in its fast path.
    
    First, when using a separate list, XLogBeginInsert() was being always
    called before START_CRIT_SECTION(), and in this case a second thing was
    wrong when merging lists, as an exclusive lock was taken on the tail
    page *before* calling XLogBeginInsert().  Finally, when inserting items
    into a tail page, the order of XLogBeginInsert() and
    START_CRIT_SECTION() was reversed.  This commit addresses all these
    issues by moving the calls of XLogBeginInsert() after all the pages
    logged are locked and pinned, within a critical section.
    
    This has been applied first only on HEAD as of 56b6625, but as per
    discussion with Tom Lane and Álvaro Herrera, a backpatch is preferred to
    keep all the branches consistent and to respect the transam's README
    where we can.
    
    Author:  Matthias van de Meent, Zhang Mingli
    Discussion: 
https://postgr.es/m/caeze2whl8ulmqynnncu1lapwxd5rkeo0nhv+exgg_n6elu8...@mail.gmail.com
    Backpatch-through: 10
---
 src/backend/access/gin/ginfast.c | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

diff --git a/src/backend/access/gin/ginfast.c b/src/backend/access/gin/ginfast.c
index 48102ed46fc..7f8500e0c38 100644
--- a/src/backend/access/gin/ginfast.c
+++ b/src/backend/access/gin/ginfast.c
@@ -285,7 +285,6 @@ ginHeapTupleFastInsert(GinState *ginstate, 
GinTupleCollector *collector)
                memset(&sublist, 0, sizeof(GinMetaPageData));
                makeSublist(index, collector->tuples, collector->ntuples, 
&sublist);
 
-
                /*
                 * metapage was unlocked, see above
                 */
@@ -365,11 +364,11 @@ ginHeapTupleFastInsert(GinState *ginstate, 
GinTupleCollector *collector)
 
                data.ntuples = collector->ntuples;
 
+               START_CRIT_SECTION();
+
                if (needWal)
                        XLogBeginInsert();
 
-               START_CRIT_SECTION();
-
                /*
                 * Increase counter of heap tuples
                 */


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to