pack-revindex: use unsigned to store number of objects

A packfile may have up to 2^32-1 objects in it, so the
"right" data type to use is uint32_t. We currently use a
signed int, which means that we may behave incorrectly for
packfiles with more than 2^31-1 objects on 32-bit systems.

Nobody has noticed because having 2^31 objects is pretty
insane. The linux.git repo has on the order of 2^22 objects,
which is hundreds of times smaller than necessary to trigger
the bug.

Let's bump this up to an "unsigned". On 32-bit systems, this
gives us the correct data-type, and on 64-bit systems, it is
probably more efficient to use the native "unsigned" than a
true uint32_t.

While we're at it, we can fix the binary search not to
overflow in such a case if our unsigned is 32 bits.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2013-07-10 07:50:26 -04:00 committed by Junio C Hamano
parent c334b87b30
commit 012b32bb46

View File

@ -72,8 +72,8 @@ static int cmp_offset(const void *a_, const void *b_)
static void create_pack_revindex(struct pack_revindex *rix) static void create_pack_revindex(struct pack_revindex *rix)
{ {
struct packed_git *p = rix->p; struct packed_git *p = rix->p;
int num_ent = p->num_objects; unsigned num_ent = p->num_objects;
int i; unsigned i;
const char *index = p->index_data; const char *index = p->index_data;
rix->revindex = xmalloc(sizeof(*rix->revindex) * (num_ent + 1)); rix->revindex = xmalloc(sizeof(*rix->revindex) * (num_ent + 1));
@ -114,7 +114,7 @@ static void create_pack_revindex(struct pack_revindex *rix)
struct revindex_entry *find_pack_revindex(struct packed_git *p, off_t ofs) struct revindex_entry *find_pack_revindex(struct packed_git *p, off_t ofs)
{ {
int num; int num;
int lo, hi; unsigned lo, hi;
struct pack_revindex *rix; struct pack_revindex *rix;
struct revindex_entry *revindex; struct revindex_entry *revindex;
@ -132,7 +132,7 @@ struct revindex_entry *find_pack_revindex(struct packed_git *p, off_t ofs)
lo = 0; lo = 0;
hi = p->num_objects + 1; hi = p->num_objects + 1;
do { do {
int mi = (lo + hi) / 2; unsigned mi = lo + (hi - lo) / 2;
if (revindex[mi].offset == ofs) { if (revindex[mi].offset == ofs) {
return revindex + mi; return revindex + mi;
} else if (ofs < revindex[mi].offset) } else if (ofs < revindex[mi].offset)