X-Git-Url: https://git.lttng.org/?p=lttng-tools.git;a=blobdiff_plain;f=src%2Fcommon%2Fevent-rule%2Fevent-rule.c;h=627674ba90026a84cb912aa407b2a4909465f8e0;hp=e5736d6f9288e8eb716464f6ef4ffeb77c2ce692;hb=58daac01d91347336f24e1fc1cacd4e7a3101e93;hpb=077192fd1880652a61400b493a0b6cf5bb199435 diff --git a/src/common/event-rule/event-rule.c b/src/common/event-rule/event-rule.c index e5736d6f9..627674ba9 100644 --- a/src/common/event-rule/event-rule.c +++ b/src/common/event-rule/event-rule.c @@ -13,6 +13,9 @@ #include #include #include +#include +#include +#include #include enum lttng_event_rule_type lttng_event_rule_get_type( @@ -29,9 +32,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: - /* 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; + } case LTTNG_EVENT_RULE_TYPE_SYSCALL: case LTTNG_EVENT_RULE_TYPE_KPROBE: case LTTNG_EVENT_RULE_TYPE_KRETPROBE: @@ -139,21 +145,30 @@ ssize_t lttng_event_rule_create_from_payload( 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; + 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; } - 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: - /* 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; @@ -162,10 +177,11 @@ ssize_t lttng_event_rule_create_from_payload( /* 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: - /* TODO */ + create_from_payload = + lttng_event_rule_syscall_create_from_payload; break; default: ERR("Attempted to create event rule of unknown type (%i)", @@ -226,10 +242,11 @@ void lttng_event_rule_put(struct lttng_event_rule *event_rule) 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); - return rule->generate_filter_bytecode(rule, uid, gid); + return rule->generate_filter_bytecode(rule, creds); } LTTNG_HIDDEN