Re: doPickSplit stack buffer overflow in XLogInsert? - Mailing list pgsql-hackers

From Kevin Grittner
Subject Re: doPickSplit stack buffer overflow in XLogInsert?
Date
Msg-id 1385562218.37343.YahooMailNeo@web162901.mail.bf1.yahoo.com
Whole thread Raw
In response to Re: doPickSplit stack buffer overflow in XLogInsert?  (Andres Freund <andres@2ndquadrant.com>)
Responses Re: doPickSplit stack buffer overflow in XLogInsert?
List pgsql-hackers
Andres Freund <andres@2ndquadrant.com> wrote:
> On 2013-11-26 14:14:38 -0800, Kevin Grittner wrote:
>
>> I happened to build in a shell that was still set up for the clang
>> address sanitizer, and got the attached report.  On a rerun it was
>> repeatable.  XLogInsert() seems to read past the end of a variable
>> allocated on the stack in doPickSplit(). I haven't tried to analyze
>> it past that, since this part of the code is unfamiliar to me.
>
> Yea, I've seen that one before as well and planned to report it at some
> point. The reason is the MAXALIGN()s in ACCEPT_RDATA_DATA(). That rounds
> up to 8byte boundaries, while we've e.g. only added 2bytes of slop to
> toDelete.

Have you established whether having the CRC calculation read past
the end of the buffer can cause problems on recovery or standby
systems?  Should we try to get this fixed by Monday?

--
Kevin Grittner
EDB: http://www.enterprisedb.com
The Enterprise PostgreSQL Company



pgsql-hackers by date:

Previous
From: Pavel Stehule
Date:
Subject: Re: new unicode table border styles for psql
Next
From: Vik Fearing
Date:
Subject: Re: Extension Templates S03E11