summaryrefslogtreecommitdiffstats
path: root/Documentation/libtraceevent-field_get_val.txt
blob: 6a5f1cd74f4d2eefa3722a7aa0443c86843d1924 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
libtraceevent(3)
================

NAME
----
tep_get_any_field_val, tep_get_common_field_val, tep_get_field_val,
tep_get_field_raw - Get value of a field.

SYNOPSIS
--------
[verse]
--
*#include <event-parse.h>*
*#include <trace-seq.h>*

int *tep_get_any_field_val*(struct trace_seq pass:[*]_s_, struct tep_event pass:[*]_event_, const char pass:[*]_name_, struct tep_record pass:[*]_record_, unsigned long long pass:[*]_val_, int _err_);
int *tep_get_common_field_val*(struct trace_seq pass:[*]_s_, struct tep_event pass:[*]_event_, const char pass:[*]_name_, struct tep_record pass:[*]_record_, unsigned long long pass:[*]_val_, int _err_);
int *tep_get_field_val*(struct trace_seq pass:[*]_s_, struct tep_event pass:[*]_event_, const char pass:[*]_name_, struct tep_record pass:[*]_record_, unsigned long long pass:[*]_val_, int _err_);
void pass:[*]*tep_get_field_raw*(struct trace_seq pass:[*]_s_, struct tep_event pass:[*]_event_, const char pass:[*]_name_, struct tep_record pass:[*]_record_, int pass:[*]_len_, int _err_);
--

DESCRIPTION
-----------
These functions can be used to find a field and retrieve its value.

The *tep_get_any_field_val()* function searches in the _record_ for a field
with _name_, part of the _event_. If the field is found, its value is stored in
_val_. If there is an error and _err_ is not zero, then an error string is
written into _s_.

The *tep_get_common_field_val()* function does the same as
*tep_get_any_field_val()*, but searches only in the common fields. This works
for any event as all events include the common fields.

The *tep_get_field_val()* function does the same as *tep_get_any_field_val()*,
but searches only in the event specific fields.

The *tep_get_field_raw()* function searches in the _record_ for a field with
_name_, part of the _event_. If the field is found, a pointer to where the field
exists in the record's raw data is returned. The size of the data is stored in
_len_. If there is an error and _err_ is not zero, then an error string is
written into _s_.

RETURN VALUE
------------
The *tep_get_any_field_val()*, *tep_get_common_field_val()* and
*tep_get_field_val()* functions return 0 on success, or -1 in case of an error.

The *tep_get_field_raw()* function returns a pointer to field's raw data, and
places the length of this data in _len_. In case of an error NULL is returned.

EXAMPLE
-------
[source,c]
--
#include <event-parse.h>
#include <trace-seq.h>
...
struct tep_handle *tep = tep_alloc();
...
struct tep_event *event = tep_find_event_by_name(tep, "kvm", "kvm_exit");
...
void process_record(struct tep_record *record)
{
	int len;
	char *comm;
	struct tep_event *event;
	unsigned long long val;

	event = tep_find_event_by_record(tep, record);
	if (event != NULL) {
		if (tep_get_common_field_val(NULL, event, "common_type",
					     record, &val, 0) == 0) {
			/* Got the value of common type field */
		}
		if (tep_get_field_val(NULL, event, "pid", record, &val, 0) == 0) {
			/* Got the value of pid specific field */
		}
		comm = tep_get_field_raw(NULL, event, "comm", record, &len, 0);
		if (comm != NULL) {
			/* Got a pointer to the comm event specific field */
		}
	}
}
--

FILES
-----
[verse]
--
*event-parse.h*
	Header file to include in order to have access to the library APIs.
*trace-seq.h*
	Header file to include in order to have access to trace sequences
	related APIs. Trace sequences are used to allow a function to call
	several other functions to create a string of data to use.
*-ltraceevent*
	Linker switch to add when building a program that uses the library.
--

SEE ALSO
--------
*libtraceevent*(3), *trace-cmd*(1)

AUTHOR
------
[verse]
--
*Steven Rostedt* <rostedt@goodmis.org>, author of *libtraceevent*.
*Tzvetomir Stoyanov* <tz.stoyanov@gmail.com>, author of this man page.
--
REPORTING BUGS
--------------
Report bugs to  <linux-trace-devel@vger.kernel.org>

LICENSE
-------
libtraceevent is Free Software licensed under the GNU LGPL 2.1

RESOURCES
---------
https://git.kernel.org/pub/scm/libs/libtrace/libtraceevent.git/