mirror of
https://github.com/postgres/postgres.git
synced 2025-06-13 07:41:39 +03:00
pageinspect: Fix crash with gist_page_items()
Attempting to use this function with a raw page not coming from a GiST
index would cause a crash, as it was missing the same sanity checks as
gist_page_items_bytea(). This slightly refactors the code so as all the
basic validation checks for GiST pages are done in a single routine,
in the same fashion as the pageinspect functions for hash and BRIN.
This fixes an issue similar to 076f4d9
. A test is added to stress for
this case. While on it, I have added a similar test for
brin_page_items() with a combination make of a valid GiST index and a
raw btree page. This one was already protected, but it was not tested.
Reported-by: Egor Chindyaskin
Author: Dmitry Koval
Discussion: https://postgr.es/m/17815-fc4a2d3b74705703@postgresql.org
Backpatch-through: 14
This commit is contained in:
@ -15,12 +15,14 @@ SELECT * FROM brin_revmap_data(get_raw_page('test1_a_idx', 1)) LIMIT 5;
|
||||
SELECT * FROM brin_page_items(get_raw_page('test1_a_idx', 2), 'test1_a_idx')
|
||||
ORDER BY blknum, attnum LIMIT 5;
|
||||
|
||||
-- Failure for non-BRIN index.
|
||||
CREATE INDEX test1_a_btree ON test1 (a);
|
||||
SELECT brin_page_items(get_raw_page('test1_a_btree', 0), 'test1_a_btree');
|
||||
|
||||
-- Mask DETAIL messages as these are not portable across architectures.
|
||||
\set VERBOSITY terse
|
||||
|
||||
-- Failures for non-BRIN index.
|
||||
CREATE INDEX test1_a_btree ON test1 (a);
|
||||
SELECT brin_page_items(get_raw_page('test1_a_btree', 0), 'test1_a_btree');
|
||||
SELECT brin_page_items(get_raw_page('test1_a_btree', 0), 'test1_a_idx');
|
||||
|
||||
-- Invalid special area size
|
||||
SELECT brin_page_type(get_raw_page('test1', 0));
|
||||
SELECT * FROM brin_metapage_info(get_raw_page('test1', 0));
|
||||
|
@ -26,14 +26,16 @@ SELECT * FROM gist_page_items(get_raw_page('test_gist_idx', 1), 'test_gist_idx')
|
||||
-- platform-dependent (endianess), so omit the actual key data from the output.
|
||||
SELECT itemoffset, ctid, itemlen FROM gist_page_items_bytea(get_raw_page('test_gist_idx', 0));
|
||||
|
||||
-- Failure with non-GiST index.
|
||||
CREATE INDEX test_gist_btree on test_gist(t);
|
||||
SELECT gist_page_items(get_raw_page('test_gist_btree', 0), 'test_gist_btree');
|
||||
|
||||
-- Failure with various modes.
|
||||
-- Suppress the DETAIL message, to allow the tests to work across various
|
||||
-- page sizes and architectures.
|
||||
\set VERBOSITY terse
|
||||
|
||||
-- Failures with non-GiST index.
|
||||
CREATE INDEX test_gist_btree on test_gist(t);
|
||||
SELECT gist_page_items(get_raw_page('test_gist_btree', 0), 'test_gist_btree');
|
||||
SELECT gist_page_items(get_raw_page('test_gist_btree', 0), 'test_gist_idx');
|
||||
|
||||
-- Failure with various modes.
|
||||
-- invalid page size
|
||||
SELECT gist_page_items_bytea('aaa'::bytea);
|
||||
SELECT gist_page_items('aaa'::bytea, 'test_gist_idx'::regclass);
|
||||
|
Reference in New Issue
Block a user