From: René Scharfe Date: Sat, 18 Dec 2021 09:47:03 +0000 (+0100) Subject: daemon: plug memory leak on overlong path X-Git-Tag: v2.35.0-rc0~28^2 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=999bba3e0bbb2e81a3e1b2bdb5846479d1e663ad;p=thirdparty%2Fgit.git daemon: plug memory leak on overlong path Release the strbuf containing the interpolated path after copying it to a stack buffer and before erroring out if it's too long. Signed-off-by: René Scharfe Signed-off-by: Junio C Hamano --- diff --git a/daemon.c b/daemon.c index b1fcbe0d6f..99ae30fedb 100644 --- a/daemon.c +++ b/daemon.c @@ -232,13 +232,13 @@ static const char *path_ok(const char *directory, struct hostinfo *hi) rlen = strlcpy(interp_path, expanded_path.buf, sizeof(interp_path)); + strbuf_release(&expanded_path); if (rlen >= sizeof(interp_path)) { logerror("interpolated path too large: %s", interp_path); return NULL; } - strbuf_release(&expanded_path); loginfo("Interpolated dir '%s'", interp_path); dir = interp_path;