aboutsummaryrefslogtreecommitdiff
path: root/src/time-accounts.h
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2016-03-01 02:59:38 -0800
committerThomas White <taw@physics.org>2016-03-01 03:37:24 -0800
commitc780ec9c40325c257fff73c1d330c5f4d81baea9 (patch)
tree2c633bddd6479c59b595037c879ea3227d1bec93 /src/time-accounts.h
parent0c1a3d2a45878b544c0f30135fc9d1240f88889a (diff)
indexamajig: Wall clock profiling
Diffstat (limited to 'src/time-accounts.h')
-rw-r--r--src/time-accounts.h71
1 files changed, 71 insertions, 0 deletions
diff --git a/src/time-accounts.h b/src/time-accounts.h
new file mode 100644
index 00000000..92b459e1
--- /dev/null
+++ b/src/time-accounts.h
@@ -0,0 +1,71 @@
+/*
+ * time-accounts.h
+ *
+ * Simple profiling according to wall clock time
+ *
+ * Copyright © 2016 Deutsches Elektronen-Synchrotron DESY,
+ * a research centre of the Helmholtz Association.
+ *
+ * Authors:
+ * 2016 Thomas White <taw@physics.org>
+ *
+ * This file is part of CrystFEL.
+ *
+ * CrystFEL is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * CrystFEL is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with CrystFEL. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#ifndef TIME_ACCOUNTS_H
+#define TIME_ACCOUNTS_H
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+enum timeaccount
+{
+ TACC_NOTHING,
+ TACC_STREAMREAD,
+ TACC_SELECT,
+ TACC_SIGNALS,
+ TACC_QUEUETOPUP,
+ TACC_STATUS,
+ TACC_ENDCHECK,
+ TACC_WAKEUP,
+ TACC_WAITPID,
+ TACC_HDF5OPEN,
+ TACC_HDF5READ,
+ TACC_FILTER,
+ TACC_RESRANGE,
+ TACC_PEAKSEARCH,
+ TACC_INDEXING,
+ TACC_PREDPARAMS,
+ TACC_INTEGRATION,
+ TACC_TOTALS,
+ TACC_WRITESTREAM,
+ TACC_CLEANUP,
+ TACC_EVENTWAIT,
+ TACC_FINALCLEANUP,
+};
+
+typedef struct _timeaccounts TimeAccounts;
+
+extern TimeAccounts *time_accounts_init(void);
+extern void time_accounts_free(TimeAccounts *accs);
+
+extern void time_accounts_set(TimeAccounts *accs, enum timeaccount new_acc);
+
+extern void time_accounts_print(TimeAccounts *accs);
+
+#endif /* TIME_ACCOUNTS_H */