blob: f8ff71126d9e1498d71f889ac54b79704f045cbe [file] [log] [blame]
Yuval Mintz25c089d2015-10-26 11:02:26 +02001/* QLogic qed NIC Driver
2 * Copyright (c) 2015 QLogic Corporation
3 *
4 * This software is available under the terms of the GNU General Public License
5 * (GPL) Version 2, available from the file COPYING in the main directory of
6 * this source tree.
7 */
8
9#ifndef _QED_ETH_IF_H
10#define _QED_ETH_IF_H
11
12#include <linux/list.h>
13#include <linux/if_link.h>
14#include <linux/qed/eth_common.h>
15#include <linux/qed/qed_if.h>
Yuval Mintz0b55e272016-05-11 16:36:15 +030016#include <linux/qed/qed_iov_if.h>
Yuval Mintz25c089d2015-10-26 11:02:26 +020017
18struct qed_dev_eth_info {
19 struct qed_dev_info common;
20
21 u8 num_queues;
22 u8 num_tc;
23
24 u8 port_mac[ETH_ALEN];
25 u8 num_vlan_filters;
26};
27
Manish Chopracee4d262015-10-26 11:02:28 +020028struct qed_update_vport_rss_params {
29 u16 rss_ind_table[128];
30 u32 rss_key[10];
Sudarsana Reddy Kalluru8c5ebd02016-04-10 12:43:00 +030031 u8 rss_caps;
Manish Chopracee4d262015-10-26 11:02:28 +020032};
33
34struct qed_update_vport_params {
35 u8 vport_id;
36 u8 update_vport_active_flg;
37 u8 vport_active_flg;
Yuval Mintz831bfb0e2016-05-11 16:36:25 +030038 u8 update_tx_switching_flg;
39 u8 tx_switching_flg;
Yuval Mintz3f9b4a62016-02-18 17:00:39 +020040 u8 update_accept_any_vlan_flg;
41 u8 accept_any_vlan;
Manish Chopracee4d262015-10-26 11:02:28 +020042 u8 update_rss_flg;
43 struct qed_update_vport_rss_params rss_params;
44};
45
Manish Chopra088c8612016-03-04 12:35:05 -050046struct qed_start_vport_params {
47 bool remove_inner_vlan;
48 bool gro_enable;
49 bool drop_ttl0;
50 u8 vport_id;
51 u16 mtu;
52};
53
Manish Chopracee4d262015-10-26 11:02:28 +020054struct qed_stop_rxq_params {
55 u8 rss_id;
56 u8 rx_queue_id;
57 u8 vport_id;
58 bool eq_completion_only;
59};
60
61struct qed_stop_txq_params {
62 u8 rss_id;
63 u8 tx_queue_id;
64};
65
66enum qed_filter_rx_mode_type {
67 QED_FILTER_RX_MODE_TYPE_REGULAR,
68 QED_FILTER_RX_MODE_TYPE_MULTI_PROMISC,
69 QED_FILTER_RX_MODE_TYPE_PROMISC,
70};
71
72enum qed_filter_xcast_params_type {
73 QED_FILTER_XCAST_TYPE_ADD,
74 QED_FILTER_XCAST_TYPE_DEL,
75 QED_FILTER_XCAST_TYPE_REPLACE,
76};
77
78struct qed_filter_ucast_params {
79 enum qed_filter_xcast_params_type type;
80 u8 vlan_valid;
81 u16 vlan;
82 u8 mac_valid;
83 unsigned char mac[ETH_ALEN];
84};
85
86struct qed_filter_mcast_params {
87 enum qed_filter_xcast_params_type type;
88 u8 num;
89 unsigned char mac[64][ETH_ALEN];
90};
91
92union qed_filter_type_params {
93 enum qed_filter_rx_mode_type accept_flags;
94 struct qed_filter_ucast_params ucast;
95 struct qed_filter_mcast_params mcast;
96};
97
98enum qed_filter_type {
99 QED_FILTER_TYPE_UCAST,
100 QED_FILTER_TYPE_MCAST,
101 QED_FILTER_TYPE_RX_MODE,
102 QED_MAX_FILTER_TYPES,
103};
104
105struct qed_filter_params {
106 enum qed_filter_type type;
107 union qed_filter_type_params filter;
108};
109
110struct qed_queue_start_common_params {
111 u8 rss_id;
112 u8 queue_id;
113 u8 vport_id;
114 u16 sb;
115 u16 sb_idx;
Yuval Mintz351a4ded2016-06-02 10:23:29 +0300116 u16 vf_qid;
Manish Chopracee4d262015-10-26 11:02:28 +0200117};
118
Manish Chopra464f6642016-04-14 01:38:29 -0400119struct qed_tunn_params {
120 u16 vxlan_port;
121 u8 update_vxlan_port;
122 u16 geneve_port;
123 u8 update_geneve_port;
124};
125
Manish Chopracee4d262015-10-26 11:02:28 +0200126struct qed_eth_cb_ops {
127 struct qed_common_cb_ops common;
Yuval Mintzeff16962016-05-11 16:36:21 +0300128 void (*force_mac) (void *dev, u8 *mac);
Manish Chopracee4d262015-10-26 11:02:28 +0200129};
130
Yuval Mintz25c089d2015-10-26 11:02:26 +0200131struct qed_eth_ops {
132 const struct qed_common_ops *common;
Yuval Mintz0b55e272016-05-11 16:36:15 +0300133#ifdef CONFIG_QED_SRIOV
134 const struct qed_iov_hv_ops *iov;
135#endif
Yuval Mintz25c089d2015-10-26 11:02:26 +0200136
137 int (*fill_dev_info)(struct qed_dev *cdev,
138 struct qed_dev_eth_info *info);
139
Yuval Mintzcc875c22015-10-26 11:02:31 +0200140 void (*register_ops)(struct qed_dev *cdev,
141 struct qed_eth_cb_ops *ops,
142 void *cookie);
143
Yuval Mintzeff16962016-05-11 16:36:21 +0300144 bool(*check_mac) (struct qed_dev *cdev, u8 *mac);
145
Manish Chopracee4d262015-10-26 11:02:28 +0200146 int (*vport_start)(struct qed_dev *cdev,
Manish Chopra088c8612016-03-04 12:35:05 -0500147 struct qed_start_vport_params *params);
Manish Chopracee4d262015-10-26 11:02:28 +0200148
149 int (*vport_stop)(struct qed_dev *cdev,
150 u8 vport_id);
151
152 int (*vport_update)(struct qed_dev *cdev,
153 struct qed_update_vport_params *params);
154
155 int (*q_rx_start)(struct qed_dev *cdev,
156 struct qed_queue_start_common_params *params,
157 u16 bd_max_bytes,
158 dma_addr_t bd_chain_phys_addr,
159 dma_addr_t cqe_pbl_addr,
160 u16 cqe_pbl_size,
161 void __iomem **pp_prod);
162
163 int (*q_rx_stop)(struct qed_dev *cdev,
164 struct qed_stop_rxq_params *params);
165
166 int (*q_tx_start)(struct qed_dev *cdev,
167 struct qed_queue_start_common_params *params,
168 dma_addr_t pbl_addr,
169 u16 pbl_size,
170 void __iomem **pp_doorbell);
171
172 int (*q_tx_stop)(struct qed_dev *cdev,
173 struct qed_stop_txq_params *params);
174
175 int (*filter_config)(struct qed_dev *cdev,
176 struct qed_filter_params *params);
177
178 int (*fastpath_stop)(struct qed_dev *cdev);
179
180 int (*eth_cqe_completion)(struct qed_dev *cdev,
181 u8 rss_id,
182 struct eth_slow_path_rx_cqe *cqe);
Manish Chopra9df2ed02015-10-26 11:02:33 +0200183
184 void (*get_vport_stats)(struct qed_dev *cdev,
185 struct qed_eth_stats *stats);
Manish Chopra464f6642016-04-14 01:38:29 -0400186
187 int (*tunn_config)(struct qed_dev *cdev,
188 struct qed_tunn_params *params);
Yuval Mintz25c089d2015-10-26 11:02:26 +0200189};
190
Rahul Verma95114342016-04-10 12:42:59 +0300191const struct qed_eth_ops *qed_get_eth_ops(void);
Yuval Mintz25c089d2015-10-26 11:02:26 +0200192void qed_put_eth_ops(void);
193
194#endif