Re: Insufficient memory access checks in pglz_decompress - Mailing list pgsql-bugs

From Tom Lane
Subject Re: Insufficient memory access checks in pglz_decompress
Date
Msg-id 3116807.1697642067@sss.pgh.pa.us
Whole thread Raw
In response to Insufficient memory access checks in pglz_decompress  (Flavien GUEDEZ <flav.pg@oopacity.net>)
Responses Re: Insufficient memory access checks in pglz_decompress  (Flavien GUEDEZ <flav.pg@oopacity.net>)
List pgsql-bugs
Flavien GUEDEZ <flav.pg@oopacity.net> writes:
> After some investigations about very corrupted toast data in one 
> postgres instance, I found that the pglz_decompress function (in 
> common/pg_lzcompress.c) does not check correctly where it copies data 
> from using memcpy(), which could result in segfault.
> In this function, there are other checks to ensure that we do not copy 
> after the destination end, but not if we copy data from "before the 
> beginning".

Hmm, would it not be better to add this check to the existing "Check for
corrupt data" a bit further up?  Then you'd only need one instance of
the test, and only need to do it once per tag (note the comment pointing
out that dp - off stays the same), and overall it'd be less surprising IMO.

            regards, tom lane



pgsql-bugs by date:

Previous
From: Flavien GUEDEZ
Date:
Subject: Insufficient memory access checks in pglz_decompress
Next
From: Flavien GUEDEZ
Date:
Subject: Re: Insufficient memory access checks in pglz_decompress