{
int size, i, ret;
struct ltt_kernel_event *kevent;
- struct lttng_event *event_list;
+ struct lttng_event *event_list = NULL;
/* For each event in the kernel session */
cds_list_for_each_entry(kevent, &kchan->events_list.head, list) {
- ret = kernel_enable_event(kevent);
- if (ret < 0) {
- /* Enable failed but still continue */
- continue;
+ if (kevent->enabled == 0) {
+ ret = kernel_enable_event(kevent);
+ if (ret < 0) {
+ /* Enable failed but still continue */
+ continue;
+ }
}
}
}
}
free(event_list);
+
ret = LTTCOMM_OK;
end:
return ret;
ret = kernel_create_event(&event, kchan);
if (ret < 0) {
+ if (ret == -EEXIST) {
+ ret = LTTCOMM_KERN_EVENT_EXIST;
+ } else {
+ ret = LTTCOMM_KERN_ENABLE_FAIL;
+ }
goto end;
}
+
ret = LTTCOMM_OK;
end:
return ret;
{
if (to_create) {
/* Create event on all UST registered apps for session */
- ret = ust_app_create_event_all(usess, uchan, uevent);
+ ret = ust_app_create_event_glb(usess, uchan, uevent);
} else {
/* Enable event on all UST registered apps for session */
- ret = ust_app_enable_event_all(usess, uchan, uevent);
+ ret = ust_app_enable_event_glb(usess, uchan, uevent);
}
if (ret < 0) {