blob: e53b0ca49e41bcb79c906717735bd338772beaf5 [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>
16
17struct qed_dev_eth_info {
18 struct qed_dev_info common;
19
20 u8 num_queues;
21 u8 num_tc;
22
23 u8 port_mac[ETH_ALEN];
24 u8 num_vlan_filters;
25};
26
Manish Chopracee4d262015-10-26 11:02:28 +020027struct qed_update_vport_rss_params {
28 u16 rss_ind_table[128];
29 u32 rss_key[10];
30};
31
32struct qed_update_vport_params {
33 u8 vport_id;
34 u8 update_vport_active_flg;
35 u8 vport_active_flg;
Yuval Mintz3f9b4a62016-02-18 17:00:39 +020036 u8 update_accept_any_vlan_flg;
37 u8 accept_any_vlan;
Manish Chopracee4d262015-10-26 11:02:28 +020038 u8 update_rss_flg;
39 struct qed_update_vport_rss_params rss_params;
40};
41
42struct qed_stop_rxq_params {
43 u8 rss_id;
44 u8 rx_queue_id;
45 u8 vport_id;
46 bool eq_completion_only;
47};
48
49struct qed_stop_txq_params {
50 u8 rss_id;
51 u8 tx_queue_id;
52};
53
54enum qed_filter_rx_mode_type {
55 QED_FILTER_RX_MODE_TYPE_REGULAR,
56 QED_FILTER_RX_MODE_TYPE_MULTI_PROMISC,
57 QED_FILTER_RX_MODE_TYPE_PROMISC,
58};
59
60enum qed_filter_xcast_params_type {
61 QED_FILTER_XCAST_TYPE_ADD,
62 QED_FILTER_XCAST_TYPE_DEL,
63 QED_FILTER_XCAST_TYPE_REPLACE,
64};
65
66struct qed_filter_ucast_params {
67 enum qed_filter_xcast_params_type type;
68 u8 vlan_valid;
69 u16 vlan;
70 u8 mac_valid;
71 unsigned char mac[ETH_ALEN];
72};
73
74struct qed_filter_mcast_params {
75 enum qed_filter_xcast_params_type type;
76 u8 num;
77 unsigned char mac[64][ETH_ALEN];
78};
79
80union qed_filter_type_params {
81 enum qed_filter_rx_mode_type accept_flags;
82 struct qed_filter_ucast_params ucast;
83 struct qed_filter_mcast_params mcast;
84};
85
86enum qed_filter_type {
87 QED_FILTER_TYPE_UCAST,
88 QED_FILTER_TYPE_MCAST,
89 QED_FILTER_TYPE_RX_MODE,
90 QED_MAX_FILTER_TYPES,
91};
92
93struct qed_filter_params {
94 enum qed_filter_type type;
95 union qed_filter_type_params filter;
96};
97
98struct qed_queue_start_common_params {
99 u8 rss_id;
100 u8 queue_id;
101 u8 vport_id;
102 u16 sb;
103 u16 sb_idx;
104};
105
106struct qed_eth_cb_ops {
107 struct qed_common_cb_ops common;
108};
109
Yuval Mintz25c089d2015-10-26 11:02:26 +0200110struct qed_eth_ops {
111 const struct qed_common_ops *common;
112
113 int (*fill_dev_info)(struct qed_dev *cdev,
114 struct qed_dev_eth_info *info);
115
Yuval Mintzcc875c22015-10-26 11:02:31 +0200116 void (*register_ops)(struct qed_dev *cdev,
117 struct qed_eth_cb_ops *ops,
118 void *cookie);
119
Manish Chopracee4d262015-10-26 11:02:28 +0200120 int (*vport_start)(struct qed_dev *cdev,
121 u8 vport_id, u16 mtu,
122 u8 drop_ttl0_flg,
123 u8 inner_vlan_removal_en_flg);
124
125 int (*vport_stop)(struct qed_dev *cdev,
126 u8 vport_id);
127
128 int (*vport_update)(struct qed_dev *cdev,
129 struct qed_update_vport_params *params);
130
131 int (*q_rx_start)(struct qed_dev *cdev,
132 struct qed_queue_start_common_params *params,
133 u16 bd_max_bytes,
134 dma_addr_t bd_chain_phys_addr,
135 dma_addr_t cqe_pbl_addr,
136 u16 cqe_pbl_size,
137 void __iomem **pp_prod);
138
139 int (*q_rx_stop)(struct qed_dev *cdev,
140 struct qed_stop_rxq_params *params);
141
142 int (*q_tx_start)(struct qed_dev *cdev,
143 struct qed_queue_start_common_params *params,
144 dma_addr_t pbl_addr,
145 u16 pbl_size,
146 void __iomem **pp_doorbell);
147
148 int (*q_tx_stop)(struct qed_dev *cdev,
149 struct qed_stop_txq_params *params);
150
151 int (*filter_config)(struct qed_dev *cdev,
152 struct qed_filter_params *params);
153
154 int (*fastpath_stop)(struct qed_dev *cdev);
155
156 int (*eth_cqe_completion)(struct qed_dev *cdev,
157 u8 rss_id,
158 struct eth_slow_path_rx_cqe *cqe);
Manish Chopra9df2ed02015-10-26 11:02:33 +0200159
160 void (*get_vport_stats)(struct qed_dev *cdev,
161 struct qed_eth_stats *stats);
Yuval Mintz25c089d2015-10-26 11:02:26 +0200162};
163
164const struct qed_eth_ops *qed_get_eth_ops(u32 version);
165void qed_put_eth_ops(void);
166
167#endif