diff options
author | Junio C Hamano <gitster@pobox.com> | 2015-06-05 21:00:22 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2015-06-05 21:00:22 +0200 |
commit | 06629901444888e5fa491c5f5f24ff03686af9a9 (patch) | |
tree | a0109671b6e4e52e8eb3a34d70eaa7b379b62ec6 /pack-bitmap.c | |
parent | Merge branch 'ja/tutorial-asciidoctor-fix' into maint (diff) | |
parent | pack-bitmaps: plug memory leak, fix allocation size for recent_bitmaps (diff) | |
download | git-06629901444888e5fa491c5f5f24ff03686af9a9.tar.xz git-06629901444888e5fa491c5f5f24ff03686af9a9.zip |
Merge branch 'rs/plug-leak-in-pack-bitmaps' into maint
The code to read pack-bitmap wanted to allocate a few hundred
pointers to a structure, but by mistake allocated and leaked memory
enough to hold that many actual structures. Correct the allocation
size and also have it on stack, as it is small enough.
* rs/plug-leak-in-pack-bitmaps:
pack-bitmaps: plug memory leak, fix allocation size for recent_bitmaps
Diffstat (limited to 'pack-bitmap.c')
-rw-r--r-- | pack-bitmap.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/pack-bitmap.c b/pack-bitmap.c index 62a98cc119..e5abb8a046 100644 --- a/pack-bitmap.c +++ b/pack-bitmap.c @@ -209,14 +209,12 @@ static inline uint8_t read_u8(const unsigned char *buffer, size_t *pos) return buffer[(*pos)++]; } +#define MAX_XOR_OFFSET 160 + static int load_bitmap_entries_v1(struct bitmap_index *index) { - static const size_t MAX_XOR_OFFSET = 160; - uint32_t i; - struct stored_bitmap **recent_bitmaps; - - recent_bitmaps = xcalloc(MAX_XOR_OFFSET, sizeof(struct stored_bitmap)); + struct stored_bitmap *recent_bitmaps[MAX_XOR_OFFSET] = { NULL }; for (i = 0; i < index->entry_count; ++i) { int xor_offset, flags; |