blob: 4334dfa53a1f288277dd0d463d6be046f36193bd [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 Marionb97bec02021-12-12 21:43:56 +000057 u8 *bundle;
Damjan Marionf622bf42021-12-14 10:40:48 +010058 f64 ref_clock;
Damjan Marion3323e202021-12-02 11:28:57 +010059} test_main_t;
60extern test_main_t test_main;
Damjan Marione3e35552021-05-06 17:34:49 +020061
Damjan Marion3323e202021-12-02 11:28:57 +010062#define __test_funct_fn static __clib_noinline __clib_section (".test_func")
63#define __test_perf_fn static __clib_noinline __clib_section (".test_perf")
Damjan Marione3e35552021-05-06 17:34:49 +020064
65#define REGISTER_TEST(x) \
66 test_registration_t CLIB_MARCH_SFX (__test_##x); \
67 static void __clib_constructor CLIB_MARCH_SFX (__test_registration_##x) ( \
68 void) \
69 { \
70 test_registration_t *r = &CLIB_MARCH_SFX (__test_##x); \
Damjan Marion3323e202021-12-02 11:28:57 +010071 r->next = \
72 test_main.registrations[CLIB_MARCH_SFX (CLIB_MARCH_VARIANT_TYPE)]; \
73 test_main.registrations[CLIB_MARCH_SFX (CLIB_MARCH_VARIANT_TYPE)] = r; \
Damjan Marione3e35552021-05-06 17:34:49 +020074 } \
75 test_registration_t CLIB_MARCH_SFX (__test_##x)
76
Damjan Marion3323e202021-12-02 11:28:57 +010077#define PERF_TESTS(...) \
78 (test_perf_t[]) \
79 { \
80 __VA_ARGS__, {} \
81 }
82
83static_always_inline void
84test_perf_event_ioctl (int fd, u32 req)
85{
86#ifdef __x86_64__
87 asm inline("syscall"
88 :
89 : "D"(fd), "S"(req), "a"(__NR_ioctl), "d"(PERF_IOC_FLAG_GROUP)
90 : "rcx", "r11" /* registers modified by kernel */);
91#else
92 ioctl (fd, req, PERF_IOC_FLAG_GROUP);
93#endif
94}
95
96static_always_inline void
97test_perf_event_reset (int fd)
98{
99 test_perf_event_ioctl (fd, PERF_EVENT_IOC_RESET);
100}
101static_always_inline void
102test_perf_event_enable (int fd)
103{
104 test_perf_event_ioctl (fd, PERF_EVENT_IOC_ENABLE);
105}
106static_always_inline void
107test_perf_event_disable (int fd)
108{
109 test_perf_event_ioctl (fd, PERF_EVENT_IOC_DISABLE);
110}
111
112void *test_mem_alloc (uword size);
113void *test_mem_alloc_and_fill_inc_u8 (uword size, u8 start, u8 mask);
114void *test_mem_alloc_and_splat (uword elt_size, uword n_elts, void *elt);
115void test_mem_free (void *p);
116
Damjan Marione3e35552021-05-06 17:34:49 +0200117#endif