*/
#define _LGPL_SOURCE
-#include <limits.h>
+#include <dirent.h>
#include <inttypes.h>
+#include <limits.h>
+#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/stat.h>
-#include <urcu.h>
-#include <dirent.h>
#include <sys/types.h>
-#include <pthread.h>
+#include <urcu.h>
#include <common/common.hpp>
-#include <common/utils.hpp>
-#include <common/trace-chunk.hpp>
#include <common/sessiond-comm/sessiond-comm.hpp>
-#include <lttng/location-internal.hpp>
+#include <common/trace-chunk.hpp>
+#include <common/urcu.hpp>
+#include <common/utils.hpp>
+
#include "lttng-sessiond.hpp"
-#include "kernel.hpp"
+#include <lttng/location-internal.hpp>
+#include "cmd.hpp"
+#include "kernel.hpp"
#include "session.hpp"
-#include "utils.hpp"
-#include "trace-ust.hpp"
#include "timer.hpp"
-#include "cmd.hpp"
+#include "trace-ust.hpp"
+#include "utils.hpp"
namespace {
struct ltt_session_destroy_notifier_element {
void *user_data;
};
+namespace ls = lttng::sessiond;
+
/*
* NOTES:
*
rcu_read_unlock();
return found;
}
+
+void ls::details::locked_session_release(ltt_session *session)
+{
+ session_unlock(session);
+ session_put(session);
+}
+
+ltt_session::locked_ptr ls::find_locked_session_by_id(ltt_session::id_t id)
+{
+ lttng::urcu::read_lock_guard rcu_lock;
+ auto session = session_find_by_id(id);
+
+ if (!session) {
+ return nullptr;
+ }
+
+ /*
+ * The pointer falling out of scope will unlock and release the reference to the
+ * session.
+ */
+ session_lock(session);
+ return ltt_session::locked_ptr(session);
+}
+
+ltt_session::sptr ls::find_session_by_id(ltt_session::id_t id)
+{
+ lttng::urcu::read_lock_guard rcu_lock;
+ auto session = session_find_by_id(id);
+
+ if (!session) {
+ return nullptr;
+ }
+
+ return {session, session_put};
+}
#include <common/hashtable/hashtable.hpp>
#include <common/dynamic-array.hpp>
+#include <common/make-unique-wrapper.hpp>
#include <lttng/rotation.h>
#include <lttng/location.h>
#include <lttng/lttng-error.h>
typedef void (*ltt_session_clear_notifier)(const struct ltt_session *session,
void *user_data);
+namespace lttng {
+namespace sessiond {
+namespace details {
+void locked_session_release(ltt_session *session);
+} /* namespace details */
+} /* namespace sessiond */
+} /* namespace lttng */
+
/*
* Tracing session list
*
* session for both LTTng and UST.
*/
struct ltt_session {
+ using id_t = uint64_t;
+ using locked_ptr = std::unique_ptr<ltt_session,
+ lttng::details::create_unique_class<ltt_session,
+ lttng::sessiond::details::locked_session_release>::deleter>;
+ using sptr = std::shared_ptr<ltt_session>;
+
char name[NAME_MAX];
bool has_auto_generated_name;
bool name_contains_creation_time;
*/
pthread_mutex_t lock;
struct cds_list_head list;
- uint64_t id; /* session unique identifier */
+ /* session unique identifier */
+ id_t id;
/* Indicates if the session has been added to the session list and ht.*/
bool published;
/* Indicates if a destroy command has been applied to this session. */
const struct ltt_session *session);
struct ltt_session *session_find_by_name(const char *name);
-struct ltt_session *session_find_by_id(uint64_t id);
+struct ltt_session *session_find_by_id(ltt_session::id_t id);
struct ltt_session_list *session_get_list(void);
void session_list_wait_empty(void);
*/
bool sample_session_id_by_name(const char *name, uint64_t *id);
+namespace lttng {
+namespace sessiond {
+
+/*
+ * Session list lock must be acquired by the caller.
+ * The caller must not keep the ownership of the returned locked session
+ * for longer than strictly necessary. If your intention is to acquire
+ * a reference to an ltt_session, see `find_session_by_id()`.
+ */
+ltt_session::locked_ptr find_locked_session_by_id(ltt_session::id_t id);
+
+/*
+ * Session list lock must be acquired by the caller.
+ * The caller must not keep the ownership of the returned locked session
+ * for longer than strictly necessary. If your intention is to acquire
+ * a reference to an ltt_session, see `find_session_by_id()`.
+ */
+ltt_session::sptr find_session_by_id(ltt_session::id_t id);
+
+} /* namespace sessiond */
+} /* namespace lttng */
+
#endif /* _LTT_SESSION_H */