Linux-libre 5.3.12-gnu
[librecmc/linux-libre.git] / drivers / net / ethernet / netronome / nfp / abm / main.h
1 /* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */
2 /* Copyright (C) 2018 Netronome Systems, Inc. */
3
4 #ifndef __NFP_ABM_H__
5 #define __NFP_ABM_H__ 1
6
7 #include <linux/bits.h>
8 #include <linux/list.h>
9 #include <linux/radix-tree.h>
10 #include <net/devlink.h>
11 #include <net/pkt_cls.h>
12 #include <net/pkt_sched.h>
13
14 /* Dump of 64 PRIOs and 256 REDs seems to take 850us on Xeon v4 @ 2.20GHz;
15  * 2.5ms / 400Hz seems more than sufficient for stats resolution.
16  */
17 #define NFP_ABM_STATS_REFRESH_IVAL      (2500 * 1000) /* ns */
18
19 #define NFP_ABM_LVL_INFINITY            S32_MAX
20
21 struct nfp_app;
22 struct nfp_net;
23
24 #define NFP_ABM_PORTID_TYPE     GENMASK(23, 16)
25 #define NFP_ABM_PORTID_ID       GENMASK(7, 0)
26
27 /* The possible actions if thresholds are exceeded */
28 enum nfp_abm_q_action {
29         /* mark if ECN capable, otherwise drop */
30         NFP_ABM_ACT_MARK_DROP           = 0,
31         /* mark if ECN capable, otherwise goto QM */
32         NFP_ABM_ACT_MARK_QUEUE          = 1,
33         NFP_ABM_ACT_DROP                = 2,
34         NFP_ABM_ACT_QUEUE               = 3,
35         NFP_ABM_ACT_NOQUEUE             = 4,
36 };
37
38 /**
39  * struct nfp_abm - ABM NIC app structure
40  * @app:        back pointer to nfp_app
41  * @pf_id:      ID of our PF link
42  *
43  * @red_support:        is RED offload supported
44  * @num_prios:  number of supported DSCP priorities
45  * @num_bands:  number of supported DSCP priority bands
46  * @action_mask:        bitmask of supported actions
47  *
48  * @thresholds:         current threshold configuration
49  * @threshold_undef:    bitmap of thresholds which have not been set
50  * @actions:            current FW action configuration
51  * @num_thresholds:     number of @thresholds and bits in @threshold_undef
52  *
53  * @prio_map_len:       computed length of FW priority map (in bytes)
54  * @dscp_mask:          mask FW will apply on DSCP field
55  *
56  * @eswitch_mode:       devlink eswitch mode, advanced functions only visible
57  *                      in switchdev mode
58  *
59  * @q_lvls:     queue level control area
60  * @qm_stats:   queue statistics symbol
61  * @q_stats:    basic queue statistics (only in per-band case)
62  */
63 struct nfp_abm {
64         struct nfp_app *app;
65         unsigned int pf_id;
66
67         unsigned int red_support;
68         unsigned int num_prios;
69         unsigned int num_bands;
70         unsigned int action_mask;
71
72         u32 *thresholds;
73         unsigned long *threshold_undef;
74         u8 *actions;
75         size_t num_thresholds;
76
77         unsigned int prio_map_len;
78         u8 dscp_mask;
79
80         enum devlink_eswitch_mode eswitch_mode;
81
82         const struct nfp_rtsym *q_lvls;
83         const struct nfp_rtsym *qm_stats;
84         const struct nfp_rtsym *q_stats;
85 };
86
87 /**
88  * struct nfp_alink_stats - ABM NIC statistics
89  * @tx_pkts:            number of TXed packets
90  * @tx_bytes:           number of TXed bytes
91  * @backlog_pkts:       momentary backlog length (packets)
92  * @backlog_bytes:      momentary backlog length (bytes)
93  * @overlimits:         number of ECN marked TXed packets (accumulative)
94  * @drops:              number of tail-dropped packets (accumulative)
95  */
96 struct nfp_alink_stats {
97         u64 tx_pkts;
98         u64 tx_bytes;
99         u64 backlog_pkts;
100         u64 backlog_bytes;
101         u64 overlimits;
102         u64 drops;
103 };
104
105 /**
106  * struct nfp_alink_xstats - extended ABM NIC statistics
107  * @ecn_marked:         number of ECN marked TXed packets
108  * @pdrop:              number of hard drops due to queue limit
109  */
110 struct nfp_alink_xstats {
111         u64 ecn_marked;
112         u64 pdrop;
113 };
114
115 enum nfp_qdisc_type {
116         NFP_QDISC_NONE = 0,
117         NFP_QDISC_MQ,
118         NFP_QDISC_RED,
119         NFP_QDISC_GRED,
120 };
121
122 #define NFP_QDISC_UNTRACKED     ((struct nfp_qdisc *)1UL)
123
124 /**
125  * struct nfp_qdisc - tracked TC Qdisc
126  * @netdev:             netdev on which Qdisc was created
127  * @type:               Qdisc type
128  * @handle:             handle of this Qdisc
129  * @parent_handle:      handle of the parent (unreliable if Qdisc was grafted)
130  * @use_cnt:            number of attachment points in the hierarchy
131  * @num_children:       current size of the @children array
132  * @children:           pointers to children
133  *
134  * @params_ok:          parameters of this Qdisc are OK for offload
135  * @offload_mark:       offload refresh state - selected for offload
136  * @offloaded:          Qdisc is currently offloaded to the HW
137  *
138  * @mq:                 MQ Qdisc specific parameters and state
139  * @mq.stats:           current stats of the MQ Qdisc
140  * @mq.prev_stats:      previously reported @mq.stats
141  *
142  * @red:                RED Qdisc specific parameters and state
143  * @red.num_bands:      Number of valid entries in the @red.band table
144  * @red.band:           Per-band array of RED instances
145  * @red.band.ecn:               ECN marking is enabled (rather than drop)
146  * @red.band.threshold:         ECN marking threshold
147  * @red.band.stats:             current stats of the RED Qdisc
148  * @red.band.prev_stats:        previously reported @red.stats
149  * @red.band.xstats:            extended stats for RED - current
150  * @red.band.prev_xstats:       extended stats for RED - previously reported
151  */
152 struct nfp_qdisc {
153         struct net_device *netdev;
154         enum nfp_qdisc_type type;
155         u32 handle;
156         u32 parent_handle;
157         unsigned int use_cnt;
158         unsigned int num_children;
159         struct nfp_qdisc **children;
160
161         bool params_ok;
162         bool offload_mark;
163         bool offloaded;
164
165         union {
166                 /* NFP_QDISC_MQ */
167                 struct {
168                         struct nfp_alink_stats stats;
169                         struct nfp_alink_stats prev_stats;
170                 } mq;
171                 /* TC_SETUP_QDISC_RED, TC_SETUP_QDISC_GRED */
172                 struct {
173                         unsigned int num_bands;
174
175                         struct {
176                                 bool ecn;
177                                 u32 threshold;
178                                 struct nfp_alink_stats stats;
179                                 struct nfp_alink_stats prev_stats;
180                                 struct nfp_alink_xstats xstats;
181                                 struct nfp_alink_xstats prev_xstats;
182                         } band[MAX_DPs];
183                 } red;
184         };
185 };
186
187 /**
188  * struct nfp_abm_link - port tuple of a ABM NIC
189  * @abm:        back pointer to nfp_abm
190  * @vnic:       data vNIC
191  * @id:         id of the data vNIC
192  * @queue_base: id of base to host queue within PCIe (not QC idx)
193  * @total_queues:       number of PF queues
194  *
195  * @last_stats_update:  ktime of last stats update
196  *
197  * @prio_map:           current map of priorities
198  * @has_prio:           @prio_map is valid
199  *
200  * @def_band:           default band to use
201  * @dscp_map:           list of DSCP to band mappings
202  *
203  * @root_qdisc: pointer to the current root of the Qdisc hierarchy
204  * @qdiscs:     all qdiscs recorded by major part of the handle
205  */
206 struct nfp_abm_link {
207         struct nfp_abm *abm;
208         struct nfp_net *vnic;
209         unsigned int id;
210         unsigned int queue_base;
211         unsigned int total_queues;
212
213         u64 last_stats_update;
214
215         u32 *prio_map;
216         bool has_prio;
217
218         u8 def_band;
219         struct list_head dscp_map;
220
221         struct nfp_qdisc *root_qdisc;
222         struct radix_tree_root qdiscs;
223 };
224
225 static inline bool nfp_abm_has_prio(struct nfp_abm *abm)
226 {
227         return abm->num_bands > 1;
228 }
229
230 static inline bool nfp_abm_has_drop(struct nfp_abm *abm)
231 {
232         return abm->action_mask & BIT(NFP_ABM_ACT_DROP);
233 }
234
235 static inline bool nfp_abm_has_mark(struct nfp_abm *abm)
236 {
237         return abm->action_mask & BIT(NFP_ABM_ACT_MARK_DROP);
238 }
239
240 void nfp_abm_qdisc_offload_update(struct nfp_abm_link *alink);
241 int nfp_abm_setup_root(struct net_device *netdev, struct nfp_abm_link *alink,
242                        struct tc_root_qopt_offload *opt);
243 int nfp_abm_setup_tc_red(struct net_device *netdev, struct nfp_abm_link *alink,
244                          struct tc_red_qopt_offload *opt);
245 int nfp_abm_setup_tc_mq(struct net_device *netdev, struct nfp_abm_link *alink,
246                         struct tc_mq_qopt_offload *opt);
247 int nfp_abm_setup_tc_gred(struct net_device *netdev, struct nfp_abm_link *alink,
248                           struct tc_gred_qopt_offload *opt);
249 int nfp_abm_setup_cls_block(struct net_device *netdev, struct nfp_repr *repr,
250                             struct flow_block_offload *opt);
251
252 int nfp_abm_ctrl_read_params(struct nfp_abm_link *alink);
253 int nfp_abm_ctrl_find_addrs(struct nfp_abm *abm);
254 int __nfp_abm_ctrl_set_q_lvl(struct nfp_abm *abm, unsigned int id, u32 val);
255 int nfp_abm_ctrl_set_q_lvl(struct nfp_abm_link *alink, unsigned int band,
256                            unsigned int queue, u32 val);
257 int __nfp_abm_ctrl_set_q_act(struct nfp_abm *abm, unsigned int id,
258                              enum nfp_abm_q_action act);
259 int nfp_abm_ctrl_set_q_act(struct nfp_abm_link *alink, unsigned int band,
260                            unsigned int queue, enum nfp_abm_q_action act);
261 int nfp_abm_ctrl_read_q_stats(struct nfp_abm_link *alink,
262                               unsigned int band, unsigned int queue,
263                               struct nfp_alink_stats *stats);
264 int nfp_abm_ctrl_read_q_xstats(struct nfp_abm_link *alink,
265                                unsigned int band, unsigned int queue,
266                                struct nfp_alink_xstats *xstats);
267 u64 nfp_abm_ctrl_stat_non_sto(struct nfp_abm_link *alink, unsigned int i);
268 u64 nfp_abm_ctrl_stat_sto(struct nfp_abm_link *alink, unsigned int i);
269 int nfp_abm_ctrl_qm_enable(struct nfp_abm *abm);
270 int nfp_abm_ctrl_qm_disable(struct nfp_abm *abm);
271 void nfp_abm_prio_map_update(struct nfp_abm *abm);
272 int nfp_abm_ctrl_prio_map_update(struct nfp_abm_link *alink, u32 *packed);
273 #endif