Duy Nguyen <pclouds@xxxxxxxxx> writes: > verify_hdr() is a bit expensive because you need to digest the whole > index file (could big as big as 14MB on webkit). Could we get away > without it? I mean, is it enough that we pick the last 20 bytes and > compare it with istate->sha1? If we only need 20 bytes, pread() may be > better than mmap(). True. I do not think we offer xread() equivalent for pread() to help coders to avoid the common mistake of failing to resume interrupted system calls, though. The only callsite of pread() we currently have is in index-pack.c, which just does n = pread(pack_fd, inbuf, n, from); if (n < 0) die_errno(_("cannot pread pack file")); without paying attention to EAGAIN/EINTR, that seems wrong and may want to be fixed, before we introduce another call site of pread(). Thanks. -- To unsubscribe from this list: 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