lttng-context-prio.o lttng-context-nice.o \
lttng-context-vpid.o lttng-context-tid.o \
lttng-context-vtid.o lttng-context-ppid.o \
- lttng-context-vppid.o
+ lttng-context-vppid.o lttng-calibrate.o
ifneq ($(CONFIG_PERF_EVENTS),)
ltt-relay-objs += $(shell \
case LTTNG_KERNEL_WAIT_QUIESCENT:
synchronize_trace();
return 0;
+ case LTTNG_KERNEL_CALIBRATE:
+ {
+ struct lttng_calibrate __user *ucalibrate =
+ (struct lttng_calibrate __user *) arg;
+ struct lttng_calibrate calibrate;
+ int ret;
+
+ if (copy_from_user(&calibrate, ucalibrate, sizeof(calibrate)))
+ return -EFAULT;
+ ret = lttng_calibrate(&calibrate);
+ if (copy_to_user(ucalibrate, &calibrate, sizeof(calibrate)))
+ return -EFAULT;
+ return ret;
+ }
default:
return -ENOIOCTLCMD;
}
uint32_t sublevel;
};
+enum lttng_calibrate_type {
+ LTTNG_CALIBRATE_KRETPROBE,
+};
+
+struct lttng_calibrate {
+ enum lttng_calibrate_type type; /* type (input) */
+ union {
+ struct {
+ uint64_t addr; /* address to probe (output) */
+ } kretprobe;
+ } u;
+};
+
enum lttng_kernel_context_type {
LTTNG_KERNEL_CONTEXT_PID = 0,
LTTNG_KERNEL_CONTEXT_PERF_COUNTER = 1,
_IOR(0xF6, 0x41, struct lttng_kernel_tracer_version)
#define LTTNG_KERNEL_TRACEPOINT_LIST _IO(0xF6, 0x42)
#define LTTNG_KERNEL_WAIT_QUIESCENT _IO(0xF6, 0x43)
+#define LTTNG_KERNEL_CALIBRATE \
+ _IOWR(0xF6, 0x44, struct lttng_calibrate)
/* Session FD ioctl */
#define LTTNG_KERNEL_METADATA \
}
#endif
+int lttng_calibrate(struct lttng_calibrate *calibrate);
+
extern const struct file_operations lttng_tracepoint_list_fops;
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
--- /dev/null
+/*
+ * lttng-calibrate.c
+ *
+ * Copyright 2011 (c) - Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
+ *
+ * LTTng probe calibration.
+ *
+ * Dual LGPL v2.1/GPL v2 license.
+ */
+
+#include "ltt-debugfs-abi.h"
+#include "ltt-events.h"
+
+void lttng_calibrate_kretprobe(void)
+{
+}
+
+int lttng_calibrate(struct lttng_calibrate *calibrate)
+{
+ switch (calibrate->type) {
+ case LTTNG_CALIBRATE_KRETPROBE:
+ calibrate->u.kretprobe.addr = <tng_calibrate_kretprobe;
+ break;
+ default:
+ return -EINVAL;
+ }
+ return 0;
+}