X-Git-Url: https://git.lttng.org/?p=lttng-tools.git;a=blobdiff_plain;f=src%2Fbin%2Flttng-relayd%2Fctf-trace.h;h=120549633c082fa9a6b00313787322f826be1863;hp=a64d53aa663df0c7dd6abf3b2e5bba7a557fabef;hb=2a10de3b3b5a198a1633ff4167a9610c493994c1;hpb=2a174661a1e0ab551b41ff1cae7191688525fc1f diff --git a/src/bin/lttng-relayd/ctf-trace.h b/src/bin/lttng-relayd/ctf-trace.h index a64d53aa6..120549633 100644 --- a/src/bin/lttng-relayd/ctf-trace.h +++ b/src/bin/lttng-relayd/ctf-trace.h @@ -1,6 +1,10 @@ +#ifndef _CTF_TRACE_H +#define _CTF_TRACE_H + /* * Copyright (C) 2013 - Julien Desfossez * David Goulet + * 2015 - Mathieu Desnoyers * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License, version 2 only, as @@ -16,49 +20,52 @@ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ -#ifndef _CTF_TRACE_H -#define _CTF_TRACE_H - #include +#include #include -#include "lttng-relayd.h" #include "session.h" +#include "stream.h" +#include "viewer-stream.h" struct ctf_trace { - int refcount; - unsigned int invalid_flag:1; + struct urcu_ref ref; /* Every stream has a ref on the trace. */ + struct relay_session *session; /* Back ref to trace session */ + + /* Trace sub-folder relative to the session output path. */ + char *path; + + /* + * The ctf_trace lock nests inside the session lock. + */ + pthread_mutex_t lock; uint64_t id; - uint64_t metadata_received; - uint64_t metadata_sent; - struct relay_stream *metadata_stream; - struct relay_viewer_stream *viewer_metadata_stream; - /* Node indexed by stream path name in the corresponding session. */ - struct lttng_ht_node_str node; + struct relay_viewer_stream *viewer_metadata_stream; /* RCU protected */ - /* Relay stream associated with this ctf trace. */ + /* + * Relay streams associated with this ctf trace. + * Updates are protected by the stream_list lock. + * Traversals are protected by RCU. + */ struct cds_list_head stream_list; + pthread_mutex_t stream_list_lock; + + /* + * Node within session trace hash table. Node is indexed by + * stream path name. + */ + struct lttng_ht_node_str node; + struct rcu_head rcu_node; /* For call_rcu teardown. */ }; -static inline void ctf_trace_get_ref(struct ctf_trace *trace) -{ - uatomic_inc(&trace->refcount); -} +struct ctf_trace *ctf_trace_get_by_path_or_create(struct relay_session *session, + const char *subpath); +bool ctf_trace_get(struct ctf_trace *trace); +void ctf_trace_put(struct ctf_trace *trace); -static inline void ctf_trace_put_ref(struct ctf_trace *trace) -{ - uatomic_add(&trace->refcount, -1); -} +int ctf_trace_close(struct ctf_trace *trace); -void ctf_trace_assign(struct relay_stream *stream); -struct ctf_trace *ctf_trace_create(char *path_name); -void ctf_trace_destroy(struct ctf_trace *obj); -void ctf_trace_try_destroy(struct relay_session *session, - struct ctf_trace *ctf_trace); -struct ctf_trace *ctf_trace_find_by_path(struct lttng_ht *ht, - char *path_name); -void ctf_trace_add(struct lttng_ht *ht, struct ctf_trace *trace); -void ctf_trace_delete(struct lttng_ht *ht, struct ctf_trace *trace); +struct relay_viewer_stream *ctf_trace_get_viewer_metadata_stream(struct ctf_trace *trace); #endif /* _CTF_TRACE_H */