diff options
author | Michael Paquier <michael@paquier.xyz> | 2023-09-04 14:55:49 +0900 |
---|---|---|
committer | Michael Paquier <michael@paquier.xyz> | 2023-09-04 14:55:49 +0900 |
commit | fac3fa0d5b21ce59258a691b88e4176a06722bfc (patch) | |
tree | 5779bcdf8f363a6800d7caec8bd283cb1e7266d7 /src | |
parent | c397c98ae63d57c35766dbefe4ea34a5162abf53 (diff) | |
download | postgresql-fac3fa0d5b21ce59258a691b88e4176a06722bfc.tar.gz postgresql-fac3fa0d5b21ce59258a691b88e4176a06722bfc.zip |
Fix out-of-bound read in gtsvector_picksplit()
This could lead to an imprecise choice when splitting an index page of a
GiST index on a tsvector, deciding which entries should remain on the
old page and which entries should move to a new page.
This is wrong since tsearch2 has been moved into core with commit
140d4ebcb46e, so backpatch all the way down. This error has been
spotted by valgrind.
Author: Alexander Lakhin
Discussion: https://postgr.es/m/17950-6c80a8d2b94ec695@postgresql.org
Backpatch-through: 11
Diffstat (limited to 'src')
-rw-r--r-- | src/backend/utils/adt/tsgistidx.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/backend/utils/adt/tsgistidx.c b/src/backend/utils/adt/tsgistidx.c index f0cd2866ff5..12a4111e99a 100644 --- a/src/backend/utils/adt/tsgistidx.c +++ b/src/backend/utils/adt/tsgistidx.c @@ -730,7 +730,7 @@ gtsvector_picksplit(PG_FUNCTION_ARGS) size_alpha = SIGLENBIT(siglen) - sizebitvec((cache[j].allistrue) ? GETSIGN(datum_l) : - GETSIGN(cache[j].sign), + cache[j].sign, siglen); } else @@ -744,7 +744,7 @@ gtsvector_picksplit(PG_FUNCTION_ARGS) size_beta = SIGLENBIT(siglen) - sizebitvec((cache[j].allistrue) ? GETSIGN(datum_r) : - GETSIGN(cache[j].sign), + cache[j].sign, siglen); } else |