aboutsummaryrefslogtreecommitdiff
path: root/src/backend/executor/execIndexing.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2016-04-14 19:42:21 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2016-04-14 19:42:21 -0400
commit6a3d3965d6d5eec30e1c36b3ffa3355ee9201933 (patch)
treeb0fdbc84c19974634c338edf2b240126e61c3ec2 /src/backend/executor/execIndexing.c
parentc2dc194bdbf5f84ceb433ed416eb389c1234ebc9 (diff)
downloadpostgresql-6a3d3965d6d5eec30e1c36b3ffa3355ee9201933.tar.gz
postgresql-6a3d3965d6d5eec30e1c36b3ffa3355ee9201933.zip
Fix core dump in ReorderBufferRestoreChange on alignment-picky platforms.
When re-reading an update involving both an old tuple and a new tuple from disk, reorderbuffer.c was careless about whether the new tuple is suitably aligned for direct access --- in general, it isn't. We'd missed seeing this in the buildfarm because the contrib/test_decoding tests exercise this code path only a few times, and by chance all of those cases have old tuples with length a multiple of 4, which is usually enough to make the access to the new tuple's t_len safe. For some still-not-entirely-clear reason, however, Debian's sparc build gets a bus error, as reported by Christoph Berg; perhaps it's assuming 8-byte alignment of the pointer? The lack of previous field reports is probably because you need all of these conditions to trigger a crash: an alignment-picky platform (not Intel), a transaction large enough to spill to disk, an update within that xact that changes a primary-key field and has an odd-length old tuple, and of course logical decoding tracing the transaction. Avoid the alignment assumption by using memcpy instead of fetching t_len directly, and add a test case that exposes the crash on picky platforms. Back-patch to 9.4 where the bug was introduced. Discussion: <20160413094117.GC21485@msg.credativ.de>
Diffstat (limited to 'src/backend/executor/execIndexing.c')
0 files changed, 0 insertions, 0 deletions