projects
/
lttv.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add support for block devices in restore_init_state()
[lttv.git]
/
ltt
/
branches
/
poly
/
lttv
/
lttv
/
hook.h
diff --git
a/ltt/branches/poly/lttv/lttv/hook.h
b/ltt/branches/poly/lttv/lttv/hook.h
index 193714c6d987407a726c707005f6d0a3c6b7a041..197184a6d4ce9333be659c31ecb5a5408b0e0add 100644
(file)
--- a/
ltt/branches/poly/lttv/lttv/hook.h
+++ b/
ltt/branches/poly/lttv/lttv/hook.h
@@
-22,6
+22,7
@@
#define HOOK_H
#include <glib.h>
#define HOOK_H
#include <glib.h>
+#include <ltt/compiler.h>
/* A hook is a function to call with the supplied hook data, and with
call site specific data (e.g., hooks for events are called with a
/* A hook is a function to call with the supplied hook data, and with
call site specific data (e.g., hooks for events are called with a
@@
-122,8
+123,14
@@
gboolean lttv_hooks_call_check_merge(LttvHooks *h1, void *call_data1,
/* Sometimes different hooks need to be called based on the case. The
case is represented by an unsigned integer id */
/* Sometimes different hooks need to be called based on the case. The
case is represented by an unsigned integer id */
-typedef GPtrArray LttvHooksById;
+typedef struct _LttvHooksById {
+ GPtrArray *index;
+ GArray *array;
+} LttvHooksById;
+/* macro to calculate the hook ID of a facility/event pair. */
+#define GET_HOOK_ID(fac_id, ev_id) \
+ ( (guint)fac_id | ((guint)ev_id << FACILITIES_BITS) )
/* Create and destroy a hooks by id list */
/* Create and destroy a hooks by id list */
@@
-144,7
+151,14
@@
unsigned lttv_hooks_by_id_max_id(LttvHooksById *h);
/* Get the list of hooks for an id, NULL if none exists */
/* Get the list of hooks for an id, NULL if none exists */
-LttvHooks *lttv_hooks_by_id_get(LttvHooksById *h, unsigned id);
+static inline LttvHooks *lttv_hooks_by_id_get(LttvHooksById *h, unsigned id)
+{
+ LttvHooks *ret;
+ if(likely(id < h->index->len)) ret = h->index->pdata[id];
+ else ret = NULL;
+
+ return ret;
+}
/* Remove the list of hooks associated with an id */
/* Remove the list of hooks associated with an id */
This page took
0.023972 seconds
and
4
git commands to generate.