Skip to content

Commit c41e20b

Browse files
awhitcroftJunio C Hamano
authored andcommitted
send-pack: remove remote reference limit
When build a pack for a push we query the remote copy for existant heads. These are used to prune unnecessary objects from the pack. As we receive the remote references in get_remote_heads() we validate the reference names via check_ref() which includes a length check; rejecting those >45 characters in size. This is a miss converted change, it was originally designed to reject messages which were less than 45 characters in length (a 40 character sha1 and refs/) to prevent comparing unitialised memory. check_ref() now gets the raw length so check for at least 5 characters. Signed-off-by: Andy Whitcroft <apw@shadowen.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
1 parent 825b045 commit c41e20b

File tree

1 file changed

+1
-1
lines changed

1 file changed

+1
-1
lines changed

connect.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,7 @@ static int check_ref(const char *name, int len, unsigned int flags)
1717
if (!flags)
1818
return 1;
1919

20-
if (len > 45 || memcmp(name, "refs/", 5))
20+
if (len < 5 || memcmp(name, "refs/", 5))
2121
return 0;
2222

2323
/* Skip the "refs/" part */

0 commit comments

Comments
 (0)