Loading...
Note: File does not exist in v3.5.6.
1/* SPDX-License-Identifier: GPL-2.0-only */
2/* Copyright (c) 2023 Intel Corporation. */
3#ifndef ADF_GEN4_TL_H
4#define ADF_GEN4_TL_H
5
6#include <linux/stddef.h>
7#include <linux/types.h>
8
9struct adf_tl_hw_data;
10
11/* Computation constants. */
12#define ADF_GEN4_CPP_NS_PER_CYCLE 2
13#define ADF_GEN4_TL_BW_HW_UNITS_TO_BYTES 64
14
15/* Maximum aggregation time. Value in milliseconds. */
16#define ADF_GEN4_TL_MAX_AGGR_TIME_MS 4000
17/* Num of buffers to store historic values. */
18#define ADF_GEN4_TL_NUM_HIST_BUFFS \
19 (ADF_GEN4_TL_MAX_AGGR_TIME_MS / ADF_TL_DATA_WR_INTERVAL_MS)
20
21/* Max number of HW resources of one type. */
22#define ADF_GEN4_TL_MAX_SLICES_PER_TYPE 24
23
24/* Max number of simultaneously monitored ring pairs. */
25#define ADF_GEN4_TL_MAX_RP_NUM 4
26
27/**
28 * struct adf_gen4_tl_slice_data_regs - HW slice data as populated by FW.
29 * @reg_tm_slice_exec_cnt: Slice execution count.
30 * @reg_tm_slice_util: Slice utilization.
31 */
32struct adf_gen4_tl_slice_data_regs {
33 __u32 reg_tm_slice_exec_cnt;
34 __u32 reg_tm_slice_util;
35};
36
37#define ADF_GEN4_TL_SLICE_REG_SZ sizeof(struct adf_gen4_tl_slice_data_regs)
38
39/**
40 * struct adf_gen4_tl_device_data_regs - This structure stores device telemetry
41 * counter values as are being populated periodically by device.
42 * @reg_tl_rd_lat_acc: read latency accumulator
43 * @reg_tl_gp_lat_acc: get-put latency accumulator
44 * @reg_tl_at_page_req_lat_acc: AT/DevTLB page request latency accumulator
45 * @reg_tl_at_trans_lat_acc: DevTLB transaction latency accumulator
46 * @reg_tl_re_acc: accumulated ring empty time
47 * @reg_tl_pci_trans_cnt: PCIe partial transactions
48 * @reg_tl_rd_lat_max: maximum logged read latency
49 * @reg_tl_rd_cmpl_cnt: read requests completed count
50 * @reg_tl_gp_lat_max: maximum logged get to put latency
51 * @reg_tl_ae_put_cnt: Accelerator Engine put counts across all rings
52 * @reg_tl_bw_in: PCIe write bandwidth
53 * @reg_tl_bw_out: PCIe read bandwidth
54 * @reg_tl_at_page_req_cnt: DevTLB page requests count
55 * @reg_tl_at_trans_lat_cnt: DevTLB transaction latency samples count
56 * @reg_tl_at_max_tlb_used: maximum uTLB used
57 * @reg_tl_re_cnt: ring empty time samples count
58 * @reserved: reserved
59 * @ath_slices: array of Authentication slices utilization registers
60 * @cph_slices: array of Cipher slices utilization registers
61 * @cpr_slices: array of Compression slices utilization registers
62 * @xlt_slices: array of Translator slices utilization registers
63 * @dcpr_slices: array of Decompression slices utilization registers
64 * @pke_slices: array of PKE slices utilization registers
65 * @ucs_slices: array of UCS slices utilization registers
66 * @wat_slices: array of Wireless Authentication slices utilization registers
67 * @wcp_slices: array of Wireless Cipher slices utilization registers
68 */
69struct adf_gen4_tl_device_data_regs {
70 __u64 reg_tl_rd_lat_acc;
71 __u64 reg_tl_gp_lat_acc;
72 __u64 reg_tl_at_page_req_lat_acc;
73 __u64 reg_tl_at_trans_lat_acc;
74 __u64 reg_tl_re_acc;
75 __u32 reg_tl_pci_trans_cnt;
76 __u32 reg_tl_rd_lat_max;
77 __u32 reg_tl_rd_cmpl_cnt;
78 __u32 reg_tl_gp_lat_max;
79 __u32 reg_tl_ae_put_cnt;
80 __u32 reg_tl_bw_in;
81 __u32 reg_tl_bw_out;
82 __u32 reg_tl_at_page_req_cnt;
83 __u32 reg_tl_at_trans_lat_cnt;
84 __u32 reg_tl_at_max_tlb_used;
85 __u32 reg_tl_re_cnt;
86 __u32 reserved;
87 struct adf_gen4_tl_slice_data_regs ath_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
88 struct adf_gen4_tl_slice_data_regs cph_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
89 struct adf_gen4_tl_slice_data_regs cpr_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
90 struct adf_gen4_tl_slice_data_regs xlt_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
91 struct adf_gen4_tl_slice_data_regs dcpr_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
92 struct adf_gen4_tl_slice_data_regs pke_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
93 struct adf_gen4_tl_slice_data_regs ucs_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
94 struct adf_gen4_tl_slice_data_regs wat_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
95 struct adf_gen4_tl_slice_data_regs wcp_slices[ADF_GEN4_TL_MAX_SLICES_PER_TYPE];
96};
97
98/**
99 * struct adf_gen4_tl_ring_pair_data_regs - This structure stores Ring Pair
100 * telemetry counter values as are being populated periodically by device.
101 * @reg_tl_gp_lat_acc: get-put latency accumulator
102 * @reserved: reserved
103 * @reg_tl_pci_trans_cnt: PCIe partial transactions
104 * @reg_tl_ae_put_cnt: Accelerator Engine put counts across all rings
105 * @reg_tl_bw_in: PCIe write bandwidth
106 * @reg_tl_bw_out: PCIe read bandwidth
107 * @reg_tl_at_glob_devtlb_hit: Message descriptor DevTLB hit rate
108 * @reg_tl_at_glob_devtlb_miss: Message descriptor DevTLB miss rate
109 * @reg_tl_at_payld_devtlb_hit: Payload DevTLB hit rate
110 * @reg_tl_at_payld_devtlb_miss: Payload DevTLB miss rate
111 * @reg_tl_re_cnt: ring empty time samples count
112 * @reserved1: reserved
113 */
114struct adf_gen4_tl_ring_pair_data_regs {
115 __u64 reg_tl_gp_lat_acc;
116 __u64 reserved;
117 __u32 reg_tl_pci_trans_cnt;
118 __u32 reg_tl_ae_put_cnt;
119 __u32 reg_tl_bw_in;
120 __u32 reg_tl_bw_out;
121 __u32 reg_tl_at_glob_devtlb_hit;
122 __u32 reg_tl_at_glob_devtlb_miss;
123 __u32 reg_tl_at_payld_devtlb_hit;
124 __u32 reg_tl_at_payld_devtlb_miss;
125 __u32 reg_tl_re_cnt;
126 __u32 reserved1;
127};
128
129#define ADF_GEN4_TL_RP_REG_SZ sizeof(struct adf_gen4_tl_ring_pair_data_regs)
130
131/**
132 * struct adf_gen4_tl_layout - This structure represents entire telemetry
133 * counters data: Device + 4 Ring Pairs as are being populated periodically
134 * by device.
135 * @tl_device_data_regs: structure of device telemetry registers
136 * @tl_ring_pairs_data_regs: array of ring pairs telemetry registers
137 * @reg_tl_msg_cnt: telemetry messages counter
138 * @reserved: reserved
139 */
140struct adf_gen4_tl_layout {
141 struct adf_gen4_tl_device_data_regs tl_device_data_regs;
142 struct adf_gen4_tl_ring_pair_data_regs
143 tl_ring_pairs_data_regs[ADF_GEN4_TL_MAX_RP_NUM];
144 __u32 reg_tl_msg_cnt;
145 __u32 reserved;
146};
147
148#define ADF_GEN4_TL_LAYOUT_SZ sizeof(struct adf_gen4_tl_layout)
149#define ADF_GEN4_TL_MSG_CNT_OFF offsetof(struct adf_gen4_tl_layout, reg_tl_msg_cnt)
150
151#ifdef CONFIG_DEBUG_FS
152void adf_gen4_init_tl_data(struct adf_tl_hw_data *tl_data);
153#else
154static inline void adf_gen4_init_tl_data(struct adf_tl_hw_data *tl_data)
155{
156}
157#endif /* CONFIG_DEBUG_FS */
158#endif /* ADF_GEN4_TL_H */