pgsql: Temporarily make MemoryContextContains return false - Mailing list pgsql-committers

From David Rowley
Subject pgsql: Temporarily make MemoryContextContains return false
Date
Msg-id E1oWGez-001zvW-4L@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Temporarily make MemoryContextContains return false

5265e91fd changed MemoryContextContains to update it so that it works
correctly with the new MemoryChunk code added in c6e0fe1f2.  However,
5265e91fd was done with the assumption that MemoryContextContains would
only ever be given pointers to memory that had been returned by one of our
MemoryContext allocators.  It seems that's not true and many of our 32-bit
buildfarm animals are clearly showing that.

There are some code paths that call MemoryContextContains with a pointer
pointing part way into an allocated chunk.  The example of this found by
the 32-bit buildfarm animals is the int2int4_sum() function.  This
function returns transdata->sum, which is not a pointer to memory that was
allocated directly.  This return value is then subsequently passed to
MemoryContextContains which causes it to crash due to it thinking the
memory directly prior to that pointer is a MemoryChunk.  What's actually
in that memory is the field in the struct that comes prior to the "sum"
field.  This problem didn't occur in 64-bit world because BIGINT is a
byval type and the code which was calling MemoryContextContains with the
bad pointer only does so with non-byval types.

Here, instead of reverting 5265e91fd and making MemoryContextContains
completely broken again, let's just make it always return false for now.
Effectively prior to 5265e91fd it was doing that anyway, this at least
makes that more explicit.  The only repercussions of this with the current
MemoryContextContains calls are that we perform a datumCopy() when we
might not need to.  This should make the 32-bit buildfarm animals happy
again and give us more time to consider a long-term fix.

Discussion: https://postgr.es/m/20220907130552.sfjri7jublfxyyi4%40jrouhaud

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/b76fb6c2a99eb7d49f96e56599fef1ffc1c134c9

Modified Files
--------------
src/backend/utils/mmgr/mcxt.c | 29 +++++++++--------------------
1 file changed, 9 insertions(+), 20 deletions(-)


pgsql-committers by date:

Previous
From: Peter Eisentraut
Date:
Subject: Re: pgsql: doc: clarify recursion internal behavior
Next
From: Tom Lane
Date:
Subject: Re: pgsql: Raise a warning if there is a possibility of data from multiple