patch 9.0.1842: Need more accurate profiling

Problem:  Need more accurate profiling
Solution: Improve profiling results

closes: #12192

Reduce overhead of checking if a function should be profiled,
by caching results of checking (which are done with regexp).

Cache uf_hash for uf_name in ufunc_T.

Cache cleared when regexps are changed.

Break at first match for has_profiling lookup.

Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: Ernie Rael <errael@raelity.com>
This commit is contained in:
Ernie Rael
2023-09-02 15:09:18 +02:00
committed by Christian Brabandt
parent 9d093fd056
commit 21d3212361
8 changed files with 133 additions and 7 deletions

View File

@ -664,7 +664,8 @@ script_prof_save(
void
profile_may_start_func(profinfo_T *info, ufunc_T *fp, ufunc_T *caller)
{
if (!fp->uf_profiling && has_profiling(FALSE, fp->uf_name, NULL))
if (!fp->uf_profiling && has_profiling(FALSE, fp->uf_name, NULL,
&fp->uf_hash))
{
info->pi_started_profiling = TRUE;
func_do_profile(fp);