]> git.ipfire.org Git - thirdparty/git.git/commit - walker.c
walker_fetch(): avoid raw array length computation
authorJeff King <peff@peff.net>
Thu, 30 Jan 2020 09:52:32 +0000 (04:52 -0500)
committerJunio C Hamano <gitster@pobox.com>
Thu, 30 Jan 2020 21:55:02 +0000 (13:55 -0800)
commit667b76ec5819b151355e322ad9c6264b9cb3f9cd
tree1f1ce96d0a62d3ba5eb9672a1f31e139e6d56a7b
parent9734b74a8f9e327e02762024596961209cf989d5
walker_fetch(): avoid raw array length computation

We compute the length of an array of object_id's with a raw
multiplication. In theory this could trigger an integer overflow which
would cause an under-allocation (and eventually an out of bounds write).

I doubt this can be triggered in practice, since you'd need to feed it
an enormous number of target objects, which would typically come from
the ref advertisement and be using proportional memory. And even on
64-bit systems, where "int" is much smaller than "size_t", that should
hold: even though "targets" is an int, the multiplication will be done
as a size_t because of the use of sizeof().

But we can easily fix it by using ALLOC_ARRAY(), which uses st_mult()
under the hood.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
walker.c