[ltt-dev] [PATCH] make lttctl select channel_root in debugfs automatically
Zhaolei
zhaolei at cn.fujitsu.com
Thu Oct 16 00:08:50 EDT 2008
Hi Mathieu,
this patch make lttctl select channel_root in debugfs automatically
when no specify.
Applies on top of ltt-control-0.54-10102008.
Signed-off-by: Zhaolei <zhaolei at cn.fujitsu.com>
---
diff -Nur ltt-control-0.54-10102008.org/lttctl/lttctl.c ltt-control-0.54-10102008/lttctl/lttctl.c
--- ltt-control-0.54-10102008.org/lttctl/lttctl.c 2008-10-15 15:29:54.000000000 +0800
+++ ltt-control-0.54-10102008/lttctl/lttctl.c 2008-10-16 11:53:49.000000000 +0800
@@ -22,6 +22,7 @@
#include <signal.h>
#include <dirent.h>
#include <string.h>
+#include <limits.h>
#include <sys/stat.h>
/* Buffer for file copy : 4k seems optimal. */
@@ -52,6 +53,7 @@
static enum trace_mode mode = LTT_TRACE_NORMAL;
static enum trace_ctl_op op = CTL_OP_NONE;
static char *channel_root = NULL;
+static char channel_root_default[PATH_MAX];
static char *trace_root = NULL;
static char *num_threads = "1";
@@ -92,6 +94,26 @@
printf("\n");
}
+int getdebugfsmntdir(char *mntdir)
+{
+ char mnt_dir[PATH_MAX];
+ char mnt_type[PATH_MAX];
+
+ FILE *fp = fopen("/proc/mounts", "r");
+ if (!fp) {
+ return EINVAL;
+ }
+
+ while (1) {
+ if (fscanf(fp, "%*s %s %s %*s %*s %*s", mnt_dir, mnt_type) <= 0) {
+ return ENOENT;
+ }
+ if (!strcmp(mnt_type, "debugfs")) {
+ strcpy(mntdir, mnt_dir);
+ return 0;
+ }
+ }
+}
/* parse_arguments
*
@@ -304,9 +326,16 @@
ret = EINVAL;
}
if(channel_root == NULL) {
- printf("Please specify -l ltt_root_path with the -d option.\n");
- printf("\n");
- ret = EINVAL;
+ if (getdebugfsmntdir(channel_root_default) == 0) {
+ strcat(channel_root_default, "/ltt");
+ printf("No -l ltt_root_path with the -d option, using default: %s\n", channel_root_default);
+ printf("\n");
+ channel_root=channel_root_default;
+ } else {
+ printf("Please specify -l ltt_root_path with the -d option.\n");
+ printf("\n");
+ ret = EINVAL;
+ }
}
}
More information about the lttng-dev
mailing list