Introduce new config option for mmap limit.
Rather than hardcoding the maximum number of bytes which can be mmapped from pack files we should make this value configurable, allowing the end user to increase or decrease this limit on a per-repository basis depending on the size of the repository and the capabilities of their operating system. In general users should not need to manually tune such a low-level setting within the core code, but being able to artifically limit the number of bytes which we can mmap at once from pack files will make it easier to craft test cases for the new mmap sliding window implementation. Signed-off-by: Shawn O. Pearce <spearce@spearce.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
parent
4d703a1a90
commit
77ccc5bbd1
@ -118,6 +118,15 @@ core.legacyheaders::
|
|||||||
database directly (where the "http://" and "rsync://" protocols
|
database directly (where the "http://" and "rsync://" protocols
|
||||||
count as direct access).
|
count as direct access).
|
||||||
|
|
||||||
|
core.packedGitLimit::
|
||||||
|
Maximum number of bytes to map simultaneously into memory
|
||||||
|
from pack files. If Git needs to access more than this many
|
||||||
|
bytes at once to complete an operation it will unmap existing
|
||||||
|
regions to reclaim virtual address space within the process.
|
||||||
|
Default is 256 MiB, which should be reasonable for all
|
||||||
|
users/operating systems, except on largest Git projects.
|
||||||
|
You probably do not need to adjust this value.
|
||||||
|
|
||||||
alias.*::
|
alias.*::
|
||||||
Command aliases for the gitlink:git[1] command wrapper - e.g.
|
Command aliases for the gitlink:git[1] command wrapper - e.g.
|
||||||
after defining "alias.last = cat-file commit HEAD", the invocation
|
after defining "alias.last = cat-file commit HEAD", the invocation
|
||||||
|
1
cache.h
1
cache.h
@ -196,6 +196,7 @@ extern int warn_ambiguous_refs;
|
|||||||
extern int shared_repository;
|
extern int shared_repository;
|
||||||
extern const char *apply_default_whitespace;
|
extern const char *apply_default_whitespace;
|
||||||
extern int zlib_compression_level;
|
extern int zlib_compression_level;
|
||||||
|
extern size_t packed_git_limit;
|
||||||
|
|
||||||
#define GIT_REPO_VERSION 0
|
#define GIT_REPO_VERSION 0
|
||||||
extern int repository_format_version;
|
extern int repository_format_version;
|
||||||
|
5
config.c
5
config.c
@ -298,6 +298,11 @@ int git_default_config(const char *var, const char *value)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!strcmp(var, "core.packedgitlimit")) {
|
||||||
|
packed_git_limit = git_config_int(var, value);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (!strcmp(var, "user.name")) {
|
if (!strcmp(var, "user.name")) {
|
||||||
strlcpy(git_default_name, value, sizeof(git_default_name));
|
strlcpy(git_default_name, value, sizeof(git_default_name));
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -23,6 +23,7 @@ char *git_log_output_encoding;
|
|||||||
int shared_repository = PERM_UMASK;
|
int shared_repository = PERM_UMASK;
|
||||||
const char *apply_default_whitespace;
|
const char *apply_default_whitespace;
|
||||||
int zlib_compression_level = Z_DEFAULT_COMPRESSION;
|
int zlib_compression_level = Z_DEFAULT_COMPRESSION;
|
||||||
|
size_t packed_git_limit = 256 * 1024 * 1024;
|
||||||
int pager_in_use;
|
int pager_in_use;
|
||||||
int pager_use_color = 1;
|
int pager_use_color = 1;
|
||||||
|
|
||||||
|
@ -397,7 +397,6 @@ static char *find_sha1_file(const unsigned char *sha1, struct stat *st)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define PACK_MAX_SZ (1<<26)
|
|
||||||
static int pack_used_ctr;
|
static int pack_used_ctr;
|
||||||
static unsigned long pack_mapped;
|
static unsigned long pack_mapped;
|
||||||
struct packed_git *packed_git;
|
struct packed_git *packed_git;
|
||||||
@ -490,7 +489,7 @@ int use_packed_git(struct packed_git *p)
|
|||||||
struct pack_header *hdr;
|
struct pack_header *hdr;
|
||||||
|
|
||||||
pack_mapped += p->pack_size;
|
pack_mapped += p->pack_size;
|
||||||
while (PACK_MAX_SZ < pack_mapped && unuse_one_packed_git())
|
while (packed_git_limit < pack_mapped && unuse_one_packed_git())
|
||||||
; /* nothing */
|
; /* nothing */
|
||||||
fd = open(p->pack_name, O_RDONLY);
|
fd = open(p->pack_name, O_RDONLY);
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user