@@ -12,7 +12,7 @@ SYNOPSIS
--
*#include <tracefs.h>*
-struct tracefs_hist pass:[*]tracefs_hist_alloc(struct tracefs_instance pass:[*] instance,
+struct tracefs_hist pass:[*]tracefs_hist_alloc(struct tracefs_tep pass:[*] tep,
const char pass:[*]system, const char pass:[*]event,
const char pass:[*]key, enum tracefs_hist_key_type type);
void tracefs_hist_free(struct tracefs_hist pass:[*]hist);
@@ -25,8 +25,8 @@ int tracefs_hist_sort_key_direction(struct tracefs_hist pass:[*]hist,
const char pass:[*]sort_key,
enum tracefs_hist_sort_direction dir);
int tracefs_hist_add_name(struct tracefs_hist pass:[*]hist, const char pass:[*]name);
-int tracefs_hist_start(struct tracefs_hist pass:[*]hist);
-int tracefs_hist_destory(struct tracefs_hist pass:[*]hist);
+int tracefs_hist_start(struct tracefs_instance pass:[*]instance, struct tracefs_hist pass:[*]hist);
+int tracefs_hist_destory(struct tracefs_instance pass:[*]instance, struct tracefs_hist pass:[*]hist);
--
DESCRIPTION
@@ -38,10 +38,11 @@ See https://www.kernel.org/doc/html/latest/trace/histogram.html for more informa
*tracefs_hist_alloc*() allocates a "struct tracefs_hist" descriptor and returns
the address of it. This descriptor must be freed by *tracefs_hist_free*().
-The _instance_ is the instance that contains the event that the histogram will be
-attached to. The _system_ is the system or group of the event. The _event_ is the event
-to attach the histogram to. The _key_ is a field of the event that will be used as
-the key of the histogram. The _type_ is the type of the _key_. See KEY TYPES below.
+The _tep_ is a trace event handle (see *tracefs_local_events*(3)), that holds the
+_system_ and _event_ that the histogram will be attached to. The _system_ is the
+system or group of the event. The _event_ is the event to attach the histogram to.
+The _key_ is a field of the event that will be used as the key of the histogram.
+The _type_ is the type of the _key_. See KEY TYPES below.
*tracefs_hist_free*() frees the _tracefs_hist_ descriptor. Note, it does not stop
or disable the running histogram if it was started. *tracefs_hist_destroy*() needs
@@ -81,15 +82,24 @@ into a single histogram (shown by either event's hist file). The _hist_
is the histogram to name, and the _name_ is the name to give it.
*tracefs_hist_start* is called to actually start the histogram _hist_.
+The _instance_ is the instance to start the histogram in, NULL if it
+should start at the top level.
*tracefs_hist_pause* is called to pause the histogram _hist_.
+The _instance_ is the instance to pause the histogram in, NULL if it
+is in the top level.
*tracefs_hist_continue* is called to continue a paused histogram _hist_.
+The _instance_ is the instance to continue the histogram, NULL if it
+is in the top level.
*tracefs_hist_reset* is called to clear / reset the histogram _hist_.
+The _instance_ is the instance to clear the histogram, NULL if it
+is in the top level.
*tracefs_hist_destory* is called to delete the histogram where it will no longer
-exist.
+exist. The _instance_ is the instance to delete the histogram from, NULL if it
+is in the top level.
KEY TYPES
@@ -152,6 +162,7 @@ int main (int argc, char **argv, char **env)
{
struct tracefs_instance *instance;
struct tracefs_hist *hist;
+ struct tep_handle *tep;
enum commands cmd;
char *cmd_str;
int ret;
@@ -186,7 +197,8 @@ int main (int argc, char **argv, char **env)
exit(-1);
}
- hist = tracefs_hist_alloc(instance, "kmem", "kmalloc",
+ tep = tracefs_local_events(NULL);
+ hist = tracefs_hist_alloc(tep, "kmem", "kmalloc",
"call_site", TRACEFS_HIST_KEY_SYM);
if (!hist) {
fprintf(stderr, "Failed hist create\n");
@@ -208,7 +220,7 @@ int main (int argc, char **argv, char **env)
switch (cmd) {
case START:
- ret = tracefs_hist_start(hist);
+ ret = tracefs_hist_start(instance, hist);
if (ret) {
char *err = tracefs_error_last(instance);
if (err)
@@ -216,16 +228,16 @@ int main (int argc, char **argv, char **env)
}
break;
case PAUSE:
- ret = tracefs_hist_pause(hist);
+ ret = tracefs_hist_pause(instance, hist);
break;
case CONT:
- ret = tracefs_hist_continue(hist);
+ ret = tracefs_hist_continue(instance, hist);
break;
case RESET:
- ret = tracefs_hist_reset(hist);
+ ret = tracefs_hist_reset(instance, hist);
break;
case DELETE:
- ret = tracefs_hist_destroy(hist);
+ ret = tracefs_hist_destroy(instance, hist);
break;
case SHOW: {
char *content;
@@ -282,9 +282,9 @@ struct tracefs_hist;
void tracefs_hist_free
(struct tracefs_hist *hist);
struct tracefs_hist *
-tracefs_hist_alloc(struct tracefs_instance * instance,
- const char *system, const char *event,
- const char *key, enum tracefs_hist_key_type type);
+tracefs_hist_alloc(struct tep_handle *tep,
+ const char *system, const char *event,
+ const char *key, enum tracefs_hist_key_type type);
int tracefs_hist_add_key(struct tracefs_hist *hist, const char *key,
enum tracefs_hist_key_type type);
int tracefs_hist_add_value(struct tracefs_hist *hist, const char *value);
@@ -294,11 +294,11 @@ int tracefs_hist_sort_key_direction(struct tracefs_hist *hist,
const char *sort_key,
enum tracefs_hist_sort_direction dir);
int tracefs_hist_add_name(struct tracefs_hist *hist, const char *name);
-int tracefs_hist_start(struct tracefs_hist *hist);
-int tracefs_hist_pause(struct tracefs_hist *hist);
-int tracefs_hist_continue(struct tracefs_hist *hist);
-int tracefs_hist_reset(struct tracefs_hist *hist);
-int tracefs_hist_destroy(struct tracefs_hist *hist);
+int tracefs_hist_start(struct tracefs_instance *instance, struct tracefs_hist *hist);
+int tracefs_hist_pause(struct tracefs_instance *instance,struct tracefs_hist *hist);
+int tracefs_hist_continue(struct tracefs_instance *instance,struct tracefs_hist *hist);
+int tracefs_hist_reset(struct tracefs_instance *instance,struct tracefs_hist *hist);
+int tracefs_hist_destroy(struct tracefs_instance *instance,struct tracefs_hist *hist);
struct tracefs_synth;
@@ -23,9 +23,10 @@
#define DESCENDING ".descending"
struct tracefs_hist {
- struct tracefs_instance *instance;
+ struct tep_handle *tep;
+ struct tep_event *event;
char *system;
- char *event;
+ char *event_name;
char *name;
char **keys;
char **values;
@@ -65,15 +66,17 @@ static void add_list(struct trace_seq *seq, const char *start,
* Returns 0 on succes -1 on error.
*/
static int
-trace_hist_start(struct tracefs_hist *hist,
+trace_hist_start(struct tracefs_instance *instance, struct tracefs_hist *hist,
enum tracefs_hist_command command)
{
- struct tracefs_instance *instance = hist->instance;
const char *system = hist->system;
- const char *event = hist->event;
+ const char *event = hist->event_name;
struct trace_seq seq;
int ret;
+ if (!tracefs_event_file_exists(instance, system, event, HIST_FILE))
+ return -1;
+
errno = -EINVAL;
if (!hist->keys)
return -1;
@@ -129,9 +132,9 @@ void tracefs_hist_free(struct tracefs_hist *hist)
if (!hist)
return;
- trace_put_instance(hist->instance);
+ tep_unref(hist->tep);
free(hist->system);
- free(hist->event);
+ free(hist->event_name);
free(hist->name);
free(hist->filter);
tracefs_list_free(hist->keys);
@@ -142,9 +145,9 @@ void tracefs_hist_free(struct tracefs_hist *hist)
/**
* tracefs_hist_alloc - Initialize a histogram
- * @instance: The instance the histogram will be in (NULL for toplevel)
+ * @tep: The tep handle that has the @system and @event.
* @system: The system the histogram event is in.
- * @event: The event that the histogram will be attached to.
+ * @event_name: The name of the event that the histogram will be attached to.
* @key: The primary key the histogram will use
* @type: The format type of the key.
*
@@ -157,33 +160,31 @@ void tracefs_hist_free(struct tracefs_hist *hist)
* NULL on failure.
*/
struct tracefs_hist *
-tracefs_hist_alloc(struct tracefs_instance * instance,
- const char *system, const char *event,
+tracefs_hist_alloc(struct tep_handle *tep,
+ const char *system, const char *event_name,
const char *key, enum tracefs_hist_key_type type)
{
+ struct tep_event *event;
struct tracefs_hist *hist;
int ret;
- if (!system || !event || !key)
+ if (!system || !event_name || !key)
return NULL;
- if (!tracefs_event_file_exists(instance, system, event, HIST_FILE))
+ event = tep_find_event_by_name(tep, system, event_name);
+ if (!event)
return NULL;
hist = calloc(1, sizeof(*hist));
if (!hist)
return NULL;
- ret = trace_get_instance(instance);
- if (ret < 0) {
- free(hist);
- return NULL;
- }
-
- hist->instance = instance;
+ tep_ref(tep);
+ hist->tep = tep;
+ hist->event = event;
hist->system = strdup(system);
- hist->event = strdup(event);
+ hist->event_name = strdup(event_name);
ret = tracefs_hist_add_key(hist, key, type);
@@ -302,58 +303,63 @@ int tracefs_hist_add_name(struct tracefs_hist *hist, const char *name)
/**
* tracefs_hist_start - enable a histogram
+ * @instance: The instance the histogram will be in (NULL for toplevel)
* @hist: The histogram to start
*
* Starts executing a histogram.
*
* Returns 0 on success, -1 on error.
*/
-int tracefs_hist_start(struct tracefs_hist *hist)
+int tracefs_hist_start(struct tracefs_instance *instance, struct tracefs_hist *hist)
{
- return trace_hist_start(hist, 0);
+ return trace_hist_start(instance, hist, 0);
}
/**
* tracefs_hist_pause - pause a histogram
+ * @instance: The instance the histogram is in (NULL for toplevel)
* @hist: The histogram to pause
*
* Pause a histogram.
*
* Returns 0 on success, -1 on error.
*/
-int tracefs_hist_pause(struct tracefs_hist *hist)
+int tracefs_hist_pause(struct tracefs_instance *instance, struct tracefs_hist *hist)
{
- return trace_hist_start(hist, HIST_CMD_PAUSE);
+ return trace_hist_start(instance, hist, HIST_CMD_PAUSE);
}
/**
* tracefs_hist_continue - continue a paused histogram
+ * @instance: The instance the histogram is in (NULL for toplevel)
* @hist: The histogram to continue
*
* Continue a histogram.
*
* Returns 0 on success, -1 on error.
*/
-int tracefs_hist_continue(struct tracefs_hist *hist)
+int tracefs_hist_continue(struct tracefs_instance *instance, struct tracefs_hist *hist)
{
- return trace_hist_start(hist, HIST_CMD_CONT);
+ return trace_hist_start(instance, hist, HIST_CMD_CONT);
}
/**
* tracefs_hist_reset - clear a histogram
+ * @instance: The instance the histogram is in (NULL for toplevel)
* @hist: The histogram to reset
*
* Resets a histogram.
*
* Returns 0 on success, -1 on error.
*/
-int tracefs_hist_reset(struct tracefs_hist *hist)
+int tracefs_hist_reset(struct tracefs_instance *instance, struct tracefs_hist *hist)
{
- return trace_hist_start(hist, HIST_CMD_CLEAR);
+ return trace_hist_start(instance, hist, HIST_CMD_CLEAR);
}
/**
* tracefs_hist_destroy - deletes a histogram (needs to be enabled again)
+ * @instance: The instance the histogram is in (NULL for toplevel)
* @hist: The histogram to delete
*
* Deletes (removes) a running histogram. This is different than
@@ -363,9 +369,9 @@ int tracefs_hist_reset(struct tracefs_hist *hist)
*
* Returns 0 on success, -1 on error.
*/
-int tracefs_hist_destroy(struct tracefs_hist *hist)
+int tracefs_hist_destroy(struct tracefs_instance *instance, struct tracefs_hist *hist)
{
- return trace_hist_start(hist, HIST_CMD_DESTROY);
+ return trace_hist_start(instance, hist, HIST_CMD_DESTROY);
}
static char **