diff options
author | Thomas White <taw@physics.org> | 2021-12-07 17:15:04 +0100 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2021-12-07 17:20:18 +0100 |
commit | 0c5f4739df52f8cf1782d7a608dfa49336e94844 (patch) | |
tree | a50f4b2d0afc99f3d4fa60c8de55ac3f5886768b | |
parent | fe938a0ad2af037fff80114ca2832d41dc48e55e (diff) |
indexamajig: Generate per-frame profiling numbers
-rw-r--r-- | src/im-sandbox.c | 16 | ||||
-rw-r--r-- | src/time-accounts.c | 50 | ||||
-rw-r--r-- | src/time-accounts.h | 3 |
3 files changed, 63 insertions, 6 deletions
diff --git a/src/im-sandbox.c b/src/im-sandbox.c index 9724c245..9115cb1b 100644 --- a/src/im-sandbox.c +++ b/src/im-sandbox.c @@ -329,7 +329,6 @@ static int run_work(const struct index_args *iargs, Stream *st, int cookie, const char *tmpdir, struct sandbox *sb) { int allDone = 0; - TimeAccounts *taccs; struct im_zmq *zmqstuff = NULL; /* Connect via ZMQ */ @@ -344,10 +343,9 @@ static int run_work(const struct index_args *iargs, Stream *st, } } - taccs = time_accounts_init(); - while ( !allDone ) { + TimeAccounts *taccs; struct pattern_args pargs; int ser; char *line; @@ -357,6 +355,8 @@ static int run_work(const struct index_args *iargs, Stream *st, char *ser_str = NULL; int ok = 1; + taccs = time_accounts_init(); + /* Wait until an event is ready */ time_accounts_set(taccs, TACC_EVENTWAIT); set_last_task(sb->shared->last_task[cookie], "wait_event"); @@ -456,15 +456,19 @@ static int run_work(const struct index_args *iargs, Stream *st, /* pargs.zmq_data will be copied into the image structure, so * that it can be queried for "header" values etc. It will * eventually be freed by image_free() under process_image() */ + + if ( sb->profile ) { + pthread_mutex_lock(&sb->shared->term_lock); + time_accounts_print_short(taccs); + pthread_mutex_unlock(&sb->shared->term_lock); + } + time_accounts_free(taccs); } im_zmq_shutdown(zmqstuff); - time_accounts_set(taccs, TACC_FINALCLEANUP); cleanup_indexing(iargs->ipriv); cell_free(iargs->cell); - if ( sb->profile ) time_accounts_print(taccs); - time_accounts_free(taccs); return 0; } diff --git a/src/time-accounts.c b/src/time-accounts.c index 77ab9b5d..7124ed51 100644 --- a/src/time-accounts.c +++ b/src/time-accounts.c @@ -98,6 +98,13 @@ static int find_account(TimeAccounts *accs, enum timeaccount acc) } +void time_accounts_reset(TimeAccounts *accs) +{ + accs->n_accs = 0; + accs->cur_acc = TACC_NOTHING; +} + + #ifdef HAVE_CLOCK_GETTIME void time_accounts_set(TimeAccounts *accs, enum timeaccount new_acc) @@ -192,6 +199,49 @@ static const char *taccname(enum timeaccount acc) } +static const char *taccname_short(enum timeaccount acc) +{ + switch ( acc ) { + case TACC_NOTHING : return "?????"; + case TACC_SELECT : return "selct"; + case TACC_STREAMREAD : return "sread"; + case TACC_SIGNALS : return "signs"; + case TACC_QUEUETOPUP : return "qfill"; + case TACC_STATUS : return "print"; + case TACC_ENDCHECK : return "endch"; + case TACC_WAKEUP : return "wakew"; + case TACC_WAITPID : return "waitw"; + case TACC_WAITFILE : return "wfile"; + case TACC_HDF5OPEN : return "ofile"; + case TACC_HDF5READ : return "rfile"; + case TACC_FILTER : return "filtr"; + case TACC_RESRANGE : return "rrnge"; + case TACC_PEAKSEARCH : return "peaks"; + case TACC_INDEXING : return "index"; + case TACC_PREDPARAMS : return "predp"; + case TACC_INTEGRATION : return "integ"; + case TACC_TOTALS : return "ctotl"; + case TACC_WRITESTREAM : return "swrte"; + case TACC_CLEANUP : return "clean"; + case TACC_EVENTWAIT : return "wevnt"; + case TACC_FINALCLEANUP : return "final"; + default : return "unkwn"; + } +} + + +void time_accounts_print_short(TimeAccounts *accs) +{ + int i; + for ( i=0; i<accs->n_accs; i++ ) { + printf("%s: %.3f ", taccname_short(accs->accs[i]), + (double)accs->sec[i] + accs->nsec[i]/1e9); + } + printf("\n"); + fflush(stdout); +} + + void time_accounts_print(TimeAccounts *accs) { int i; diff --git a/src/time-accounts.h b/src/time-accounts.h index 41990e7f..c7e54d0f 100644 --- a/src/time-accounts.h +++ b/src/time-accounts.h @@ -67,6 +67,9 @@ extern void time_accounts_free(TimeAccounts *accs); extern void time_accounts_set(TimeAccounts *accs, enum timeaccount new_acc); +extern void time_accounts_reset(TimeAccounts *accs); + +extern void time_accounts_print_short(TimeAccounts *accs); extern void time_accounts_print(TimeAccounts *accs); #endif /* TIME_ACCOUNTS_H */ |