xref: /freebsd/contrib/processor-trace/libipt/test/src/ptunit-block_decoder.c (revision 85f87cf491bec6f90948a85b10f5523ea24db9e3)
1*85f87cf4SRuslan Bukin /*
2*85f87cf4SRuslan Bukin  * Copyright (c) 2019, Intel Corporation
3*85f87cf4SRuslan Bukin  *
4*85f87cf4SRuslan Bukin  * Redistribution and use in source and binary forms, with or without
5*85f87cf4SRuslan Bukin  * modification, are permitted provided that the following conditions are met:
6*85f87cf4SRuslan Bukin  *
7*85f87cf4SRuslan Bukin  *  * Redistributions of source code must retain the above copyright notice,
8*85f87cf4SRuslan Bukin  *    this list of conditions and the following disclaimer.
9*85f87cf4SRuslan Bukin  *  * Redistributions in binary form must reproduce the above copyright notice,
10*85f87cf4SRuslan Bukin  *    this list of conditions and the following disclaimer in the documentation
11*85f87cf4SRuslan Bukin  *    and/or other materials provided with the distribution.
12*85f87cf4SRuslan Bukin  *  * Neither the name of Intel Corporation nor the names of its contributors
13*85f87cf4SRuslan Bukin  *    may be used to endorse or promote products derived from this software
14*85f87cf4SRuslan Bukin  *    without specific prior written permission.
15*85f87cf4SRuslan Bukin  *
16*85f87cf4SRuslan Bukin  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17*85f87cf4SRuslan Bukin  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*85f87cf4SRuslan Bukin  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*85f87cf4SRuslan Bukin  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
20*85f87cf4SRuslan Bukin  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21*85f87cf4SRuslan Bukin  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22*85f87cf4SRuslan Bukin  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23*85f87cf4SRuslan Bukin  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24*85f87cf4SRuslan Bukin  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25*85f87cf4SRuslan Bukin  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26*85f87cf4SRuslan Bukin  * POSSIBILITY OF SUCH DAMAGE.
27*85f87cf4SRuslan Bukin  */
28*85f87cf4SRuslan Bukin 
29*85f87cf4SRuslan Bukin #include "ptunit.h"
30*85f87cf4SRuslan Bukin 
31*85f87cf4SRuslan Bukin #include "pt_block_decoder.h"
32*85f87cf4SRuslan Bukin 
33*85f87cf4SRuslan Bukin #include "intel-pt.h"
34*85f87cf4SRuslan Bukin 
35*85f87cf4SRuslan Bukin 
36*85f87cf4SRuslan Bukin /* A test fixture providing a decoder operating on a small buffer. */
37*85f87cf4SRuslan Bukin struct test_fixture {
38*85f87cf4SRuslan Bukin 	/* The packet_decoder. */
39*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
40*85f87cf4SRuslan Bukin 
41*85f87cf4SRuslan Bukin 	/* The configuration. */
42*85f87cf4SRuslan Bukin 	struct pt_config config;
43*85f87cf4SRuslan Bukin 
44*85f87cf4SRuslan Bukin 	/* The buffer it operates on. */
45*85f87cf4SRuslan Bukin 	uint8_t buffer[24];
46*85f87cf4SRuslan Bukin 
47*85f87cf4SRuslan Bukin 	/* The test fixture initialization and finalization functions. */
48*85f87cf4SRuslan Bukin 	struct ptunit_result (*init)(struct test_fixture *tfix);
49*85f87cf4SRuslan Bukin 	struct ptunit_result (*fini)(struct test_fixture *tfix);
50*85f87cf4SRuslan Bukin };
51*85f87cf4SRuslan Bukin 
tfix_init(struct test_fixture * tfix)52*85f87cf4SRuslan Bukin static struct ptunit_result tfix_init(struct test_fixture *tfix)
53*85f87cf4SRuslan Bukin {
54*85f87cf4SRuslan Bukin 	struct pt_config *config;
55*85f87cf4SRuslan Bukin 	uint8_t *buffer;
56*85f87cf4SRuslan Bukin 	int errcode;
57*85f87cf4SRuslan Bukin 
58*85f87cf4SRuslan Bukin 	config = &tfix->config;
59*85f87cf4SRuslan Bukin 	buffer = tfix->buffer;
60*85f87cf4SRuslan Bukin 
61*85f87cf4SRuslan Bukin 	memset(buffer, 0, sizeof(tfix->buffer));
62*85f87cf4SRuslan Bukin 
63*85f87cf4SRuslan Bukin 	pt_config_init(config);
64*85f87cf4SRuslan Bukin 	config->begin = buffer;
65*85f87cf4SRuslan Bukin 	config->end = buffer + sizeof(tfix->buffer);
66*85f87cf4SRuslan Bukin 
67*85f87cf4SRuslan Bukin 	errcode = pt_blk_decoder_init(&tfix->decoder, config);
68*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, 0);
69*85f87cf4SRuslan Bukin 
70*85f87cf4SRuslan Bukin 	return ptu_passed();
71*85f87cf4SRuslan Bukin }
72*85f87cf4SRuslan Bukin 
decoder_init_null(void)73*85f87cf4SRuslan Bukin static struct ptunit_result decoder_init_null(void)
74*85f87cf4SRuslan Bukin {
75*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
76*85f87cf4SRuslan Bukin 	struct pt_config config;
77*85f87cf4SRuslan Bukin 	int errcode;
78*85f87cf4SRuslan Bukin 
79*85f87cf4SRuslan Bukin 	errcode = pt_blk_decoder_init(NULL, &config);
80*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_internal);
81*85f87cf4SRuslan Bukin 
82*85f87cf4SRuslan Bukin 	errcode = pt_blk_decoder_init(&decoder, NULL);
83*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
84*85f87cf4SRuslan Bukin 
85*85f87cf4SRuslan Bukin 	return ptu_passed();
86*85f87cf4SRuslan Bukin }
87*85f87cf4SRuslan Bukin 
decoder_fini_null(void)88*85f87cf4SRuslan Bukin static struct ptunit_result decoder_fini_null(void)
89*85f87cf4SRuslan Bukin {
90*85f87cf4SRuslan Bukin 	pt_blk_decoder_fini(NULL);
91*85f87cf4SRuslan Bukin 
92*85f87cf4SRuslan Bukin 	return ptu_passed();
93*85f87cf4SRuslan Bukin }
94*85f87cf4SRuslan Bukin 
alloc_decoder_null(void)95*85f87cf4SRuslan Bukin static struct ptunit_result alloc_decoder_null(void)
96*85f87cf4SRuslan Bukin {
97*85f87cf4SRuslan Bukin 	struct pt_block_decoder *decoder;
98*85f87cf4SRuslan Bukin 
99*85f87cf4SRuslan Bukin 	decoder = pt_blk_alloc_decoder(NULL);
100*85f87cf4SRuslan Bukin 	ptu_null(decoder);
101*85f87cf4SRuslan Bukin 
102*85f87cf4SRuslan Bukin 	return ptu_passed();
103*85f87cf4SRuslan Bukin }
104*85f87cf4SRuslan Bukin 
free_decoder_null(void)105*85f87cf4SRuslan Bukin static struct ptunit_result free_decoder_null(void)
106*85f87cf4SRuslan Bukin {
107*85f87cf4SRuslan Bukin 	pt_blk_free_decoder(NULL);
108*85f87cf4SRuslan Bukin 
109*85f87cf4SRuslan Bukin 	return ptu_passed();
110*85f87cf4SRuslan Bukin }
111*85f87cf4SRuslan Bukin 
sync_forward_null(void)112*85f87cf4SRuslan Bukin static struct ptunit_result sync_forward_null(void)
113*85f87cf4SRuslan Bukin {
114*85f87cf4SRuslan Bukin 	int errcode;
115*85f87cf4SRuslan Bukin 
116*85f87cf4SRuslan Bukin 	errcode = pt_blk_sync_forward(NULL);
117*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
118*85f87cf4SRuslan Bukin 
119*85f87cf4SRuslan Bukin 	return ptu_passed();
120*85f87cf4SRuslan Bukin }
121*85f87cf4SRuslan Bukin 
sync_backward_null(void)122*85f87cf4SRuslan Bukin static struct ptunit_result sync_backward_null(void)
123*85f87cf4SRuslan Bukin {
124*85f87cf4SRuslan Bukin 	int errcode;
125*85f87cf4SRuslan Bukin 
126*85f87cf4SRuslan Bukin 	errcode = pt_blk_sync_backward(NULL);
127*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
128*85f87cf4SRuslan Bukin 
129*85f87cf4SRuslan Bukin 	return ptu_passed();
130*85f87cf4SRuslan Bukin }
131*85f87cf4SRuslan Bukin 
sync_set_null(void)132*85f87cf4SRuslan Bukin static struct ptunit_result sync_set_null(void)
133*85f87cf4SRuslan Bukin {
134*85f87cf4SRuslan Bukin 	int errcode;
135*85f87cf4SRuslan Bukin 
136*85f87cf4SRuslan Bukin 	errcode = pt_blk_sync_set(NULL, 0ull);
137*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
138*85f87cf4SRuslan Bukin 
139*85f87cf4SRuslan Bukin 	return ptu_passed();
140*85f87cf4SRuslan Bukin }
141*85f87cf4SRuslan Bukin 
sync_set_eos(struct test_fixture * tfix)142*85f87cf4SRuslan Bukin static struct ptunit_result sync_set_eos(struct test_fixture *tfix)
143*85f87cf4SRuslan Bukin {
144*85f87cf4SRuslan Bukin 	int errcode;
145*85f87cf4SRuslan Bukin 
146*85f87cf4SRuslan Bukin 	errcode = pt_blk_sync_set(&tfix->decoder, sizeof(tfix->buffer) + 1);
147*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_eos);
148*85f87cf4SRuslan Bukin 
149*85f87cf4SRuslan Bukin 	return ptu_passed();
150*85f87cf4SRuslan Bukin }
151*85f87cf4SRuslan Bukin 
get_offset_null(void)152*85f87cf4SRuslan Bukin static struct ptunit_result get_offset_null(void)
153*85f87cf4SRuslan Bukin {
154*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
155*85f87cf4SRuslan Bukin 	uint64_t offset;
156*85f87cf4SRuslan Bukin 	int errcode;
157*85f87cf4SRuslan Bukin 
158*85f87cf4SRuslan Bukin 	errcode = pt_blk_get_offset(NULL, &offset);
159*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
160*85f87cf4SRuslan Bukin 
161*85f87cf4SRuslan Bukin 	errcode = pt_blk_get_offset(&decoder, NULL);
162*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
163*85f87cf4SRuslan Bukin 
164*85f87cf4SRuslan Bukin 	return ptu_passed();
165*85f87cf4SRuslan Bukin }
166*85f87cf4SRuslan Bukin 
get_offset_init(struct test_fixture * tfix)167*85f87cf4SRuslan Bukin static struct ptunit_result get_offset_init(struct test_fixture *tfix)
168*85f87cf4SRuslan Bukin {
169*85f87cf4SRuslan Bukin 	uint64_t offset;
170*85f87cf4SRuslan Bukin 	int errcode;
171*85f87cf4SRuslan Bukin 
172*85f87cf4SRuslan Bukin 	errcode = pt_blk_get_offset(&tfix->decoder, &offset);
173*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_nosync);
174*85f87cf4SRuslan Bukin 
175*85f87cf4SRuslan Bukin 	return ptu_passed();
176*85f87cf4SRuslan Bukin }
177*85f87cf4SRuslan Bukin 
get_sync_offset_null(void)178*85f87cf4SRuslan Bukin static struct ptunit_result get_sync_offset_null(void)
179*85f87cf4SRuslan Bukin {
180*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
181*85f87cf4SRuslan Bukin 	uint64_t offset;
182*85f87cf4SRuslan Bukin 	int errcode;
183*85f87cf4SRuslan Bukin 
184*85f87cf4SRuslan Bukin 	errcode = pt_blk_get_sync_offset(NULL, &offset);
185*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
186*85f87cf4SRuslan Bukin 
187*85f87cf4SRuslan Bukin 	errcode = pt_blk_get_sync_offset(&decoder, NULL);
188*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
189*85f87cf4SRuslan Bukin 
190*85f87cf4SRuslan Bukin 	return ptu_passed();
191*85f87cf4SRuslan Bukin }
192*85f87cf4SRuslan Bukin 
get_image_null(void)193*85f87cf4SRuslan Bukin static struct ptunit_result get_image_null(void)
194*85f87cf4SRuslan Bukin {
195*85f87cf4SRuslan Bukin 	const struct pt_image *image;
196*85f87cf4SRuslan Bukin 
197*85f87cf4SRuslan Bukin 	image = pt_blk_get_image(NULL);
198*85f87cf4SRuslan Bukin 	ptu_null(image);
199*85f87cf4SRuslan Bukin 
200*85f87cf4SRuslan Bukin 	return ptu_passed();
201*85f87cf4SRuslan Bukin }
202*85f87cf4SRuslan Bukin 
set_image_null(void)203*85f87cf4SRuslan Bukin static struct ptunit_result set_image_null(void)
204*85f87cf4SRuslan Bukin {
205*85f87cf4SRuslan Bukin 	struct pt_image image;
206*85f87cf4SRuslan Bukin 	int errcode;
207*85f87cf4SRuslan Bukin 
208*85f87cf4SRuslan Bukin 	errcode = pt_blk_set_image(NULL, &image);
209*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
210*85f87cf4SRuslan Bukin 
211*85f87cf4SRuslan Bukin 	errcode = pt_blk_set_image(NULL, NULL);
212*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
213*85f87cf4SRuslan Bukin 
214*85f87cf4SRuslan Bukin 	return ptu_passed();
215*85f87cf4SRuslan Bukin }
216*85f87cf4SRuslan Bukin 
get_config_null(void)217*85f87cf4SRuslan Bukin static struct ptunit_result get_config_null(void)
218*85f87cf4SRuslan Bukin {
219*85f87cf4SRuslan Bukin 	const struct pt_config *config;
220*85f87cf4SRuslan Bukin 
221*85f87cf4SRuslan Bukin 	config = pt_blk_get_config(NULL);
222*85f87cf4SRuslan Bukin 	ptu_null(config);
223*85f87cf4SRuslan Bukin 
224*85f87cf4SRuslan Bukin 	return ptu_passed();
225*85f87cf4SRuslan Bukin }
226*85f87cf4SRuslan Bukin 
get_config(struct test_fixture * tfix)227*85f87cf4SRuslan Bukin static struct ptunit_result get_config(struct test_fixture *tfix)
228*85f87cf4SRuslan Bukin {
229*85f87cf4SRuslan Bukin 	const struct pt_config *config;
230*85f87cf4SRuslan Bukin 
231*85f87cf4SRuslan Bukin 	config = pt_blk_get_config(&tfix->decoder);
232*85f87cf4SRuslan Bukin 	ptu_ptr(config);
233*85f87cf4SRuslan Bukin 
234*85f87cf4SRuslan Bukin 	return ptu_passed();
235*85f87cf4SRuslan Bukin }
236*85f87cf4SRuslan Bukin 
time_null(void)237*85f87cf4SRuslan Bukin static struct ptunit_result time_null(void)
238*85f87cf4SRuslan Bukin {
239*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
240*85f87cf4SRuslan Bukin 	uint64_t time;
241*85f87cf4SRuslan Bukin 	uint32_t lost_mtc, lost_cyc;
242*85f87cf4SRuslan Bukin 	int errcode;
243*85f87cf4SRuslan Bukin 
244*85f87cf4SRuslan Bukin 	errcode = pt_blk_time(NULL, &time, &lost_mtc, &lost_cyc);
245*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
246*85f87cf4SRuslan Bukin 
247*85f87cf4SRuslan Bukin 	errcode = pt_blk_time(&decoder, NULL, &lost_mtc, &lost_cyc);
248*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
249*85f87cf4SRuslan Bukin 
250*85f87cf4SRuslan Bukin 	return ptu_passed();
251*85f87cf4SRuslan Bukin }
252*85f87cf4SRuslan Bukin 
cbr_null(void)253*85f87cf4SRuslan Bukin static struct ptunit_result cbr_null(void)
254*85f87cf4SRuslan Bukin {
255*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
256*85f87cf4SRuslan Bukin 	uint32_t cbr;
257*85f87cf4SRuslan Bukin 	int errcode;
258*85f87cf4SRuslan Bukin 
259*85f87cf4SRuslan Bukin 	errcode = pt_blk_core_bus_ratio(NULL, &cbr);
260*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
261*85f87cf4SRuslan Bukin 
262*85f87cf4SRuslan Bukin 	errcode = pt_blk_core_bus_ratio(&decoder, NULL);
263*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
264*85f87cf4SRuslan Bukin 
265*85f87cf4SRuslan Bukin 	return ptu_passed();
266*85f87cf4SRuslan Bukin }
267*85f87cf4SRuslan Bukin 
asid_null(void)268*85f87cf4SRuslan Bukin static struct ptunit_result asid_null(void)
269*85f87cf4SRuslan Bukin {
270*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
271*85f87cf4SRuslan Bukin 	struct pt_asid asid;
272*85f87cf4SRuslan Bukin 	int errcode;
273*85f87cf4SRuslan Bukin 
274*85f87cf4SRuslan Bukin 	errcode = pt_blk_asid(NULL, &asid, sizeof(asid));
275*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
276*85f87cf4SRuslan Bukin 
277*85f87cf4SRuslan Bukin 	errcode = pt_blk_asid(&decoder, NULL, sizeof(asid));
278*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
279*85f87cf4SRuslan Bukin 
280*85f87cf4SRuslan Bukin 	return ptu_passed();
281*85f87cf4SRuslan Bukin }
282*85f87cf4SRuslan Bukin 
next_null(void)283*85f87cf4SRuslan Bukin static struct ptunit_result next_null(void)
284*85f87cf4SRuslan Bukin {
285*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
286*85f87cf4SRuslan Bukin 	struct pt_block block;
287*85f87cf4SRuslan Bukin 	int errcode;
288*85f87cf4SRuslan Bukin 
289*85f87cf4SRuslan Bukin 	errcode = pt_blk_next(NULL, &block, sizeof(block));
290*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
291*85f87cf4SRuslan Bukin 
292*85f87cf4SRuslan Bukin 	errcode = pt_blk_next(&decoder, NULL, sizeof(block));
293*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
294*85f87cf4SRuslan Bukin 
295*85f87cf4SRuslan Bukin 	return ptu_passed();
296*85f87cf4SRuslan Bukin }
297*85f87cf4SRuslan Bukin 
event_null(void)298*85f87cf4SRuslan Bukin static struct ptunit_result event_null(void)
299*85f87cf4SRuslan Bukin {
300*85f87cf4SRuslan Bukin 	struct pt_block_decoder decoder;
301*85f87cf4SRuslan Bukin 	struct pt_event event;
302*85f87cf4SRuslan Bukin 	int errcode;
303*85f87cf4SRuslan Bukin 
304*85f87cf4SRuslan Bukin 	errcode = pt_blk_event(NULL, &event, sizeof(event));
305*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
306*85f87cf4SRuslan Bukin 
307*85f87cf4SRuslan Bukin 	errcode = pt_blk_event(&decoder, NULL, sizeof(event));
308*85f87cf4SRuslan Bukin 	ptu_int_eq(errcode, -pte_invalid);
309*85f87cf4SRuslan Bukin 
310*85f87cf4SRuslan Bukin 	return ptu_passed();
311*85f87cf4SRuslan Bukin }
312*85f87cf4SRuslan Bukin 
main(int argc,char ** argv)313*85f87cf4SRuslan Bukin int main(int argc, char **argv)
314*85f87cf4SRuslan Bukin {
315*85f87cf4SRuslan Bukin 	struct test_fixture tfix;
316*85f87cf4SRuslan Bukin 	struct ptunit_suite suite;
317*85f87cf4SRuslan Bukin 
318*85f87cf4SRuslan Bukin 	tfix.init = tfix_init;
319*85f87cf4SRuslan Bukin 	tfix.fini = NULL;
320*85f87cf4SRuslan Bukin 
321*85f87cf4SRuslan Bukin 	suite = ptunit_mk_suite(argc, argv);
322*85f87cf4SRuslan Bukin 
323*85f87cf4SRuslan Bukin 	ptu_run(suite, decoder_init_null);
324*85f87cf4SRuslan Bukin 	ptu_run(suite, decoder_fini_null);
325*85f87cf4SRuslan Bukin 	ptu_run(suite, alloc_decoder_null);
326*85f87cf4SRuslan Bukin 	ptu_run(suite, free_decoder_null);
327*85f87cf4SRuslan Bukin 
328*85f87cf4SRuslan Bukin 	ptu_run(suite, sync_forward_null);
329*85f87cf4SRuslan Bukin 	ptu_run(suite, sync_backward_null);
330*85f87cf4SRuslan Bukin 	ptu_run(suite, sync_set_null);
331*85f87cf4SRuslan Bukin 	ptu_run_f(suite, sync_set_eos, tfix);
332*85f87cf4SRuslan Bukin 
333*85f87cf4SRuslan Bukin 	ptu_run(suite, get_offset_null);
334*85f87cf4SRuslan Bukin 	ptu_run_f(suite, get_offset_init, tfix);
335*85f87cf4SRuslan Bukin 	ptu_run(suite, get_sync_offset_null);
336*85f87cf4SRuslan Bukin 
337*85f87cf4SRuslan Bukin 	ptu_run(suite, get_image_null);
338*85f87cf4SRuslan Bukin 	ptu_run(suite, set_image_null);
339*85f87cf4SRuslan Bukin 
340*85f87cf4SRuslan Bukin 	ptu_run(suite, get_config_null);
341*85f87cf4SRuslan Bukin 	ptu_run_f(suite, get_config, tfix);
342*85f87cf4SRuslan Bukin 
343*85f87cf4SRuslan Bukin 	ptu_run(suite, time_null);
344*85f87cf4SRuslan Bukin 	ptu_run(suite, cbr_null);
345*85f87cf4SRuslan Bukin 	ptu_run(suite, asid_null);
346*85f87cf4SRuslan Bukin 
347*85f87cf4SRuslan Bukin 	ptu_run(suite, next_null);
348*85f87cf4SRuslan Bukin 	ptu_run(suite, event_null);
349*85f87cf4SRuslan Bukin 
350*85f87cf4SRuslan Bukin 	return ptunit_report(&suite);
351*85f87cf4SRuslan Bukin }
352