#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
+#include <stdbool.h>
#include "../command.h"
{
int ret;
char *session_name = NULL;
+ bool session_was_stopped;
ret = lttng_stop_tracing_no_wait(session->name);
if (ret < 0 && ret != -LTTNG_ERR_TRACE_ALREADY_STOPPED) {
ERR("%s", lttng_strerror(ret));
}
+ session_was_stopped = ret == -LTTNG_ERR_TRACE_ALREADY_STOPPED;
if (!opt_no_wait) {
_MSG("Waiting for data availability");
fflush(stdout);
} while (ret != 0);
MSG("");
}
+ if (!session_was_stopped) {
+ /*
+ * Don't print the event and packet loss warnings since the user
+ * already saw them when stopping the trace.
+ */
+ print_session_stats(session->name);
+ }
ret = lttng_destroy_session_no_wait(session->name);
if (ret < 0) {
#include <signal.h>
#include <netinet/in.h>
#include <arpa/inet.h>
+#include <inttypes.h>
#include <common/error.h>
#include <common/utils.h>
return ret;
}
+
+/*
+ * Get the discarded events and lost packet counts.
+ */
+void print_session_stats(const char *session_name)
+{
+ int count, nb_domains, domain_idx, channel_idx;
+ struct lttng_domain *domains;
+ struct lttng_channel *channels;
+ uint64_t discarded_total = 0, lost_total = 0;
+
+ nb_domains = lttng_list_domains(session_name, &domains);
+ if (nb_domains < 0) {
+ goto end;
+ }
+ for (domain_idx = 0; domain_idx < nb_domains; domain_idx++) {
+ struct lttng_handle *handle = lttng_create_handle(session_name,
+ &domains[domain_idx]);
+
+ if (!handle) {
+ ERR("Failed to create session handle while printing session stats.");
+ goto end;
+ }
+
+ count = lttng_list_channels(handle, &channels);
+ for (channel_idx = 0; channel_idx < count; channel_idx++) {
+ int ret;
+ uint64_t discarded = 0, lost = 0;
+ struct lttng_channel *channel = &channels[channel_idx];
+
+ ret = lttng_channel_get_discarded_event_count(channel,
+ &discarded);
+ if (ret) {
+ ERR("Failed to retrieve discarded event count from channel %s",
+ channel->name);
+ }
+
+ ret = lttng_channel_get_lost_packet_count(channel,
+ &lost);
+ if (ret) {
+ ERR("Failed to retrieve lost packet count from channel %s",
+ channel->name);
+ }
+
+ discarded_total += discarded;
+ lost_total += lost;
+ }
+ lttng_destroy_handle(handle);
+ }
+ if (discarded_total > 0) {
+ MSG("[warning] %" PRIu64 " events discarded, please refer to "
+ "the documentation on channel configuration.",
+ discarded_total);
+ }
+ if (lost_total > 0) {
+ MSG("[warning] %" PRIu64 " packets lost, please refer to "
+ "the documentation on channel configuration.",
+ lost_total);
+ }
+
+end:
+ return;
+}