Bug #497 » fix-per-uid-flush.patch
src/bin/lttng-sessiond/ust-app.c | ||
---|---|---|
/*
|
||
* Start tracing for a specific UST session and app.
|
||
*/
|
||
static
|
||
int ust_app_start_trace(struct ltt_ust_session *usess, struct ust_app *app)
|
||
{
|
||
int ret = 0;
|
||
... | ... | |
/*
|
||
* Stop tracing for a specific UST session and app.
|
||
*/
|
||
static
|
||
int ust_app_stop_trace(struct ltt_ust_session *usess, struct ust_app *app)
|
||
{
|
||
int ret = 0;
|
||
struct lttng_ht_iter iter;
|
||
struct ust_app_session *ua_sess;
|
||
struct ust_app_channel *ua_chan;
|
||
struct ust_registry_session *registry;
|
||
DBG("Stopping tracing for ust app pid %d", app->pid);
|
||
... | ... | |
health_code_update();
|
||
registry = get_session_registry(ua_sess);
|
||
assert(registry);
|
||
/* Push metadata for application before freeing the application. */
|
||
(void) push_metadata(registry, ua_sess->consumer);
|
||
pthread_mutex_unlock(&ua_sess->lock);
|
||
end_no_session:
|
||
rcu_read_unlock();
|
||
health_code_update();
|
||
return 0;
|
||
error_rcu_unlock:
|
||
pthread_mutex_unlock(&ua_sess->lock);
|
||
rcu_read_unlock();
|
||
health_code_update();
|
||
return -1;
|
||
}
|
||
/*
|
||
* Flush buffers for a specific UST session and app.
|
||
*/
|
||
static
|
||
int ust_app_flush_trace(struct ltt_ust_session *usess, struct ust_app *app)
|
||
{
|
||
int ret = 0;
|
||
struct lttng_ht_iter iter;
|
||
struct ust_app_session *ua_sess;
|
||
struct ust_app_channel *ua_chan;
|
||
DBG("Flushing buffers for ust app pid %d", app->pid);
|
||
rcu_read_lock();
|
||
if (!app->compatible) {
|
||
goto end_no_session;
|
||
}
|
||
ua_sess = lookup_session_by_app(usess, app);
|
||
if (ua_sess == NULL) {
|
||
goto end_no_session;
|
||
}
|
||
pthread_mutex_lock(&ua_sess->lock);
|
||
health_code_update();
|
||
/* Flushing buffers */
|
||
cds_lfht_for_each_entry(ua_sess->channels->ht, &iter.iter, ua_chan,
|
||
node.node) {
|
||
... | ... | |
health_code_update();
|
||
registry = get_session_registry(ua_sess);
|
||
assert(registry);
|
||
/* Push metadata for application before freeing the application. */
|
||
(void) push_metadata(registry, ua_sess->consumer);
|
||
pthread_mutex_unlock(&ua_sess->lock);
|
||
end_no_session:
|
||
rcu_read_unlock();
|
||
health_code_update();
|
||
return 0;
|
||
error_rcu_unlock:
|
||
pthread_mutex_unlock(&ua_sess->lock);
|
||
rcu_read_unlock();
|
||
health_code_update();
|
||
return -1;
|
||
}
|
||
/*
|
||
... | ... | |
rcu_read_lock();
|
||
/* Flush all per UID buffers associated to that session. */
|
||
if (usess->buffer_type == LTTNG_BUFFER_PER_UID) {
|
||
cds_lfht_for_each_entry(ust_app_ht->ht, &iter.iter, app, pid_n.node) {
|
||
ret = ust_app_stop_trace(usess, app);
|
||
if (ret < 0) {
|
||
/* Continue to next apps even on error */
|
||
continue;
|
||
}
|
||
}
|
||
/* Flush buffers */
|
||
switch (usess->buffer_type) {
|
||
case LTTNG_BUFFER_PER_UID:
|
||
{
|
||
struct buffer_reg_uid *reg;
|
||
/* Flush all per UID buffers associated to that session. */
|
||
cds_list_for_each_entry(reg, &usess->buffer_reg_uid_list, lnode) {
|
||
struct buffer_reg_channel *reg_chan;
|
||
struct consumer_socket *socket;
|
||
... | ... | |
(void) consumer_flush_channel(socket, reg_chan->consumer_key);
|
||
}
|
||
}
|
||
break;
|
||
}
|
||
cds_lfht_for_each_entry(ust_app_ht->ht, &iter.iter, app, pid_n.node) {
|
||
ret = ust_app_stop_trace(usess, app);
|
||
if (ret < 0) {
|
||
/* Continue to next apps even on error */
|
||
continue;
|
||
case LTTNG_BUFFER_PER_PID:
|
||
cds_lfht_for_each_entry(ust_app_ht->ht, &iter.iter, app, pid_n.node) {
|
||
ret = ust_app_flush_trace(usess, app);
|
||
if (ret < 0) {
|
||
/* Continue to next apps even on error */
|
||
continue;
|
||
}
|
||
}
|
||
break;
|
||
default:
|
||
assert(0);
|
||
break;
|
||
}
|
||
rcu_read_unlock();
|
src/bin/lttng-sessiond/ust-app.h | ||
---|---|---|
int ust_app_version(struct ust_app *app);
|
||
void ust_app_unregister(int sock);
|
||
unsigned long ust_app_list_count(void);
|
||
int ust_app_start_trace(struct ltt_ust_session *usess, struct ust_app *app);
|
||
int ust_app_stop_trace(struct ltt_ust_session *usess, struct ust_app *app);
|
||
int ust_app_start_trace_all(struct ltt_ust_session *usess);
|
||
int ust_app_stop_trace_all(struct ltt_ust_session *usess);
|
||
int ust_app_destroy_trace_all(struct ltt_ust_session *usess);
|
- « Previous
- 1
- …
- 7
- 8
- 9
- Next »