Michael Paquier <michael@paquier.xyz> writes:
> On Thu, Aug 30, 2018 at 10:39:26AM -0400, Tom Lane wrote:
>> (The right fix, of course, is to malloc the work buffer rather than
>> put it on the stack.)
> pg_upgrade/file.c is careful about that (5afcd2a), and has a comment on
> the matter, as does pg_standby.c.
> Now, grepping around for "BLCKSZ]", some garbage may have accumulated?
Ah, that's a cute idea for finding trouble spots.
> - entrySplitPage in ginentrypage.c
> - rewind_copy_file_range in file.c
> - _hash_alloc_buckets in hashpage.c
> - pg_prewarm.c
> - blinsert.c
> - pg_waldump.c
> - logtape.c
Some of these are safe, I think, because the buffers are only used as
targets for read() and write(). But some are definitely broken.
My own list of files that seem to have issues is
blinsert.c
generic_xlog.c
ginentrypage.c
hashpage.c
pg_verify_checksums.c
pg_waldump.c
xloginsert.c
The fact that some of these are pretty old and we've not noticed is
not good. It suggests that we don't currently have any compilers in the
buildfarm that under-align char[] arrays on the stack, which seems like
a gotcha waiting to bite us. I wonder if there is any way to persuade
some compiler on a non-Intel box to do that.
Anyway, I'll work on a patch for that, unless you were on it already?
regards, tom lane