xref: /aosp_15_r20/external/libtraceevent/utest/traceevent-utest.c (revision 436bf2bcd5202612ffffe471bbcc1f277cc8d28e)
1*436bf2bcSAndroid Build Coastguard Worker // SPDX-License-Identifier: LGPL-2.1
2*436bf2bcSAndroid Build Coastguard Worker /*
3*436bf2bcSAndroid Build Coastguard Worker  * Copyright (C) 2020, VMware, Tzvetomir Stoyanov <[email protected]>
4*436bf2bcSAndroid Build Coastguard Worker  *
5*436bf2bcSAndroid Build Coastguard Worker  * Modified from libtracefs to libtraceevent:
6*436bf2bcSAndroid Build Coastguard Worker  *   Copyright (C) 2021, VMware, Steven Rostedt <[email protected]>
7*436bf2bcSAndroid Build Coastguard Worker  *
8*436bf2bcSAndroid Build Coastguard Worker  */
9*436bf2bcSAndroid Build Coastguard Worker #include <stdio.h>
10*436bf2bcSAndroid Build Coastguard Worker #include <stdlib.h>
11*436bf2bcSAndroid Build Coastguard Worker #include <sys/stat.h>
12*436bf2bcSAndroid Build Coastguard Worker #include <fcntl.h>
13*436bf2bcSAndroid Build Coastguard Worker #include <unistd.h>
14*436bf2bcSAndroid Build Coastguard Worker #include <time.h>
15*436bf2bcSAndroid Build Coastguard Worker #include <dirent.h>
16*436bf2bcSAndroid Build Coastguard Worker #include <ftw.h>
17*436bf2bcSAndroid Build Coastguard Worker 
18*436bf2bcSAndroid Build Coastguard Worker #include <CUnit/CUnit.h>
19*436bf2bcSAndroid Build Coastguard Worker #include <CUnit/Basic.h>
20*436bf2bcSAndroid Build Coastguard Worker 
21*436bf2bcSAndroid Build Coastguard Worker #include "event-parse.h"
22*436bf2bcSAndroid Build Coastguard Worker #include "trace-seq.h"
23*436bf2bcSAndroid Build Coastguard Worker 
24*436bf2bcSAndroid Build Coastguard Worker #define TRACEEVENT_SUITE	"traceevent library"
25*436bf2bcSAndroid Build Coastguard Worker 
26*436bf2bcSAndroid Build Coastguard Worker #define DYN_STR_EVENT_SYSTEM		"irq"
27*436bf2bcSAndroid Build Coastguard Worker #define DYN_STR_FIELD			"name"
28*436bf2bcSAndroid Build Coastguard Worker #define DYN_STRING			"hello"
29*436bf2bcSAndroid Build Coastguard Worker #define DYN_STRING_FMT			"irq=0 handler=hello"
30*436bf2bcSAndroid Build Coastguard Worker static const char dyn_str_event[] =
31*436bf2bcSAndroid Build Coastguard Worker 	"name: irq_handler_entry\n"
32*436bf2bcSAndroid Build Coastguard Worker 	"ID: 1\n"
33*436bf2bcSAndroid Build Coastguard Worker 	"format:\n"
34*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned short common_type;\toffset:0;\tsize:2;\tsigned:0;\n"
35*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned char common_flags;\toffset:2;\tsize:1;\tsigned:0;\n"
36*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned char common_preempt_count;\toffset:3;\tsize:1;\tsigned:0;\n"
37*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:int common_pid;\toffset:4;\tsize:4;\tsigned:1;\n"
38*436bf2bcSAndroid Build Coastguard Worker 	"\n"
39*436bf2bcSAndroid Build Coastguard Worker         "\tfield:int irq;\toffset:8;\tsize:4;\tsigned:1;\n"
40*436bf2bcSAndroid Build Coastguard Worker         "\tfield:__data_loc char[] name;\toffset:12;\tsize:4;\tsigned:1;\n"
41*436bf2bcSAndroid Build Coastguard Worker 	"\n"
42*436bf2bcSAndroid Build Coastguard Worker 	"print fmt: \"irq=%d handler=%s\", REC->irq, __get_str(name)\n";
43*436bf2bcSAndroid Build Coastguard Worker 
44*436bf2bcSAndroid Build Coastguard Worker static char dyn_str_data[] = {
45*436bf2bcSAndroid Build Coastguard Worker #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
46*436bf2bcSAndroid Build Coastguard Worker 	/* common type */		1, 0x00,
47*436bf2bcSAndroid Build Coastguard Worker #else
48*436bf2bcSAndroid Build Coastguard Worker 	/* common type */		0x00, 1,
49*436bf2bcSAndroid Build Coastguard Worker #endif
50*436bf2bcSAndroid Build Coastguard Worker 	/* common flags */		0x00,
51*436bf2bcSAndroid Build Coastguard Worker 	/* common_preempt_count */	0x00,
52*436bf2bcSAndroid Build Coastguard Worker 	/* common_pid */		0x00, 0x00, 0x00, 0x00,
53*436bf2bcSAndroid Build Coastguard Worker 	/* irq */			0x00, 0x00, 0x00, 0x00,
54*436bf2bcSAndroid Build Coastguard Worker 
55*436bf2bcSAndroid Build Coastguard Worker #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
56*436bf2bcSAndroid Build Coastguard Worker 	/* name : offset */		16, 0x00,
57*436bf2bcSAndroid Build Coastguard Worker 	/* name : length */		6, 0x00,
58*436bf2bcSAndroid Build Coastguard Worker #else
59*436bf2bcSAndroid Build Coastguard Worker 	/* name : length */		0x00, 6,
60*436bf2bcSAndroid Build Coastguard Worker 	/* name : offset */		0x00, 16,
61*436bf2bcSAndroid Build Coastguard Worker #endif
62*436bf2bcSAndroid Build Coastguard Worker 	/* name */			'h', 'e', 'l', 'l', 'o', '\0',
63*436bf2bcSAndroid Build Coastguard Worker 	/* padding */			0x00, 0x00
64*436bf2bcSAndroid Build Coastguard Worker };
65*436bf2bcSAndroid Build Coastguard Worker static void *dyn_str_event_data = (void *)dyn_str_data;
66*436bf2bcSAndroid Build Coastguard Worker 
67*436bf2bcSAndroid Build Coastguard Worker static const char dyn_str_old_event[] =
68*436bf2bcSAndroid Build Coastguard Worker 	"name: irq_handler_entry\n"
69*436bf2bcSAndroid Build Coastguard Worker 	"ID: 2\n"
70*436bf2bcSAndroid Build Coastguard Worker 	"format:\n"
71*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned short common_type;\toffset:0;\tsize:2;\n"
72*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned char common_flags;\toffset:2;\tsize:1;\n"
73*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned char common_preempt_count;\toffset:3;\tsize:1;\n"
74*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:int common_pid;\toffset:4;\tsize:4;\n"
75*436bf2bcSAndroid Build Coastguard Worker 	"\n"
76*436bf2bcSAndroid Build Coastguard Worker         "\tfield:int irq;\toffset:8;\tsize:4;\n"
77*436bf2bcSAndroid Build Coastguard Worker         "\tfield:__data_loc name;\toffset:12;\tsize:2;\n"
78*436bf2bcSAndroid Build Coastguard Worker 	"\n"
79*436bf2bcSAndroid Build Coastguard Worker 	"print fmt: \"irq=%d handler=%s\", REC->irq, __get_str(name)\n";
80*436bf2bcSAndroid Build Coastguard Worker 
81*436bf2bcSAndroid Build Coastguard Worker static char dyn_str_old_data[] = {
82*436bf2bcSAndroid Build Coastguard Worker #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
83*436bf2bcSAndroid Build Coastguard Worker 	/* common type */		2, 0x00,
84*436bf2bcSAndroid Build Coastguard Worker #else
85*436bf2bcSAndroid Build Coastguard Worker 	/* common type */		0x00, 2,
86*436bf2bcSAndroid Build Coastguard Worker #endif
87*436bf2bcSAndroid Build Coastguard Worker 	/* common flags */		0x00,
88*436bf2bcSAndroid Build Coastguard Worker 	/* common_preempt_count */	0x00,
89*436bf2bcSAndroid Build Coastguard Worker 	/* common_pid */		0x00, 0x00, 0x00, 0x00,
90*436bf2bcSAndroid Build Coastguard Worker 	/* irq */			0x00, 0x00, 0x00, 0x00,
91*436bf2bcSAndroid Build Coastguard Worker 
92*436bf2bcSAndroid Build Coastguard Worker #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
93*436bf2bcSAndroid Build Coastguard Worker 	/* name : offset */		16, 0x00,
94*436bf2bcSAndroid Build Coastguard Worker #else
95*436bf2bcSAndroid Build Coastguard Worker 	/* name : offset */		0x00, 16,
96*436bf2bcSAndroid Build Coastguard Worker #endif
97*436bf2bcSAndroid Build Coastguard Worker 	/* padding */			0x00, 0x00,
98*436bf2bcSAndroid Build Coastguard Worker 	/* name */			'h', 'e', 'l', 'l', 'o', '\0',
99*436bf2bcSAndroid Build Coastguard Worker 	/* padding */			0x00, 0x00, 0x00
100*436bf2bcSAndroid Build Coastguard Worker };
101*436bf2bcSAndroid Build Coastguard Worker static void *dyn_str_old_event_data = (void *)dyn_str_old_data;
102*436bf2bcSAndroid Build Coastguard Worker 
103*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_EVENT_SYSTEM "ipi"
104*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_EVENT_FIELD  "cpumask"
105*436bf2bcSAndroid Build Coastguard Worker static const char cpumask_event_format[] =
106*436bf2bcSAndroid Build Coastguard Worker 	"name: ipi_send_cpumask\n"
107*436bf2bcSAndroid Build Coastguard Worker 	"ID: 3\n"
108*436bf2bcSAndroid Build Coastguard Worker 	"format:\n"
109*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned short common_type;\toffset:0;\tsize:2;\n"
110*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned char common_flags;\toffset:2;\tsize:1;\n"
111*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned char common_preempt_count;\toffset:3;\tsize:1;\n"
112*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:int common_pid;\toffset:4;\tsize:4;\n"
113*436bf2bcSAndroid Build Coastguard Worker 	"\n"
114*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:__data_loc cpumask_t *[] cpumask;\toffset:8;\tsize:4;\tsigned:0;\n"
115*436bf2bcSAndroid Build Coastguard Worker 	"\n"
116*436bf2bcSAndroid Build Coastguard Worker 	"print fmt: \"cpumask=%s\", __get_cpumask(cpumask)\n";
117*436bf2bcSAndroid Build Coastguard Worker 
118*436bf2bcSAndroid Build Coastguard Worker /* Mind the endianness! */
119*436bf2bcSAndroid Build Coastguard Worker #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
120*436bf2bcSAndroid Build Coastguard Worker #define DECL_CPUMASK_EVENT_DATA(name, args...)			\
121*436bf2bcSAndroid Build Coastguard Worker 	static char cpumask_##name##_event_data[] = {		\
122*436bf2bcSAndroid Build Coastguard Worker 	/* common type */		3, 0x00,                \
123*436bf2bcSAndroid Build Coastguard Worker 	/* common flags */		0x00,                   \
124*436bf2bcSAndroid Build Coastguard Worker 	/* common_preempt_count */	0x00,                   \
125*436bf2bcSAndroid Build Coastguard Worker 	/* common_pid */		0x00, 0x00, 0x00, 0x00, \
126*436bf2bcSAndroid Build Coastguard Worker 	/* [offset, size] */            16, 0x00, 8, 0x00,      \
127*436bf2bcSAndroid Build Coastguard Worker 	/* padding */			0x00, 0x00, 0x00, 0x00, \
128*436bf2bcSAndroid Build Coastguard Worker 	/* cpumask */                   args,                   \
129*436bf2bcSAndroid Build Coastguard Worker }
130*436bf2bcSAndroid Build Coastguard Worker #else
131*436bf2bcSAndroid Build Coastguard Worker #define DECL_CPUMASK_EVENT_DATA(name, args...)			\
132*436bf2bcSAndroid Build Coastguard Worker static char cpumask_##name##_event_data[] = {                       \
133*436bf2bcSAndroid Build Coastguard Worker 	/* common type */		0x00, 3,                \
134*436bf2bcSAndroid Build Coastguard Worker 	/* common flags */		0x00,                   \
135*436bf2bcSAndroid Build Coastguard Worker 	/* common_preempt_count */	0x00,                   \
136*436bf2bcSAndroid Build Coastguard Worker 	/* common_pid */		0x00, 0x00, 0x00, 0x00, \
137*436bf2bcSAndroid Build Coastguard Worker 	/* [offset, size] */            0x00, 8, 0x00, 16,      \
138*436bf2bcSAndroid Build Coastguard Worker 	/* padding */			0x00, 0x00, 0x00, 0x00, \
139*436bf2bcSAndroid Build Coastguard Worker 	/* cpumask */                   args,                   \
140*436bf2bcSAndroid Build Coastguard Worker }
141*436bf2bcSAndroid Build Coastguard Worker #endif
142*436bf2bcSAndroid Build Coastguard Worker 
143*436bf2bcSAndroid Build Coastguard Worker #define SIZEOF_LONG0_FMT "[FAILED TO PARSE] s4=0 u4=0 s8=0 u8=0x0"
144*436bf2bcSAndroid Build Coastguard Worker #define SIZEOF_LONG4_FMT "int=4 unsigned=4 unsigned int=4 long=4 unsigned long=4 long long=8 unsigned long long=8 s4=4 u4=4 s8=8 u8=8"
145*436bf2bcSAndroid Build Coastguard Worker #define SIZEOF_LONG8_FMT "int=4 unsigned=4 unsigned int=4 long=8 unsigned long=8 long long=8 unsigned long long=8 s4=4 u4=4 s8=8 u8=8"
146*436bf2bcSAndroid Build Coastguard Worker 
147*436bf2bcSAndroid Build Coastguard Worker static const char size_of_event[] =
148*436bf2bcSAndroid Build Coastguard Worker 	"name: sizeof_event\n"
149*436bf2bcSAndroid Build Coastguard Worker 	"ID: 23\n"
150*436bf2bcSAndroid Build Coastguard Worker 	"format:\n"
151*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned short common_type;\toffset:0;\tsize:2;\tsigned:0;\n"
152*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned char common_flags;\toffset:2;\tsize:1;\tsigned:0;\n"
153*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:unsigned char common_preempt_count;\toffset:3;\tsize:1;\tsigned:0;\n"
154*436bf2bcSAndroid Build Coastguard Worker 	"\tfield:int common_pid;\toffset:4;\tsize:4;\tsigned:1;\n"
155*436bf2bcSAndroid Build Coastguard Worker 	"\n"
156*436bf2bcSAndroid Build Coastguard Worker         "\tfield:int s4;\toffset:8;\tsize:4;\tsigned:1;\n"
157*436bf2bcSAndroid Build Coastguard Worker         "\tfield:unsigned int u4;\toffset:12;\tsize:4;\tsigned:0;\n"
158*436bf2bcSAndroid Build Coastguard Worker         "\tfield:long long s8;\toffset:16;\tsize:8;\tsigned:1;\n"
159*436bf2bcSAndroid Build Coastguard Worker         "\tfield:unsigned long long u8;\toffset:24;\tsize:8;\tsigned:0;\n"
160*436bf2bcSAndroid Build Coastguard Worker 	"\n"
161*436bf2bcSAndroid Build Coastguard Worker 	"print fmt: \"int=%d unsigned=%d unsigned int=%d long=%d unsigned long=%d long long=%d unsigned long long=%d s4=%d u4=%d s8=%d u8=%d\", "
162*436bf2bcSAndroid Build Coastguard Worker 	"sizeof(int), sizeof(unsigned), sizeof(unsigned int), sizeof(long), sizeof(unsigned long), "
163*436bf2bcSAndroid Build Coastguard Worker 	"sizeof(long long), sizeof(unsigned long long), sizeof(REC->s4), "
164*436bf2bcSAndroid Build Coastguard Worker 	"sizeof(REC->u4), sizeof(REC->s8), sizeof(REC->u8))\n";
165*436bf2bcSAndroid Build Coastguard Worker static char sizeof_data[] = {
166*436bf2bcSAndroid Build Coastguard Worker #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
167*436bf2bcSAndroid Build Coastguard Worker 	/* common type */		23, 0x00,
168*436bf2bcSAndroid Build Coastguard Worker #else
169*436bf2bcSAndroid Build Coastguard Worker 	/* common type */		0x00, 23,
170*436bf2bcSAndroid Build Coastguard Worker #endif
171*436bf2bcSAndroid Build Coastguard Worker 	/* common flags */		0x00,
172*436bf2bcSAndroid Build Coastguard Worker 	/* common_preempt_count */	0x00,
173*436bf2bcSAndroid Build Coastguard Worker 	/* common_pid */		0x00, 0x00, 0x00, 0x00,
174*436bf2bcSAndroid Build Coastguard Worker 	/* irq */			0x00, 0x00, 0x00, 0x00,
175*436bf2bcSAndroid Build Coastguard Worker 
176*436bf2bcSAndroid Build Coastguard Worker 	/* s4 */			0x00, 0x00, 0x00, 0x00,
177*436bf2bcSAndroid Build Coastguard Worker 	/* u4 */			0x00, 0x00, 0x00, 0x00,
178*436bf2bcSAndroid Build Coastguard Worker 	/* s8 */			0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
179*436bf2bcSAndroid Build Coastguard Worker 	/* u8 */			0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
180*436bf2bcSAndroid Build Coastguard Worker };
181*436bf2bcSAndroid Build Coastguard Worker static void *sizeof_event_data = (void *)sizeof_data;
182*436bf2bcSAndroid Build Coastguard Worker 
183*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(full, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff);
184*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_FULL     "ARRAY[ff, ff, ff, ff, ff, ff, ff, ff]"
185*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_FULL_FMT "cpumask=0-63"
186*436bf2bcSAndroid Build Coastguard Worker 
187*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(empty, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00);
188*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_EMPTY     "ARRAY[00, 00, 00, 00, 00, 00, 00, 00]"
189*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_EMPTY_FMT "cpumask="
190*436bf2bcSAndroid Build Coastguard Worker 
191*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(half, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55);
192*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_HALF     "ARRAY[55, 55, 55, 55, 55, 55, 55, 55]"
193*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_HALF_FMT "cpumask=0,2,4,6,8,10,12,14,16,18,20,22,24,26,28,30,32,34,36,38,40,42,44,46,48,50,52,54,56,58,60,62"
194*436bf2bcSAndroid Build Coastguard Worker 
195*436bf2bcSAndroid Build Coastguard Worker #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
196*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(bytep1, 0x01, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00);
197*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEP1     "ARRAY[01, 80, 00, 00, 00, 00, 00, 00]"
198*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEP1_FMT "cpumask=0,15"
199*436bf2bcSAndroid Build Coastguard Worker 
200*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(bytep2, 0x01, 0x00, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00);
201*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEP2     "ARRAY[01, 00, 80, 00, 00, 00, 00, 00]"
202*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEP2_FMT "cpumask=0,23"
203*436bf2bcSAndroid Build Coastguard Worker 
204*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(bytepn, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x80);
205*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEPN     "ARRAY[01, 00, 00, 00, 00, 00, 00, 80]"
206*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEPN_FMT "cpumask=0,63"
207*436bf2bcSAndroid Build Coastguard Worker 
208*436bf2bcSAndroid Build Coastguard Worker #else
209*436bf2bcSAndroid Build Coastguard Worker 
210*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(bytep1, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x80, 0x01);
211*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEP1     "ARRAY[00, 00, 00, 00, 00, 00, 80, 01]"
212*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEP1_FMT "cpumask=0,15"
213*436bf2bcSAndroid Build Coastguard Worker 
214*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(bytep2, 0x00, 0x00, 0x00, 0x00, 0x00, 0x80, 0x00, 0x01);
215*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEP2     "ARRAY[00, 00, 00, 00, 00, 80, 00, 01]"
216*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEP2_FMT "cpumask=0,23"
217*436bf2bcSAndroid Build Coastguard Worker 
218*436bf2bcSAndroid Build Coastguard Worker DECL_CPUMASK_EVENT_DATA(bytepn, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01);
219*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEPN     "ARRAY[80, 00, 00, 00, 00, 00, 00, 01]"
220*436bf2bcSAndroid Build Coastguard Worker #define CPUMASK_BYTEPN_FMT "cpumask=0,63"
221*436bf2bcSAndroid Build Coastguard Worker #endif
222*436bf2bcSAndroid Build Coastguard Worker 
223*436bf2bcSAndroid Build Coastguard Worker static struct tep_handle *test_tep;
224*436bf2bcSAndroid Build Coastguard Worker static struct trace_seq *test_seq;
225*436bf2bcSAndroid Build Coastguard Worker static struct trace_seq seq_storage;
226*436bf2bcSAndroid Build Coastguard Worker 
parse_dyn_str(const char * dyn_str,void * data,int size)227*436bf2bcSAndroid Build Coastguard Worker static void parse_dyn_str(const char *dyn_str, void *data, int size)
228*436bf2bcSAndroid Build Coastguard Worker {
229*436bf2bcSAndroid Build Coastguard Worker 	struct tep_format_field *field;
230*436bf2bcSAndroid Build Coastguard Worker 	struct tep_event *event;
231*436bf2bcSAndroid Build Coastguard Worker 	struct tep_record record;
232*436bf2bcSAndroid Build Coastguard Worker 
233*436bf2bcSAndroid Build Coastguard Worker 	record.data = data;
234*436bf2bcSAndroid Build Coastguard Worker 	record.size = size;
235*436bf2bcSAndroid Build Coastguard Worker 
236*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(tep_parse_format(test_tep, &event,
237*436bf2bcSAndroid Build Coastguard Worker 				 dyn_str, strlen(dyn_str),
238*436bf2bcSAndroid Build Coastguard Worker 				DYN_STR_EVENT_SYSTEM) == TEP_ERRNO__SUCCESS);
239*436bf2bcSAndroid Build Coastguard Worker 
240*436bf2bcSAndroid Build Coastguard Worker 	field = tep_find_any_field(event, DYN_STR_FIELD);
241*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(field != NULL);
242*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_reset(test_seq);
243*436bf2bcSAndroid Build Coastguard Worker 	tep_print_field_content(test_seq, data, size, field);
244*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(strcmp(test_seq->buffer, DYN_STRING) == 0);
245*436bf2bcSAndroid Build Coastguard Worker 
246*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_reset(test_seq);
247*436bf2bcSAndroid Build Coastguard Worker 	tep_print_event(test_tep, test_seq, &record, "%s", TEP_PRINT_INFO);
248*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_do_printf(test_seq);
249*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(strcmp(test_seq->buffer, DYN_STRING_FMT) == 0);
250*436bf2bcSAndroid Build Coastguard Worker }
251*436bf2bcSAndroid Build Coastguard Worker 
test_parse_dyn_str_event(void)252*436bf2bcSAndroid Build Coastguard Worker static void test_parse_dyn_str_event(void)
253*436bf2bcSAndroid Build Coastguard Worker {
254*436bf2bcSAndroid Build Coastguard Worker 	parse_dyn_str(dyn_str_event, dyn_str_event_data, sizeof(dyn_str_data));
255*436bf2bcSAndroid Build Coastguard Worker }
256*436bf2bcSAndroid Build Coastguard Worker 
test_parse_dyn_str_old_event(void)257*436bf2bcSAndroid Build Coastguard Worker static void test_parse_dyn_str_old_event(void)
258*436bf2bcSAndroid Build Coastguard Worker {
259*436bf2bcSAndroid Build Coastguard Worker 	parse_dyn_str(dyn_str_old_event, dyn_str_old_event_data, sizeof(dyn_str_old_data));
260*436bf2bcSAndroid Build Coastguard Worker }
261*436bf2bcSAndroid Build Coastguard Worker 
parse_cpumask(const char * format,void * data,int size,const char * expected_raw,const char * expected)262*436bf2bcSAndroid Build Coastguard Worker static void parse_cpumask(const char *format, void *data, int size,
263*436bf2bcSAndroid Build Coastguard Worker 			  const char* expected_raw, const char* expected)
264*436bf2bcSAndroid Build Coastguard Worker {
265*436bf2bcSAndroid Build Coastguard Worker 	struct tep_format_field *field;
266*436bf2bcSAndroid Build Coastguard Worker 	struct tep_event *event;
267*436bf2bcSAndroid Build Coastguard Worker 	struct tep_record record;
268*436bf2bcSAndroid Build Coastguard Worker 
269*436bf2bcSAndroid Build Coastguard Worker 	record.data = data;
270*436bf2bcSAndroid Build Coastguard Worker 	record.size = size;
271*436bf2bcSAndroid Build Coastguard Worker 
272*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(tep_parse_format(test_tep, &event,
273*436bf2bcSAndroid Build Coastguard Worker 				 format, strlen(format),
274*436bf2bcSAndroid Build Coastguard Worker 				 CPUMASK_EVENT_SYSTEM) == TEP_ERRNO__SUCCESS);
275*436bf2bcSAndroid Build Coastguard Worker 
276*436bf2bcSAndroid Build Coastguard Worker 	field = tep_find_any_field(event, CPUMASK_EVENT_FIELD);
277*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(field != NULL);
278*436bf2bcSAndroid Build Coastguard Worker 
279*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_reset(test_seq);
280*436bf2bcSAndroid Build Coastguard Worker 	tep_print_field_content(test_seq, data, size, field);
281*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(strcmp(test_seq->buffer, expected_raw) == 0);
282*436bf2bcSAndroid Build Coastguard Worker 
283*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_reset(test_seq);
284*436bf2bcSAndroid Build Coastguard Worker 	tep_print_event(test_tep, test_seq, &record, "%s", TEP_PRINT_INFO);
285*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_do_printf(test_seq);
286*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(strcmp(test_seq->buffer, expected) == 0);
287*436bf2bcSAndroid Build Coastguard Worker }
288*436bf2bcSAndroid Build Coastguard Worker 
test_parse_cpumask_full(void)289*436bf2bcSAndroid Build Coastguard Worker static void test_parse_cpumask_full(void)
290*436bf2bcSAndroid Build Coastguard Worker {
291*436bf2bcSAndroid Build Coastguard Worker 	parse_cpumask(cpumask_event_format,
292*436bf2bcSAndroid Build Coastguard Worker 		      cpumask_full_event_data, sizeof(cpumask_full_event_data),
293*436bf2bcSAndroid Build Coastguard Worker 		      CPUMASK_FULL, CPUMASK_FULL_FMT);
294*436bf2bcSAndroid Build Coastguard Worker }
295*436bf2bcSAndroid Build Coastguard Worker 
test_parse_cpumask_empty(void)296*436bf2bcSAndroid Build Coastguard Worker static void test_parse_cpumask_empty(void)
297*436bf2bcSAndroid Build Coastguard Worker {
298*436bf2bcSAndroid Build Coastguard Worker 	parse_cpumask(cpumask_event_format,
299*436bf2bcSAndroid Build Coastguard Worker 		      cpumask_empty_event_data, sizeof(cpumask_empty_event_data),
300*436bf2bcSAndroid Build Coastguard Worker 		      CPUMASK_EMPTY, CPUMASK_EMPTY_FMT);
301*436bf2bcSAndroid Build Coastguard Worker }
302*436bf2bcSAndroid Build Coastguard Worker 
test_parse_cpumask_half(void)303*436bf2bcSAndroid Build Coastguard Worker static void test_parse_cpumask_half(void)
304*436bf2bcSAndroid Build Coastguard Worker {
305*436bf2bcSAndroid Build Coastguard Worker 	parse_cpumask(cpumask_event_format,
306*436bf2bcSAndroid Build Coastguard Worker 		      cpumask_half_event_data, sizeof(cpumask_half_event_data),
307*436bf2bcSAndroid Build Coastguard Worker 		      CPUMASK_HALF, CPUMASK_HALF_FMT);
308*436bf2bcSAndroid Build Coastguard Worker }
309*436bf2bcSAndroid Build Coastguard Worker 
test_parse_cpumask_bytep1(void)310*436bf2bcSAndroid Build Coastguard Worker static void test_parse_cpumask_bytep1(void)
311*436bf2bcSAndroid Build Coastguard Worker {
312*436bf2bcSAndroid Build Coastguard Worker 	parse_cpumask(cpumask_event_format,
313*436bf2bcSAndroid Build Coastguard Worker 		      cpumask_bytep1_event_data, sizeof(cpumask_bytep1_event_data),
314*436bf2bcSAndroid Build Coastguard Worker 		      CPUMASK_BYTEP1, CPUMASK_BYTEP1_FMT);
315*436bf2bcSAndroid Build Coastguard Worker }
316*436bf2bcSAndroid Build Coastguard Worker 
test_parse_cpumask_bytep2(void)317*436bf2bcSAndroid Build Coastguard Worker static void test_parse_cpumask_bytep2(void)
318*436bf2bcSAndroid Build Coastguard Worker {
319*436bf2bcSAndroid Build Coastguard Worker 	parse_cpumask(cpumask_event_format,
320*436bf2bcSAndroid Build Coastguard Worker 		      cpumask_bytep2_event_data, sizeof(cpumask_bytep2_event_data),
321*436bf2bcSAndroid Build Coastguard Worker 		      CPUMASK_BYTEP2, CPUMASK_BYTEP2_FMT);
322*436bf2bcSAndroid Build Coastguard Worker }
323*436bf2bcSAndroid Build Coastguard Worker 
test_parse_cpumask_bytepn(void)324*436bf2bcSAndroid Build Coastguard Worker static void test_parse_cpumask_bytepn(void)
325*436bf2bcSAndroid Build Coastguard Worker {
326*436bf2bcSAndroid Build Coastguard Worker 	parse_cpumask(cpumask_event_format,
327*436bf2bcSAndroid Build Coastguard Worker 		      cpumask_bytepn_event_data, sizeof(cpumask_bytepn_event_data),
328*436bf2bcSAndroid Build Coastguard Worker 		      CPUMASK_BYTEPN, CPUMASK_BYTEPN_FMT);
329*436bf2bcSAndroid Build Coastguard Worker }
330*436bf2bcSAndroid Build Coastguard Worker 
test_parse_sizeof(int long_size,int value,const char * system,const char * test_str)331*436bf2bcSAndroid Build Coastguard Worker static void test_parse_sizeof(int long_size, int value, const char *system,
332*436bf2bcSAndroid Build Coastguard Worker 			      const char *test_str)
333*436bf2bcSAndroid Build Coastguard Worker {
334*436bf2bcSAndroid Build Coastguard Worker 	struct tep_event *event;
335*436bf2bcSAndroid Build Coastguard Worker 	struct tep_record record;
336*436bf2bcSAndroid Build Coastguard Worker 	char *sizeof_event;
337*436bf2bcSAndroid Build Coastguard Worker 	char *p;
338*436bf2bcSAndroid Build Coastguard Worker 
339*436bf2bcSAndroid Build Coastguard Worker 	tep_set_long_size(test_tep, long_size);
340*436bf2bcSAndroid Build Coastguard Worker 
341*436bf2bcSAndroid Build Coastguard Worker 	record.data = sizeof_event_data;
342*436bf2bcSAndroid Build Coastguard Worker 	record.size = sizeof(sizeof_data);
343*436bf2bcSAndroid Build Coastguard Worker 
344*436bf2bcSAndroid Build Coastguard Worker 	sizeof_event = strdup(size_of_event);
345*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(sizeof_event != NULL);
346*436bf2bcSAndroid Build Coastguard Worker 
347*436bf2bcSAndroid Build Coastguard Worker 	/* Set a new id */
348*436bf2bcSAndroid Build Coastguard Worker 	p = strstr(sizeof_event, "ID: 2");
349*436bf2bcSAndroid Build Coastguard Worker 	p[5] = '0' + value;
350*436bf2bcSAndroid Build Coastguard Worker 
351*436bf2bcSAndroid Build Coastguard Worker 	/* Handles endianess */
352*436bf2bcSAndroid Build Coastguard Worker 	*(unsigned short *)sizeof_data = 20 + value;
353*436bf2bcSAndroid Build Coastguard Worker 
354*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(tep_parse_format(test_tep, &event, sizeof_event,
355*436bf2bcSAndroid Build Coastguard Worker 				 strlen(sizeof_event),
356*436bf2bcSAndroid Build Coastguard Worker 				 system) == TEP_ERRNO__SUCCESS);
357*436bf2bcSAndroid Build Coastguard Worker 
358*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_reset(test_seq);
359*436bf2bcSAndroid Build Coastguard Worker 	tep_print_event(test_tep, test_seq, &record, "%s", TEP_PRINT_INFO);
360*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_do_printf(test_seq);
361*436bf2bcSAndroid Build Coastguard Worker 	CU_TEST(strcmp(test_seq->buffer, test_str) == 0);
362*436bf2bcSAndroid Build Coastguard Worker 
363*436bf2bcSAndroid Build Coastguard Worker 	free(sizeof_event);
364*436bf2bcSAndroid Build Coastguard Worker }
365*436bf2bcSAndroid Build Coastguard Worker 
test_parse_sizeof8(void)366*436bf2bcSAndroid Build Coastguard Worker static void test_parse_sizeof8(void)
367*436bf2bcSAndroid Build Coastguard Worker {
368*436bf2bcSAndroid Build Coastguard Worker 	test_parse_sizeof(8, 3, "sizeof8", SIZEOF_LONG8_FMT);
369*436bf2bcSAndroid Build Coastguard Worker }
370*436bf2bcSAndroid Build Coastguard Worker 
test_parse_sizeof4(void)371*436bf2bcSAndroid Build Coastguard Worker static void test_parse_sizeof4(void)
372*436bf2bcSAndroid Build Coastguard Worker {
373*436bf2bcSAndroid Build Coastguard Worker 	test_parse_sizeof(4, 4, "sizeof4", SIZEOF_LONG4_FMT);
374*436bf2bcSAndroid Build Coastguard Worker }
375*436bf2bcSAndroid Build Coastguard Worker 
test_parse_sizeof_undef(void)376*436bf2bcSAndroid Build Coastguard Worker static void test_parse_sizeof_undef(void)
377*436bf2bcSAndroid Build Coastguard Worker {
378*436bf2bcSAndroid Build Coastguard Worker 	test_parse_sizeof(0, 5, "sizeof_undef", SIZEOF_LONG0_FMT);
379*436bf2bcSAndroid Build Coastguard Worker }
380*436bf2bcSAndroid Build Coastguard Worker 
test_suite_destroy(void)381*436bf2bcSAndroid Build Coastguard Worker static int test_suite_destroy(void)
382*436bf2bcSAndroid Build Coastguard Worker {
383*436bf2bcSAndroid Build Coastguard Worker 	tep_free(test_tep);
384*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_destroy(test_seq);
385*436bf2bcSAndroid Build Coastguard Worker 	return 0;
386*436bf2bcSAndroid Build Coastguard Worker }
387*436bf2bcSAndroid Build Coastguard Worker 
test_suite_init(void)388*436bf2bcSAndroid Build Coastguard Worker static int test_suite_init(void)
389*436bf2bcSAndroid Build Coastguard Worker {
390*436bf2bcSAndroid Build Coastguard Worker 	test_seq = &seq_storage;
391*436bf2bcSAndroid Build Coastguard Worker 	trace_seq_init(test_seq);
392*436bf2bcSAndroid Build Coastguard Worker 	test_tep = tep_alloc();
393*436bf2bcSAndroid Build Coastguard Worker 	if (!test_tep)
394*436bf2bcSAndroid Build Coastguard Worker 		return 1;
395*436bf2bcSAndroid Build Coastguard Worker #if __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
396*436bf2bcSAndroid Build Coastguard Worker 	tep_set_file_bigendian(test_tep, TEP_BIG_ENDIAN);
397*436bf2bcSAndroid Build Coastguard Worker #endif
398*436bf2bcSAndroid Build Coastguard Worker 	return 0;
399*436bf2bcSAndroid Build Coastguard Worker }
400*436bf2bcSAndroid Build Coastguard Worker 
test_traceevent_lib(void)401*436bf2bcSAndroid Build Coastguard Worker void test_traceevent_lib(void)
402*436bf2bcSAndroid Build Coastguard Worker {
403*436bf2bcSAndroid Build Coastguard Worker 	CU_pSuite suite = NULL;
404*436bf2bcSAndroid Build Coastguard Worker 
405*436bf2bcSAndroid Build Coastguard Worker 	suite = CU_add_suite(TRACEEVENT_SUITE, test_suite_init, test_suite_destroy);
406*436bf2bcSAndroid Build Coastguard Worker 	if (suite == NULL) {
407*436bf2bcSAndroid Build Coastguard Worker 		fprintf(stderr, "Suite \"%s\" cannot be ceated\n", TRACEEVENT_SUITE);
408*436bf2bcSAndroid Build Coastguard Worker 		return;
409*436bf2bcSAndroid Build Coastguard Worker 	}
410*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse dynamic string event",
411*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_dyn_str_event);
412*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse old dynamic string event",
413*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_dyn_str_old_event);
414*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse full cpumask",
415*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_cpumask_full);
416*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse empty cpumask",
417*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_cpumask_empty);
418*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse half-filled cpumask",
419*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_cpumask_half);
420*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse cpumask spanning 2 bytes",
421*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_cpumask_bytep1);
422*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse cpumask spanning 3 bytes",
423*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_cpumask_bytep2);
424*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse cpumask spanning all bytes",
425*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_cpumask_bytepn);
426*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse sizeof() 8byte values",
427*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_sizeof8);
428*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse sizeof() 4byte values",
429*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_sizeof4);
430*436bf2bcSAndroid Build Coastguard Worker 	CU_add_test(suite, "parse sizeof() no long size defined",
431*436bf2bcSAndroid Build Coastguard Worker 		    test_parse_sizeof_undef);
432*436bf2bcSAndroid Build Coastguard Worker }
433