From mboxrd@z Thu Jan 1 00:00:00 1970 From: Martin Koegler Subject: [PATCH] parse_commit_buffer: don't parse invalid commits Date: Sun, 6 Jan 2008 20:03:11 +0100 Message-ID: <11996461913672-git-send-email-mkoegler@auto.tuwien.ac.at> References: <11996461912682-git-send-email-mkoegler@auto.tuwien.ac.at> Cc: git@vger.kernel.org, Martin Koegler To: Junio C Hamano X-From: git-owner@vger.kernel.org Sun Jan 06 20:04:29 2008 Return-path: Envelope-to: gcvg-git-2@gmane.org Received: from vger.kernel.org ([209.132.176.167]) by lo.gmane.org with esmtp (Exim 4.50) id 1JBanN-00070m-54 for gcvg-git-2@gmane.org; Sun, 06 Jan 2008 20:04:29 +0100 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753346AbYAFTDR (ORCPT ); Sun, 6 Jan 2008 14:03:17 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753219AbYAFTDQ (ORCPT ); Sun, 6 Jan 2008 14:03:16 -0500 Received: from thor.auto.tuwien.ac.at ([128.130.60.15]:36295 "EHLO thor.auto.tuwien.ac.at" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755188AbYAFTDN (ORCPT ); Sun, 6 Jan 2008 14:03:13 -0500 Received: from localhost (localhost [127.0.0.1]) by thor.auto.tuwien.ac.at (Postfix) with ESMTP id 84585680BF6A; Sun, 6 Jan 2008 20:03:11 +0100 (CET) X-Virus-Scanned: Debian amavisd-new at auto.tuwien.ac.at Received: from thor.auto.tuwien.ac.at ([127.0.0.1]) by localhost (thor.auto.tuwien.ac.at [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id iczLrGnNoLIk; Sun, 6 Jan 2008 20:03:11 +0100 (CET) Received: by thor.auto.tuwien.ac.at (Postfix, from userid 3001) id 63DAB680BEA2; Sun, 6 Jan 2008 20:03:11 +0100 (CET) X-Mailer: git-send-email 1.5.3.1 In-Reply-To: <11996461912682-git-send-email-mkoegler@auto.tuwien.ac.at> Sender: git-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: git@vger.kernel.org Archived-At: Signed-off-by: Martin Koegler --- commit.c | 28 +++++++++++++++++++++------- 1 files changed, 21 insertions(+), 7 deletions(-) diff --git a/commit.c b/commit.c index f074811..ffa0894 100644 --- a/commit.c +++ b/commit.c @@ -48,19 +48,33 @@ struct commit *lookup_commit(const unsigned char *sha1) return check_commit(obj, sha1, 0); } -static unsigned long parse_commit_date(const char *buf) +static unsigned long parse_commit_date(const char *buf, const char* tail) { unsigned long date; + char datebuf[20]; + unsigned long len; + if (buf + 6 >= tail) + return 0; if (memcmp(buf, "author", 6)) return 0; - while (*buf++ != '\n') + while (buf < tail && *buf++ != '\n') /* nada */; + if (buf + 9 >= tail) + return 0; if (memcmp(buf, "committer", 9)) return 0; - while (*buf++ != '>') + while (buf < tail && *buf++ != '>') /* nada */; - date = strtoul(buf, NULL, 10); + if (buf >= tail) + return 0; + + len = tail - buf; + if (len > sizeof(datebuf) - 1) + len = sizeof(datebuf) - 1; + memcpy(datebuf, buf, len); + datebuf[len] = 0; + date = strtoul(datebuf, NULL, 10); if (date == ULONG_MAX) date = 0; return date; @@ -236,9 +250,9 @@ int parse_commit_buffer(struct commit *item, void *buffer, unsigned long size) return 0; item->object.parsed = 1; tail += size; - if (tail <= bufptr + 5 || memcmp(bufptr, "tree ", 5)) + if (tail <= bufptr + 46 || memcmp(bufptr, "tree ", 5) || bufptr[45] != '\n') return error("bogus commit object %s", sha1_to_hex(item->object.sha1)); - if (tail <= bufptr + 45 || get_sha1_hex(bufptr + 5, parent) < 0) + if (get_sha1_hex(bufptr + 5, parent) < 0) return error("bad tree pointer in commit %s", sha1_to_hex(item->object.sha1)); item->tree = lookup_tree(parent); @@ -275,7 +289,7 @@ int parse_commit_buffer(struct commit *item, void *buffer, unsigned long size) n_refs++; } } - item->date = parse_commit_date(bufptr); + item->date = parse_commit_date(bufptr, tail); if (track_object_refs) { unsigned i = 0; -- 1.4.4.4