projects
/
lttng-ust.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Version 2.12.4
[lttng-ust.git]
/
liblttng-ust
/
lttng-ust-abi.c
diff --git
a/liblttng-ust/lttng-ust-abi.c
b/liblttng-ust/lttng-ust-abi.c
index 2de4df1aeee9a3e0dd992e2843681cff070e0c9f..1bf7a5aeab03a84b09c05dda0fdfe9ab8b7ead97 100644
(file)
--- a/
liblttng-ust/lttng-ust-abi.c
+++ b/
liblttng-ust/lttng-ust-abi.c
@@
-438,6
+438,10
@@
int lttng_abi_map_channel(int session_objd,
goto handle_error;
}
goto handle_error;
}
+ /* Ownership of chan_data and wakeup_fd taken by channel handle. */
+ uargs->channel.chan_data = NULL;
+ uargs->channel.wakeup_fd = -1;
+
chan = shmp(channel_handle, channel_handle->chan);
assert(chan);
chan->handle = channel_handle;
chan = shmp(channel_handle, channel_handle->chan);
assert(chan);
chan->handle = channel_handle;
@@
-521,24
+525,9
@@
alloc_error:
channel_destroy(chan, channel_handle, 0);
return ret;
channel_destroy(chan, channel_handle, 0);
return ret;
- /*
- * error path before channel creation (owning chan_data and
- * wakeup_fd).
- */
handle_error:
active:
invalid:
handle_error:
active:
invalid:
- {
- int close_ret;
-
- lttng_ust_lock_fd_tracker();
- close_ret = close(wakeup_fd);
- lttng_ust_unlock_fd_tracker();
- if (close_ret) {
- PERROR("close");
- }
- }
- free(chan_data);
return ret;
}
return ret;
}
@@
-783,6
+772,9
@@
int lttng_abi_map_stream(int channel_objd, struct lttng_ust_stream *info,
info->stream_nr, info->len);
if (ret)
goto error_add_stream;
info->stream_nr, info->len);
if (ret)
goto error_add_stream;
+ /* Take ownership of shm_fd and wakeup_fd. */
+ uargs->stream.shm_fd = -1;
+ uargs->stream.wakeup_fd = -1;
return 0;
return 0;
This page took
0.024436 seconds
and
4
git commands to generate.