summaryrefslogtreecommitdiff
path: root/sha1_file.c
diff options
context:
space:
mode:
authorJeff King <peff@peff.net>2017-04-01 08:05:21 (GMT)
committerJunio C Hamano <gitster@pobox.com>2017-04-01 17:45:16 (GMT)
commit93cff9a978e1c177ac3e889867004a56773301b2 (patch)
tree04d51c6baf53266ac783cfa0a4ef52d58a95a058 /sha1_file.c
parent49800c940790cc7465d1b03e08d472ffd8684808 (diff)
downloadgit-93cff9a978e1c177ac3e889867004a56773301b2.zip
git-93cff9a978e1c177ac3e889867004a56773301b2.tar.gz
git-93cff9a978e1c177ac3e889867004a56773301b2.tar.bz2
sha1_loose_object_info: return error for corrupted objects
When sha1_loose_object_info() finds that a loose object file cannot be stat(2)ed or mmap(2)ed, it returns -1 to signal an error to the caller. However, if it found that the loose object file is corrupt and the object data cannot be used from it, it stuffs OBJ_BAD into "type" field of the object_info, but returns zero (i.e., success), which can confuse callers. This is due to 052fe5eac (sha1_loose_object_info: make type lookup optional, 2013-07-12), which switched the return to a strict success/error, rather than returning the type (but botched the return). Callers of regular sha1_object_info() don't notice the difference, as that function returns the type (which is OBJ_BAD in this case). However, direct callers of sha1_object_info_extended() see the function return success, but without setting any meaningful values in the object_info struct, leading them to access potentially uninitialized memory. The easiest way to see the bug is via "cat-file -s", which will happily ignore the corruption and report whatever value happened to be in the "size" variable. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'sha1_file.c')
-rw-r--r--sha1_file.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/sha1_file.c b/sha1_file.c
index d77b915..b8fbcc5 100644
--- a/sha1_file.c
+++ b/sha1_file.c
@@ -2867,7 +2867,7 @@ static int sha1_loose_object_info(const unsigned char *sha1,
if (status && oi->typep)
*oi->typep = status;
strbuf_release(&hdrbuf);
- return 0;
+ return (status < 0) ? status : 0;
}
int sha1_object_info_extended(const unsigned char *sha1, struct object_info *oi, unsigned flags)