commit-graph.c: prevent overflow in split_graph_merge_strategy()
In a similar spirit as previous commits, ensure that we don't overflow when choosing how to split and merge different layers of the commit-graph. In particular, avoid a potential overflow between `size_mult` and `num_commits`, as well as a potential overflow between the number of commits currently in the merged graph, and the number of commits in the graph about to be merged. Signed-off-by: Taylor Blau <me@ttaylorr.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
51c31a6408
commit
19565d093d
@ -2112,11 +2112,16 @@ static void split_graph_merge_strategy(struct write_commit_graph_context *ctx)
|
||||
|
||||
if (flags != COMMIT_GRAPH_SPLIT_MERGE_PROHIBITED &&
|
||||
flags != COMMIT_GRAPH_SPLIT_REPLACE) {
|
||||
while (g && (g->num_commits <= size_mult * num_commits ||
|
||||
while (g && (g->num_commits <= st_mult(size_mult, num_commits) ||
|
||||
(max_commits && num_commits > max_commits))) {
|
||||
if (g->odb != ctx->odb)
|
||||
break;
|
||||
|
||||
if (unsigned_add_overflows(num_commits, g->num_commits))
|
||||
die(_("cannot merge graphs with %"PRIuMAX", "
|
||||
"%"PRIuMAX" commits"),
|
||||
(uintmax_t)num_commits,
|
||||
(uintmax_t)g->num_commits);
|
||||
num_commits += g->num_commits;
|
||||
g = g->base_graph;
|
||||
|
||||
|
Reference in New Issue
Block a user