diff options
author | Damjan Marion <damarion@cisco.com> | 2022-04-06 21:16:37 +0200 |
---|---|---|
committer | Florin Coras <florin.coras@gmail.com> | 2022-04-08 15:53:10 +0000 |
commit | d5045e68a782d484e3f0e54edb4a88dc3dfac291 (patch) | |
tree | f0cf5627b672050e4463d1dee4ea952a066c12d6 /src/vppinfra/vector/test/test.h | |
parent | dfc43164078b481e39dc0a87e8e358cc6a56d14e (diff) |
vppinfra: introduce clib_perfmom
Type: improvement
Change-Id: I85a90774eb313020435c9bc2297c1bdf23d52efc
Signed-off-by: Damjan Marion <damarion@cisco.com>
Diffstat (limited to 'src/vppinfra/vector/test/test.h')
-rw-r--r-- | src/vppinfra/vector/test/test.h | 30 |
1 files changed, 9 insertions, 21 deletions
diff --git a/src/vppinfra/vector/test/test.h b/src/vppinfra/vector/test/test.h index 4511bf31fa9..7d54d80c6ec 100644 --- a/src/vppinfra/vector/test/test.h +++ b/src/vppinfra/vector/test/test.h @@ -6,6 +6,7 @@ #define included_test_test_h #include <vppinfra/cpu.h> +#include <vppinfra/perfmon/perfmon.h> #ifdef __linux__ #include <sys/ioctl.h> #include <linux/perf_event.h> @@ -14,10 +15,11 @@ typedef clib_error_t *(test_fn_t) (clib_error_t *); struct test_perf_; -typedef void (test_perf_fn_t) (int fd, struct test_perf_ *tp); +typedef void (test_perf_fn_t) (struct test_perf_ *tp); typedef struct test_perf_ { + int fd; u64 n_ops; union { @@ -34,7 +36,6 @@ typedef struct test_perf_ u64 arg2; void *ptr2; }; - char *op_name; char *name; test_perf_fn_t *fn; } test_perf_t; @@ -83,32 +84,19 @@ extern test_main_t test_main; } static_always_inline void -test_perf_event_ioctl (int fd, u32 req) +test_perf_event_reset (test_perf_t *t) { -#ifdef __x86_64__ - asm inline("syscall" - : - : "D"(fd), "S"(req), "a"(__NR_ioctl), "d"(PERF_IOC_FLAG_GROUP) - : "rcx", "r11" /* registers modified by kernel */); -#else - ioctl (fd, req, PERF_IOC_FLAG_GROUP); -#endif -} - -static_always_inline void -test_perf_event_reset (int fd) -{ - test_perf_event_ioctl (fd, PERF_EVENT_IOC_RESET); + clib_perfmon_ioctl (t->fd, PERF_EVENT_IOC_RESET); } static_always_inline void -test_perf_event_enable (int fd) +test_perf_event_enable (test_perf_t *t) { - test_perf_event_ioctl (fd, PERF_EVENT_IOC_ENABLE); + clib_perfmon_ioctl (t->fd, PERF_EVENT_IOC_ENABLE); } static_always_inline void -test_perf_event_disable (int fd) +test_perf_event_disable (test_perf_t *t) { - test_perf_event_ioctl (fd, PERF_EVENT_IOC_DISABLE); + clib_perfmon_ioctl (t->fd, PERF_EVENT_IOC_DISABLE); } void *test_mem_alloc (uword size); |