On Mon, Aug 27, 2018 at 9:36 PM Junio C Hamano <gitster@xxxxxxxxx> wrote: > > PS. I notice that v4 does not pad to align entries at 4 byte boundary > > like v2/v3. This could cause a slight slow down on x86 and segfault on > > some other platforms. > > Care to elaborate? > > Long time ago, we used to mmap and read directly from the index file > contents, requiring either an unaligned read or padded entries. But > that was eons ago and we first read and convert from on-disk using > get_be32() etc. to in-core structure, so I am not sure what you mean > by "segfault" here. > My bad. I saw this line #define get_be16(p) ntohs(*(unsigned short *)(p)) and jumped to conclusion without realizing that block is for safe unaligned access. > > @@ -1898,7 +1884,8 @@ int do_read_index(struct index_state *istate, const char *path, int must_exist) > > struct cache_header *hdr; > > void *mmap; > > size_t mmap_size; > > - struct strbuf previous_name_buf = STRBUF_INIT, *previous_name; > > + const struct cache_entry *previous_ce = NULL; > > + struct cache_entry *dummy_entry = NULL; > > > > if (istate->initialized) > > return istate->cache_nr; > > @@ -1936,11 +1923,10 @@ int do_read_index(struct index_state *istate, const char *path, int must_exist) > > istate->initialized = 1; > > > > if (istate->version == 4) { > > - previous_name = &previous_name_buf; > > + previous_ce = dummy_entry = make_empty_transient_cache_entry(0); > > I do like the idea of passing the previous ce around to tell the > next one what the previous name was, but I would have preferred to > see this done a bit more cleanly without requiring us to support "a > dummy entry with name whose length is 0"; a real cache entry never > has zero-length name, and our code may want to enforce it as a > sanity check. > > I think we can just call create_from_disk() with NULL set to > previous_ce in the first round; of course, the logic to assign the > one we just created to previous_ce must check istate->version, > instead of "is previous_ce NULL?" (which is an indirect way to check > the same thing used in this patch). Yeah I kinda hated dummy_entry too but the feeling wasn't strong enough to move towards the index->version check. I guess I'm going to do it now. -- Duy