aboutsummaryrefslogtreecommitdiff
path: root/src/backend/access/transam/xlogutils.c
diff options
context:
space:
mode:
authorDavid Rowley <drowley@postgresql.org>2022-09-09 00:28:38 +1200
committerDavid Rowley <drowley@postgresql.org>2022-09-09 00:28:38 +1200
commitb76fb6c2a99eb7d49f96e56599fef1ffc1c134c9 (patch)
tree455b0ccf0fb0e5c9bfd0fefd6edc2f5e39700fd6 /src/backend/access/transam/xlogutils.c
parente7936f8b3e57046c0e178ccefa04ac7e6fbae79c (diff)
downloadpostgresql-b76fb6c2a99eb7d49f96e56599fef1ffc1c134c9.tar.gz
postgresql-b76fb6c2a99eb7d49f96e56599fef1ffc1c134c9.zip
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
Diffstat (limited to 'src/backend/access/transam/xlogutils.c')
0 files changed, 0 insertions, 0 deletions