]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Code coverage for most pg_mblen* calls.
authorThomas Munro <tmunro@postgresql.org>
Sun, 11 Jan 2026 21:20:06 +0000 (10:20 +1300)
committerThomas Munro <tmunro@postgresql.org>
Sun, 8 Feb 2026 23:29:41 +0000 (12:29 +1300)
commit4c08960d97e950b00a4f6bf255d5409da98c6032
tree1a18128cb9a6d1c008eebb1f624c4a6b82e97245
parentd837fb02925561091a70c5a6a74f42da57a022f9
Code coverage for most pg_mblen* calls.

A security patch changed them today, so close the coverage gap now.
Test that buffer overrun is avoided when pg_mblen*() requires more
than the number of bytes remaining.

This does not cover the calls in dict_thesaurus.c or in dict_synonym.c.
That code is straightforward.  To change that code's input, one must
have access to modify installed OS files, so low-privilege users are not
a threat.  Testing this would likewise require changing installed
share/postgresql/tsearch_data, which was enough of an obstacle to not
bother.

Security: CVE-2026-2006
Backpatch-through: 14
Co-authored-by: Thomas Munro <thomas.munro@gmail.com>
Co-authored-by: Noah Misch <noah@leadboat.com>
Reviewed-by: Heikki Linnakangas <hlinnaka@iki.fi>
15 files changed:
contrib/pg_trgm/Makefile
contrib/pg_trgm/data/trgm_utf8.data [new file with mode: 0644]
contrib/pg_trgm/expected/pg_utf8_trgm.out [new file with mode: 0644]
contrib/pg_trgm/expected/pg_utf8_trgm_1.out [new file with mode: 0644]
contrib/pg_trgm/meson.build
contrib/pg_trgm/sql/pg_utf8_trgm.sql [new file with mode: 0644]
src/backend/utils/adt/arrayfuncs.c
src/test/regress/expected/encoding.out [new file with mode: 0644]
src/test/regress/expected/encoding_1.out [new file with mode: 0644]
src/test/regress/expected/euc_kr.out [new file with mode: 0644]
src/test/regress/expected/euc_kr_1.out [new file with mode: 0644]
src/test/regress/parallel_schedule
src/test/regress/regress.c
src/test/regress/sql/encoding.sql [new file with mode: 0644]
src/test/regress/sql/euc_kr.sql [new file with mode: 0644]