@@ -1737,7 +1737,10 @@ static int read_index_extension(struct index_state *istate,
17371737{
17381738 switch (CACHE_EXT (ext )) {
17391739 case CACHE_EXT_TREE :
1740+ trace2_region_enter ("index" , "read/extension/cache_tree" , NULL );
17401741 istate -> cache_tree = cache_tree_read (data , sz );
1742+ trace2_data_intmax ("index" , NULL , "read/extension/cache_tree/bytes" , (intmax_t )sz );
1743+ trace2_region_leave ("index" , "read/extension/cache_tree" , NULL );
17411744 break ;
17421745 case CACHE_EXT_RESOLVE_UNDO :
17431746 istate -> resolve_undo = resolve_undo_read (data , sz , the_hash_algo );
@@ -2027,6 +2030,17 @@ static void *load_index_extensions(void *_data)
20272030 return NULL ;
20282031}
20292032
2033+ static void * load_index_extensions_threadproc (void * _data )
2034+ {
2035+ void * result ;
2036+
2037+ trace2_thread_start ("load_index_extensions" );
2038+ result = load_index_extensions (_data );
2039+ trace2_thread_exit ();
2040+
2041+ return result ;
2042+ }
2043+
20302044/*
20312045 * A helper function that will load the specified range of cache entries
20322046 * from the memory mapped file and add them to the given index.
@@ -2103,12 +2117,17 @@ static void *load_cache_entries_thread(void *_data)
21032117 struct load_cache_entries_thread_data * p = _data ;
21042118 int i ;
21052119
2120+ trace2_thread_start ("load_cache_entries" );
2121+
21062122 /* iterate across all ieot blocks assigned to this thread */
21072123 for (i = p -> ieot_start ; i < p -> ieot_start + p -> ieot_blocks ; i ++ ) {
21082124 p -> consumed += load_cache_entry_block (p -> istate , p -> ce_mem_pool ,
21092125 p -> offset , p -> ieot -> entries [i ].nr , p -> mmap , p -> ieot -> entries [i ].offset , NULL );
21102126 p -> offset += p -> ieot -> entries [i ].nr ;
21112127 }
2128+
2129+ trace2_thread_exit ();
2130+
21122131 return NULL ;
21132132}
21142133
@@ -2278,7 +2297,7 @@ int do_read_index(struct index_state *istate, const char *path, int must_exist)
22782297 int err ;
22792298
22802299 p .src_offset = extension_offset ;
2281- err = pthread_create (& p .pthread , NULL , load_index_extensions , & p );
2300+ err = pthread_create (& p .pthread , NULL , load_index_extensions_threadproc , & p );
22822301 if (err )
22832302 die (_ ("unable to create load_index_extensions thread: %s" ), strerror (err ));
22842303
@@ -3008,9 +3027,13 @@ static int do_write_index(struct index_state *istate, struct tempfile *tempfile,
30083027 !drop_cache_tree && istate -> cache_tree ) {
30093028 strbuf_reset (& sb );
30103029
3030+ trace2_region_enter ("index" , "write/extension/cache_tree" , NULL );
30113031 cache_tree_write (& sb , istate -> cache_tree );
30123032 err = write_index_ext_header (f , eoie_c , CACHE_EXT_TREE , sb .len ) < 0 ;
30133033 hashwrite (f , sb .buf , sb .len );
3034+ trace2_data_intmax ("index" , NULL , "write/extension/cache_tree/bytes" , (intmax_t )sb .len );
3035+ trace2_region_leave ("index" , "write/extension/cache_tree" , NULL );
3036+
30143037 if (err ) {
30153038 ret = -1 ;
30163039 goto out ;
0 commit comments