blob: 16622877c45d2b0b2556336c467984cfd3f4cbef [file] [log] [blame]
Damjan Marione3e35552021-05-06 17:34:49 +02001/* SPDX-License-Identifier: Apache-2.0
2 * Copyright(c) 2021 Cisco Systems, Inc.
3 */
4
5#ifndef included_test_test_h
6#define included_test_test_h
7
8#include <vppinfra/cpu.h>
Damjan Marion3323e202021-12-02 11:28:57 +01009#ifdef __linux__
10#include <sys/ioctl.h>
11#include <linux/perf_event.h>
12#endif
Damjan Marione3e35552021-05-06 17:34:49 +020013
14typedef clib_error_t *(test_fn_t) (clib_error_t *);
15
Damjan Marion3323e202021-12-02 11:28:57 +010016struct test_perf_;
17typedef void (test_perf_fn_t) (int fd, struct test_perf_ *tp);
18
19typedef struct test_perf_
20{
21 u64 n_ops;
Damjan Marionde3735f2021-12-06 12:48:46 +010022 union
23 {
24 u64 arg0;
25 void *ptr0;
26 };
27 union
28 {
29 u64 arg1;
30 void *ptr1;
31 };
32 union
33 {
34 u64 arg2;
35 void *ptr2;
36 };
Damjan Marion3323e202021-12-02 11:28:57 +010037 char *op_name;
38 char *name;
39 test_perf_fn_t *fn;
40} test_perf_t;
41
Damjan Marione3e35552021-05-06 17:34:49 +020042typedef struct test_registration_
43{
44 char *name;
45 u8 multiarch : 1;
46 test_fn_t *fn;
Damjan Marion3323e202021-12-02 11:28:57 +010047 test_perf_t *perf_tests;
48 u32 n_perf_tests;
Damjan Marione3e35552021-05-06 17:34:49 +020049 struct test_registration_ *next;
50} test_registration_t;
51
Damjan Marion3323e202021-12-02 11:28:57 +010052typedef struct
53{
54 test_registration_t *registrations[CLIB_MARCH_TYPE_N_VARIANTS];
55 u32 repeat;
Damjan Marion68843d12021-12-06 13:21:33 +010056 u8 *filter;
Damjan Marion3323e202021-12-02 11:28:57 +010057} test_main_t;
58extern test_main_t test_main;
Damjan Marione3e35552021-05-06 17:34:49 +020059
Damjan Marion3323e202021-12-02 11:28:57 +010060#define __test_funct_fn static __clib_noinline __clib_section (".test_func")
61#define __test_perf_fn static __clib_noinline __clib_section (".test_perf")
Damjan Marione3e35552021-05-06 17:34:49 +020062
63#define REGISTER_TEST(x) \
64 test_registration_t CLIB_MARCH_SFX (__test_##x); \
65 static void __clib_constructor CLIB_MARCH_SFX (__test_registration_##x) ( \
66 void) \
67 { \
68 test_registration_t *r = &CLIB_MARCH_SFX (__test_##x); \
Damjan Marion3323e202021-12-02 11:28:57 +010069 r->next = \
70 test_main.registrations[CLIB_MARCH_SFX (CLIB_MARCH_VARIANT_TYPE)]; \
71 test_main.registrations[CLIB_MARCH_SFX (CLIB_MARCH_VARIANT_TYPE)] = r; \
Damjan Marione3e35552021-05-06 17:34:49 +020072 } \
73 test_registration_t CLIB_MARCH_SFX (__test_##x)
74
Damjan Marion3323e202021-12-02 11:28:57 +010075#define PERF_TESTS(...) \
76 (test_perf_t[]) \
77 { \
78 __VA_ARGS__, {} \
79 }
80
81static_always_inline void
82test_perf_event_ioctl (int fd, u32 req)
83{
84#ifdef __x86_64__
85 asm inline("syscall"
86 :
87 : "D"(fd), "S"(req), "a"(__NR_ioctl), "d"(PERF_IOC_FLAG_GROUP)
88 : "rcx", "r11" /* registers modified by kernel */);
89#else
90 ioctl (fd, req, PERF_IOC_FLAG_GROUP);
91#endif
92}
93
94static_always_inline void
95test_perf_event_reset (int fd)
96{
97 test_perf_event_ioctl (fd, PERF_EVENT_IOC_RESET);
98}
99static_always_inline void
100test_perf_event_enable (int fd)
101{
102 test_perf_event_ioctl (fd, PERF_EVENT_IOC_ENABLE);
103}
104static_always_inline void
105test_perf_event_disable (int fd)
106{
107 test_perf_event_ioctl (fd, PERF_EVENT_IOC_DISABLE);
108}
109
110void *test_mem_alloc (uword size);
111void *test_mem_alloc_and_fill_inc_u8 (uword size, u8 start, u8 mask);
112void *test_mem_alloc_and_splat (uword elt_size, uword n_elts, void *elt);
113void test_mem_free (void *p);
114
Damjan Marione3e35552021-05-06 17:34:49 +0200115#endif