projects
/
lttng-tools.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Use MT-safe strtok_r in spawn viewer library helper
[lttng-tools.git]
/
src
/
common
/
event-rule
/
event-rule.c
diff --git
a/src/common/event-rule/event-rule.c
b/src/common/event-rule/event-rule.c
index 7070115867d3fd91fb30ef1283e46133d6bf5f9f..a37559c70608cf174a5401854031521e0a506409 100644
(file)
--- a/
src/common/event-rule/event-rule.c
+++ b/
src/common/event-rule/event-rule.c
@@
-11,9
+11,13
@@
#include <common/macros.h>
#include <common/payload.h>
#include <common/payload-view.h>
#include <common/macros.h>
#include <common/payload.h>
#include <common/payload-view.h>
+#include <common/hashtable/hashtable.h>
+#include <common/hashtable/utils.h>
#include <lttng/event-rule/event-rule-internal.h>
#include <lttng/event-rule/kprobe-internal.h>
#include <lttng/event-rule/syscall-internal.h>
#include <lttng/event-rule/event-rule-internal.h>
#include <lttng/event-rule/kprobe-internal.h>
#include <lttng/event-rule/syscall-internal.h>
+#include <lttng/event-rule/tracepoint-internal.h>
+#include <lttng/event-rule/uprobe-internal.h>
#include <stdbool.h>
enum lttng_event_rule_type lttng_event_rule_get_type(
#include <stdbool.h>
enum lttng_event_rule_type lttng_event_rule_get_type(
@@
-30,9
+34,12
@@
enum lttng_domain_type lttng_event_rule_get_domain_type(
switch (lttng_event_rule_get_type(event_rule)) {
case LTTNG_EVENT_RULE_TYPE_TRACEPOINT:
switch (lttng_event_rule_get_type(event_rule)) {
case LTTNG_EVENT_RULE_TYPE_TRACEPOINT:
- /* TODO */
- domain_type = LTTNG_DOMAIN_NONE;
+ {
+ enum lttng_event_rule_status status;
+ status = lttng_event_rule_tracepoint_get_domain_type(event_rule, &domain_type);
+ assert(status == LTTNG_EVENT_RULE_STATUS_OK);
break;
break;
+ }
case LTTNG_EVENT_RULE_TYPE_SYSCALL:
case LTTNG_EVENT_RULE_TYPE_KPROBE:
case LTTNG_EVENT_RULE_TYPE_KRETPROBE:
case LTTNG_EVENT_RULE_TYPE_SYSCALL:
case LTTNG_EVENT_RULE_TYPE_KPROBE:
case LTTNG_EVENT_RULE_TYPE_KRETPROBE:
@@
-140,21
+147,30
@@
ssize_t lttng_event_rule_create_from_payload(
struct lttng_event_rule **event_rule)
{
ssize_t ret, consumed = 0;
struct lttng_event_rule **event_rule)
{
ssize_t ret, consumed = 0;
- const struct lttng_event_rule_comm *event_rule_comm;
event_rule_create_from_payload_cb create_from_payload = NULL;
event_rule_create_from_payload_cb create_from_payload = NULL;
+ const struct lttng_event_rule_comm *event_rule_comm;
+ const struct lttng_payload_view event_rule_comm_view =
+ lttng_payload_view_from_view(
+ view, 0, sizeof(*event_rule_comm));
if (!view || !event_rule) {
ret = -1;
goto end;
}
if (!view || !event_rule) {
ret = -1;
goto end;
}
- DBG("Deserializing event_rule from payload.");
- event_rule_comm = (const struct lttng_event_rule_comm *) view->buffer.data;
+ if (!lttng_payload_view_is_valid(&event_rule_comm_view)) {
+ ret = -1;
+ goto end;
+ }
+
+ DBG("Deserializing event_rule from payload");
+ event_rule_comm = (const struct lttng_event_rule_comm *) event_rule_comm_view.buffer.data;
consumed += sizeof(*event_rule_comm);
switch ((enum lttng_event_rule_type) event_rule_comm->event_rule_type) {
case LTTNG_EVENT_RULE_TYPE_TRACEPOINT:
consumed += sizeof(*event_rule_comm);
switch ((enum lttng_event_rule_type) event_rule_comm->event_rule_type) {
case LTTNG_EVENT_RULE_TYPE_TRACEPOINT:
- /* TODO */
+ create_from_payload =
+ lttng_event_rule_tracepoint_create_from_payload;
break;
case LTTNG_EVENT_RULE_TYPE_KPROBE:
create_from_payload = lttng_event_rule_kprobe_create_from_payload;
break;
case LTTNG_EVENT_RULE_TYPE_KPROBE:
create_from_payload = lttng_event_rule_kprobe_create_from_payload;
@@
-163,7
+179,7
@@
ssize_t lttng_event_rule_create_from_payload(
/* TODO */
break;
case LTTNG_EVENT_RULE_TYPE_UPROBE:
/* TODO */
break;
case LTTNG_EVENT_RULE_TYPE_UPROBE:
- /* TODO */
+ create_from_payload = lttng_event_rule_uprobe_create_from_payload;
break;
case LTTNG_EVENT_RULE_TYPE_SYSCALL:
create_from_payload =
break;
case LTTNG_EVENT_RULE_TYPE_SYSCALL:
create_from_payload =
@@
-228,10
+244,11
@@
void lttng_event_rule_put(struct lttng_event_rule *event_rule)
LTTNG_HIDDEN
enum lttng_error_code lttng_event_rule_generate_filter_bytecode(
LTTNG_HIDDEN
enum lttng_error_code lttng_event_rule_generate_filter_bytecode(
- struct lttng_event_rule *rule, uid_t uid, gid_t gid)
+ struct lttng_event_rule *rule,
+ const struct lttng_credentials *creds)
{
assert(rule->generate_filter_bytecode);
{
assert(rule->generate_filter_bytecode);
- return rule->generate_filter_bytecode(rule,
uid, gid
);
+ return rule->generate_filter_bytecode(rule,
creds
);
}
LTTNG_HIDDEN
}
LTTNG_HIDDEN
@@
-250,11
+267,12
@@
const struct lttng_filter_bytecode *lttng_event_rule_get_filter_bytecode(
}
LTTNG_HIDDEN
}
LTTNG_HIDDEN
-struct lttng_event_exclusion *lttng_event_rule_generate_exclusions(
- const struct lttng_event_rule *rule)
+enum lttng_event_rule_generate_exclusions_status
+lttng_event_rule_generate_exclusions(const struct lttng_event_rule *rule,
+ struct lttng_event_exclusion **exclusions)
{
assert(rule->generate_exclusions);
{
assert(rule->generate_exclusions);
- return rule->generate_exclusions(rule);
+ return rule->generate_exclusions(rule
, exclusions
);
}
LTTNG_HIDDEN
}
LTTNG_HIDDEN
@@
-277,3
+295,10
@@
const char *lttng_event_rule_type_str(enum lttng_event_rule_type type)
abort();
}
}
abort();
}
}
+
+LTTNG_HIDDEN
+unsigned long lttng_event_rule_hash(const struct lttng_event_rule *rule)
+{
+ assert(rule->hash);
+ return rule->hash(rule);
+}
This page took
0.026349 seconds
and
4
git commands to generate.