FD.io VPP  v21.10.1-2-g0a485f517
Vector Packet Processing
perfmon_intel.h
Go to the documentation of this file.
1 /*
2  *------------------------------------------------------------------
3  * Copyright (c) 2019 Cisco and/or its affiliates.
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at:
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *------------------------------------------------------------------
16  */
17 
18 #ifndef _PERFMON_INTEL_H_
19 #define _PERFMON_INTEL_H_
20 
21 #include <vppinfra/clib.h>
22 #include <vppinfra/format.h>
23 
24 typedef struct
25 {
26  u8 event_code[2];
32  char *event_name;
34 
35 typedef struct
36 {
41 
42 typedef struct
43 {
49 
50 
51 void
53  perfmon_intel_pmc_event_t * e, int n_events);
54 
55 #define PERFMON_REGISTER_INTEL_PMC(m, e) \
56 static void __clib_constructor \
57 perfmon_register_intel_pmc_constructor() \
58 { \
59  perfmon_register_intel_pmc (m, ARRAY_LEN(m), e, ARRAY_LEN (e)); \
60 }
61 
62 #endif /* _PERFMON_INTEL_H_ */
63 
64 /*
65  * fd.io coding-style-patch-verification: ON
66  *
67  * Local Variables:
68  * eval: (c-set-style "gnu")
69  * End:
70  */
perfmon_intel_pmc_registration_t::n_events
u32 n_events
Definition: perfmon_intel.h:46
clib.h
perfmon_intel_pmc_event_t::anyt
u8 anyt
Definition: perfmon_intel.h:30
perfmon_intel_pmc_event_t::edge
u8 edge
Definition: perfmon_intel.h:31
perfmon_intel_pmc_cpu_model_t::stepping
u8 stepping
Definition: perfmon_intel.h:38
perfmon_register_intel_pmc
void perfmon_register_intel_pmc(perfmon_intel_pmc_cpu_model_t *m, int n_models, perfmon_intel_pmc_event_t *e, int n_events)
Definition: perfmon.c:30
perfmon_intel_pmc_cpu_model_t::has_stepping
u8 has_stepping
Definition: perfmon_intel.h:39
perfmon_intel_pmc_registration_t::models
perfmon_intel_pmc_cpu_model_t * models
Definition: perfmon_intel.h:45
perfmon_intel_pmc_event_t
Definition: perfmon_intel.h:24
format.h
perfmon_intel_pmc_event_t::inv
u8 inv
Definition: perfmon_intel.h:29
perfmon_intel_pmc_registration_t::n_models
u32 n_models
Definition: perfmon_intel.h:47
perfmon_intel_pmc_event_t::cmask
u8 cmask
Definition: perfmon_intel.h:28
u32
unsigned int u32
Definition: types.h:88
perfmon_intel_pmc_registration_t
Definition: perfmon_intel.h:42
perfmon_intel_pmc_event_t::umask
u8 umask
Definition: perfmon_intel.h:27
perfmon_intel_pmc_cpu_model_t
Definition: perfmon_intel.h:35
perfmon_intel_pmc_event_t::event_name
char * event_name
Definition: perfmon_intel.h:32
u8
unsigned char u8
Definition: types.h:56
perfmon_intel_pmc_cpu_model_t::model
u8 model
Definition: perfmon_intel.h:37
perfmon_intel_pmc_registration_t::events
perfmon_intel_pmc_event_t * events
Definition: perfmon_intel.h:44