aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/netronome/nfp/abm/main.h
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/ethernet/netronome/nfp/abm/main.h')
-rw-r--r--drivers/net/ethernet/netronome/nfp/abm/main.h111
1 files changed, 111 insertions, 0 deletions
diff --git a/drivers/net/ethernet/netronome/nfp/abm/main.h b/drivers/net/ethernet/netronome/nfp/abm/main.h
new file mode 100644
index 000000000000..f907b7d98917
--- /dev/null
+++ b/drivers/net/ethernet/netronome/nfp/abm/main.h
@@ -0,0 +1,111 @@
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 <net/devlink.h>
8
9struct nfp_app;
10struct nfp_net;
11
12#define NFP_ABM_PORTID_TYPE GENMASK(23, 16)
13#define NFP_ABM_PORTID_ID GENMASK(7, 0)
14
15/**
16 * struct nfp_abm - ABM NIC app structure
17 * @app: back pointer to nfp_app
18 * @pf_id: ID of our PF link
19 * @eswitch_mode: devlink eswitch mode, advanced functions only visible
20 * in switchdev mode
21 * @q_lvls: queue level control area
22 * @qm_stats: queue statistics symbol
23 */
24struct nfp_abm {
25 struct nfp_app *app;
26 unsigned int pf_id;
27 enum devlink_eswitch_mode eswitch_mode;
28 const struct nfp_rtsym *q_lvls;
29 const struct nfp_rtsym *qm_stats;
30};
31
32/**
33 * struct nfp_alink_stats - ABM NIC statistics
34 * @tx_pkts: number of TXed packets
35 * @tx_bytes: number of TXed bytes
36 * @backlog_pkts: momentary backlog length (packets)
37 * @backlog_bytes: momentary backlog length (bytes)
38 * @overlimits: number of ECN marked TXed packets (accumulative)
39 * @drops: number of tail-dropped packets (accumulative)
40 */
41struct nfp_alink_stats {
42 u64 tx_pkts;
43 u64 tx_bytes;
44 u64 backlog_pkts;
45 u64 backlog_bytes;
46 u64 overlimits;
47 u64 drops;
48};
49
50/**
51 * struct nfp_alink_xstats - extended ABM NIC statistics
52 * @ecn_marked: number of ECN marked TXed packets
53 * @pdrop: number of hard drops due to queue limit
54 */
55struct nfp_alink_xstats {
56 u64 ecn_marked;
57 u64 pdrop;
58};
59
60/**
61 * struct nfp_red_qdisc - representation of single RED Qdisc
62 * @handle: handle of currently offloaded RED Qdisc
63 * @stats: statistics from last refresh
64 * @xstats: base of extended statistics
65 */
66struct nfp_red_qdisc {
67 u32 handle;
68 struct nfp_alink_stats stats;
69 struct nfp_alink_xstats xstats;
70};
71
72/**
73 * struct nfp_abm_link - port tuple of a ABM NIC
74 * @abm: back pointer to nfp_abm
75 * @vnic: data vNIC
76 * @id: id of the data vNIC
77 * @queue_base: id of base to host queue within PCIe (not QC idx)
78 * @total_queues: number of PF queues
79 * @parent: handle of expected parent, i.e. handle of MQ, or TC_H_ROOT
80 * @num_qdiscs: number of currently used qdiscs
81 * @qdiscs: array of qdiscs
82 */
83struct nfp_abm_link {
84 struct nfp_abm *abm;
85 struct nfp_net *vnic;
86 unsigned int id;
87 unsigned int queue_base;
88 unsigned int total_queues;
89 u32 parent;
90 unsigned int num_qdiscs;
91 struct nfp_red_qdisc *qdiscs;
92};
93
94void nfp_abm_ctrl_read_params(struct nfp_abm_link *alink);
95int nfp_abm_ctrl_find_addrs(struct nfp_abm *abm);
96int nfp_abm_ctrl_set_all_q_lvls(struct nfp_abm_link *alink, u32 val);
97int nfp_abm_ctrl_set_q_lvl(struct nfp_abm_link *alink, unsigned int i,
98 u32 val);
99int nfp_abm_ctrl_read_stats(struct nfp_abm_link *alink,
100 struct nfp_alink_stats *stats);
101int nfp_abm_ctrl_read_q_stats(struct nfp_abm_link *alink, unsigned int i,
102 struct nfp_alink_stats *stats);
103int nfp_abm_ctrl_read_xstats(struct nfp_abm_link *alink,
104 struct nfp_alink_xstats *xstats);
105int nfp_abm_ctrl_read_q_xstats(struct nfp_abm_link *alink, unsigned int i,
106 struct nfp_alink_xstats *xstats);
107u64 nfp_abm_ctrl_stat_non_sto(struct nfp_abm_link *alink, unsigned int i);
108u64 nfp_abm_ctrl_stat_sto(struct nfp_abm_link *alink, unsigned int i);
109int nfp_abm_ctrl_qm_enable(struct nfp_abm *abm);
110int nfp_abm_ctrl_qm_disable(struct nfp_abm *abm);
111#endif