summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDerrick Stolee <stolee@gmail.com>2020-04-24 15:17:16 +0200
committerJunio C Hamano <gitster@pobox.com>2020-04-24 22:09:49 +0200
commit6c7ff7cf7f431e4accf360c018149d1e263eaf06 (patch)
tree5c244a9b0d966aeeecdf6558afb5395e13a0c5ec
parentpack-objects: consider packs in multi-pack-index (diff)
downloadgit-6c7ff7cf7f431e4accf360c018149d1e263eaf06.tar.xz
git-6c7ff7cf7f431e4accf360c018149d1e263eaf06.zip
multi-pack-index: close file descriptor after mmap
The multi-pack-index subsystem was not closing its file descriptor after memory-mapping the file contents. After this mmap() succeeds, there is no need to keep the file descriptor open. In fact, there is signficant reason to close it so we do not run out of descriptors. Signed-off-by: Derrick Stolee <dstolee@microsoft.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r--midx.c4
-rw-r--r--midx.h2
2 files changed, 1 insertions, 5 deletions
diff --git a/midx.c b/midx.c
index f3e8dbc108..95d29ce462 100644
--- a/midx.c
+++ b/midx.c
@@ -68,9 +68,9 @@ struct multi_pack_index *load_multi_pack_index(const char *object_dir, int local
FREE_AND_NULL(midx_name);
midx_map = xmmap(NULL, midx_size, PROT_READ, MAP_PRIVATE, fd, 0);
+ close(fd);
FLEX_ALLOC_MEM(m, object_dir, object_dir, strlen(object_dir));
- m->fd = fd;
m->data = midx_map;
m->data_len = midx_size;
m->local = local;
@@ -184,8 +184,6 @@ static void close_midx(struct multi_pack_index *m)
{
uint32_t i;
munmap((unsigned char *)m->data, m->data_len);
- close(m->fd);
- m->fd = -1;
for (i = 0; i < m->num_packs; i++) {
if (m->packs[i]) {
diff --git a/midx.h b/midx.h
index a210f1af2a..33c36ae19b 100644
--- a/midx.h
+++ b/midx.h
@@ -6,8 +6,6 @@
struct multi_pack_index {
struct multi_pack_index *next;
- int fd;
-
const unsigned char *data;
size_t data_len;