Fix masking of SP-GiST pages during xlog consistency check
authorAlexander Korotkov <[email protected]>
Sat, 20 Jun 2020 14:34:51 +0000 (17:34 +0300)
committerAlexander Korotkov <[email protected]>
Sat, 20 Jun 2020 14:35:55 +0000 (17:35 +0300)
spg_mask() didn't take into account that pd_lower equal to SizeOfPageHeaderData
is still valid value.  This commit fixes that.  Backpatch to 11, where
spg_mask() pg_lower check was introduced.

Reported-by: Michael Paquier
Discussion: https://postgr.es/m/20200615131405.GM52676%40paquier.xyz
Backpatch-through: 11

src/backend/access/spgist/spgxlog.c

index ebe6ae8715b92ac4b63a2f3e449ace400853d65c..6bebaaf0895022839713991e811c3c7db201c990 100644 (file)
@@ -1008,6 +1008,6 @@ spg_mask(char *pagedata, BlockNumber blkno)
     * Mask the unused space, but only if the page's pd_lower appears to have
     * been set correctly.
     */
-   if (pagehdr->pd_lower > SizeOfPageHeaderData)
+   if (pagehdr->pd_lower >= SizeOfPageHeaderData)
        mask_unused_space(page);
 }