Matthias Lederhofer <matled@xxxxxxx> writes: > Signed-off-by: Matthias Lederhofer <matled@xxxxxxx> > --- > <yacc> fatal: packfile '../linux-2.6/.git/objects/pack/tmp-7iPJo5' > SHA1 mismatch > <yacc> error: git-fetch-pack: unable to read from git-index-pack > <yacc> error: git-index-pack died with error code 128 > <yacc> Any idea what this means? > This happens after ~12 minutes. The problem is that the loop in > upload-pack.c actually sending the pack does not reset the timeout. > I'd guess --timeout is 600 or a bit more on git.kernel.org :) > > This does not help for low timeouts with slow clients. If a client is > slow enough so the server is blocked for more time than specified by > timeout the connection will be closed too (e.g. 15kb/s with a timeout > of 30 (git adds 10 extra) is not enough). Where do we add 10 extra? > We should either add a > warning to the man page or try to fix this. I don't know if this can > be fixed not using non-blocking sockets. I think the intent of "timeout" was to protect us from funny clients by avoiding talking with the ones that take too much time doing something that should not take too long. When we are in create_pack_file(), we are already committed to the heaviest operation anyway, so one possibility might be to stop doing timeout at that point. I am not sure if that is acceptable, though -- it opens up the daemon to even easier DoS than it currently is. My gut feeling is that your patch would be fine as is (have you tried and confirmed that it helps cases other than slow clients?) > Perhaps support for resume would be quite useful too but I've no idea > how hard this is to implement. That would be _very_ hard. - : send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html