Re: Fixing code that ignores failure of XLogRecGetBlockTag - Mailing list pgsql-hackers

From Thomas Munro
Subject Re: Fixing code that ignores failure of XLogRecGetBlockTag
Date
Msg-id CA+hUKG+4Xsn+b8tcXFizVy-mAHe0bR1qbCeHgq7ZnxMDzfSdvA@mail.gmail.com
Whole thread Raw
In response to Re: Fixing code that ignores failure of XLogRecGetBlockTag  (Robert Haas <robertmhaas@gmail.com>)
Responses Re: Fixing code that ignores failure of XLogRecGetBlockTag  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-hackers
On Tue, Apr 12, 2022 at 8:58 AM Robert Haas <robertmhaas@gmail.com> wrote:
> On Mon, Apr 11, 2022 at 2:20 PM Tom Lane <tgl@sss.pgh.pa.us> wrote:
> > Currently, XLogRecGetBlockTag has 41 callers, of which only four
> > bother to check the function's result.  The remainder take it on
> > faith that they got valid data back, and many of them will
> > misbehave in seriously nasty ways if they didn't.  (This point
> > was drawn to my attention by a Coverity complaint.)
> >
> > I think we should make this a little less fragile.  Since we
> > already have XLogRecGetBlockTagExtended, I propose that callers
> > that need to handle the case of no-such-block must use that,
> > while XLogRecGetBlockTag throws an error.  The attached patch
> > fixes that up, and also cleans up some random inconsistency
> > about use of XLogRecHasBlockRef().
>
> Looks reasonable.

+1



pgsql-hackers by date:

Previous
From: Nathan Bossart
Date:
Subject: Re: make MaxBackends available in _PG_init
Next
From: Tom Lane
Date:
Subject: Re: Fixing code that ignores failure of XLogRecGetBlockTag