]> granicus.if.org Git - postgresql/commit
Move BKP_REMOVABLE bit from individual WAL records to WAL page headers.
authorTom Lane <tgl@sss.pgh.pa.us>
Mon, 12 Dec 2011 21:22:14 +0000 (16:22 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Mon, 12 Dec 2011 21:22:14 +0000 (16:22 -0500)
commit2dd9322ba6eea76800b38bfea0599fbc459458f2
tree360f11d83e27e9c35c0e4c7a4f380c2722bceefb
parent8409b60476a4112e654d1a5099dd67a54f197afd
Move BKP_REMOVABLE bit from individual WAL records to WAL page headers.

Removing this bit from xl_info allows us to restore the old limit of four
(not three) separate pages touched by a WAL record, which is needed for the
upcoming SP-GiST feature, and will likely be useful elsewhere in future.

When we implemented XLR_BKP_REMOVABLE in 2007, we had to do it like that
because no special WAL-visible action was taken when starting a backup.
However, now we force a segment switch when starting a backup, so a
compressing WAL archiver (such as pglesslog) that uses the state shown in
the current page header will not be fooled as to removability of backup
blocks.  The only downside is that the archiver will not return to
compressing mode for up to one WAL page after the backup is over, which is
a small price to pay for getting back the extra xl_info bit.  In any case
the archiver could look for XLOG_BACKUP_END records if it thought it was
worth the trouble to do so.

Bump XLOG_PAGE_MAGIC since this is effectively a change in WAL format.
src/backend/access/transam/README
src/backend/access/transam/xlog.c
src/include/access/xlog.h
src/include/access/xlog_internal.h