diff options
| author | Nicolas Pitre <nico@cam.org> | 2008-06-24 18:58:06 -0400 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-06-24 17:03:44 -0700 | 
| commit | 27d69a465d14b516d6a1ba287edc83606f23a5a5 (patch) | |
| tree | 2f5f3ac06d37831d826078f7e1c74e6526baeaba | |
| parent | 29b0d01912cdf291ad2e9f6a4f143ee9e3c01ef9 (diff) | |
| download | git-27d69a465d14b516d6a1ba287edc83606f23a5a5.tar.gz | |
refactor pack structure allocation
New pack structures are currently allocated in 2 different places
and all members have to be initialized explicitly.  This is prone
to errors leading to segmentation faults as found by Teemu Likonen.
Let's have a common place where this structure is allocated, and have
all members explicitly initialized to zero.
Signed-off-by: Nicolas Pitre <nico@cam.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | sha1_file.c | 33 | 
1 files changed, 15 insertions, 18 deletions
| diff --git a/sha1_file.c b/sha1_file.c index 9330bc4920..b858c1308f 100644 --- a/sha1_file.c +++ b/sha1_file.c @@ -792,18 +792,28 @@ unsigned char* use_pack(struct packed_git *p,  	return win->base + offset;  } +static struct packed_git *alloc_packed_git(int extra) +{ +	struct packed_git *p = xmalloc(sizeof(*p) + extra); +	memset(p, 0, sizeof(*p)); +	p->pack_fd = -1; +	return p; +} +  struct packed_git *add_packed_git(const char *path, int path_len, int local)  {  	struct stat st; -	struct packed_git *p = xmalloc(sizeof(*p) + path_len + 2); +	struct packed_git *p = alloc_packed_git(path_len + 2);  	/*  	 * Make sure a corresponding .pack file exists and that  	 * the index looks sane.  	 */  	path_len -= strlen(".idx"); -	if (path_len < 1) +	if (path_len < 1) { +		free(p);  		return NULL; +	}  	memcpy(p->pack_name, path, path_len);  	strcpy(p->pack_name + path_len, ".pack");  	if (stat(p->pack_name, &st) || !S_ISREG(st.st_mode)) { @@ -814,16 +824,7 @@ struct packed_git *add_packed_git(const char *path, int path_len, int local)  	/* ok, it looks sane as far as we can check without  	 * actually mapping the pack file.  	 */ -	p->index_version = 0; -	p->index_data = NULL; -	p->index_size = 0; -	p->num_objects = 0; -	p->num_bad_objects = 0; -	p->bad_object_sha1 = NULL;  	p->pack_size = st.st_size; -	p->next = NULL; -	p->windows = NULL; -	p->pack_fd = -1;  	p->pack_local = local;  	p->mtime = st.st_mtime;  	if (path_len < 40 || get_sha1_hex(path + path_len - 40, p->sha1)) @@ -835,19 +836,15 @@ struct packed_git *parse_pack_index(unsigned char *sha1)  {  	const char *idx_path = sha1_pack_index_name(sha1);  	const char *path = sha1_pack_name(sha1); -	struct packed_git *p = xmalloc(sizeof(*p) + strlen(path) + 2); +	struct packed_git *p = alloc_packed_git(strlen(path) + 1); +	strcpy(p->pack_name, path); +	hashcpy(p->sha1, sha1);  	if (check_packed_git_idx(idx_path, p)) {  		free(p);  		return NULL;  	} -	strcpy(p->pack_name, path); -	p->pack_size = 0; -	p->next = NULL; -	p->windows = NULL; -	p->pack_fd = -1; -	hashcpy(p->sha1, sha1);  	return p;  } | 
