diff options
author | Junio C Hamano <gitster@pobox.com> | 2011-03-26 20:13:15 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2011-03-26 20:13:15 -0700 |
commit | b3369abfeb4b1630905de2ab516aeb946c0c19db (patch) | |
tree | 7d6c3279d4b6b2e8b5ea45bd8bf3181e2251ee0a /builtin/fetch-pack.c | |
parent | a080fdd1b15612f71e5cc660c108f7d6c03804dd (diff) | |
parent | 066bf4c2e43c7fb40405843e49f809431314865d (diff) | |
download | git-b3369abfeb4b1630905de2ab516aeb946c0c19db.tar.gz git-b3369abfeb4b1630905de2ab516aeb946c0c19db.tar.xz |
Merge branch 'jc/fetch-progressive-stride'
* jc/fetch-progressive-stride:
fetch-pack: use smaller handshake window for initial request
fetch-pack: progressively use larger handshake windows
fetch-pack: factor out hardcoded handshake window size
Conflicts:
builtin/fetch-pack.c
Diffstat (limited to 'builtin/fetch-pack.c')
-rw-r--r-- | builtin/fetch-pack.c | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/builtin/fetch-pack.c b/builtin/fetch-pack.c index 0ef9a1194..bf9990ce1 100644 --- a/builtin/fetch-pack.c +++ b/builtin/fetch-pack.c @@ -229,11 +229,25 @@ static void insert_alternate_refs(void) foreach_alt_odb(refs_from_alternate_cb, insert_one_alternate_ref); } +#define INITIAL_FLUSH 16 +#define LARGE_FLUSH 1024 + +static int next_flush(int count) +{ + if (count < INITIAL_FLUSH * 2) + count += INITIAL_FLUSH; + else if (count < LARGE_FLUSH) + count <<= 1; + else + count += LARGE_FLUSH; + return count; +} + static int find_common(int fd[2], unsigned char *result_sha1, struct ref *refs) { int fetching; - int count = 0, flushes = 0, retval; + int count = 0, flushes = 0, flush_at = INITIAL_FLUSH, retval; const unsigned char *sha1; unsigned in_vain = 0; int got_continue = 0; @@ -347,19 +361,20 @@ static int find_common(int fd[2], unsigned char *result_sha1, if (args.verbose) fprintf(stderr, "have %s\n", sha1_to_hex(sha1)); in_vain++; - if (!(31 & ++count)) { + if (flush_at <= ++count) { int ack; packet_buf_flush(&req_buf); send_request(fd[1], &req_buf); strbuf_setlen(&req_buf, state_len); flushes++; + flush_at = next_flush(count); /* * We keep one window "ahead" of the other side, and * will wait for an ACK only on the next one */ - if (!args.stateless_rpc && count == 32) + if (!args.stateless_rpc && count == INITIAL_FLUSH) continue; consume_shallow_list(fd[0]); |