xref: /linux/drivers/net/ethernet/intel/idpf/idpf_ethtool.c (revision 576d7fed09c7edbae7600f29a8a3ed6c1ead904f)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /* Copyright (C) 2023 Intel Corporation */
3 
4 #include "idpf.h"
5 
6 /**
7  * idpf_get_rxnfc - command to get RX flow classification rules
8  * @netdev: network interface device structure
9  * @cmd: ethtool rxnfc command
10  * @rule_locs: pointer to store rule locations
11  *
12  * Returns Success if the command is supported.
13  */
14 static int idpf_get_rxnfc(struct net_device *netdev, struct ethtool_rxnfc *cmd,
15 			  u32 __always_unused *rule_locs)
16 {
17 	struct idpf_vport *vport;
18 
19 	idpf_vport_ctrl_lock(netdev);
20 	vport = idpf_netdev_to_vport(netdev);
21 
22 	switch (cmd->cmd) {
23 	case ETHTOOL_GRXRINGS:
24 		cmd->data = vport->num_rxq;
25 		idpf_vport_ctrl_unlock(netdev);
26 
27 		return 0;
28 	default:
29 		break;
30 	}
31 
32 	idpf_vport_ctrl_unlock(netdev);
33 
34 	return -EOPNOTSUPP;
35 }
36 
37 /**
38  * idpf_get_rxfh_key_size - get the RSS hash key size
39  * @netdev: network interface device structure
40  *
41  * Returns the key size on success, error value on failure.
42  */
43 static u32 idpf_get_rxfh_key_size(struct net_device *netdev)
44 {
45 	struct idpf_netdev_priv *np = netdev_priv(netdev);
46 	struct idpf_vport_user_config_data *user_config;
47 
48 	if (!idpf_is_cap_ena_all(np->adapter, IDPF_RSS_CAPS, IDPF_CAP_RSS))
49 		return -EOPNOTSUPP;
50 
51 	user_config = &np->adapter->vport_config[np->vport_idx]->user_config;
52 
53 	return user_config->rss_data.rss_key_size;
54 }
55 
56 /**
57  * idpf_get_rxfh_indir_size - get the rx flow hash indirection table size
58  * @netdev: network interface device structure
59  *
60  * Returns the table size on success, error value on failure.
61  */
62 static u32 idpf_get_rxfh_indir_size(struct net_device *netdev)
63 {
64 	struct idpf_netdev_priv *np = netdev_priv(netdev);
65 	struct idpf_vport_user_config_data *user_config;
66 
67 	if (!idpf_is_cap_ena_all(np->adapter, IDPF_RSS_CAPS, IDPF_CAP_RSS))
68 		return -EOPNOTSUPP;
69 
70 	user_config = &np->adapter->vport_config[np->vport_idx]->user_config;
71 
72 	return user_config->rss_data.rss_lut_size;
73 }
74 
75 /**
76  * idpf_get_rxfh - get the rx flow hash indirection table
77  * @netdev: network interface device structure
78  * @indir: indirection table
79  * @key: hash key
80  * @hfunc: hash function in use
81  *
82  * Reads the indirection table directly from the hardware. Always returns 0.
83  */
84 static int idpf_get_rxfh(struct net_device *netdev, u32 *indir, u8 *key,
85 			 u8 *hfunc)
86 {
87 	struct idpf_netdev_priv *np = netdev_priv(netdev);
88 	struct idpf_rss_data *rss_data;
89 	struct idpf_adapter *adapter;
90 	int err = 0;
91 	u16 i;
92 
93 	idpf_vport_ctrl_lock(netdev);
94 
95 	adapter = np->adapter;
96 
97 	if (!idpf_is_cap_ena_all(adapter, IDPF_RSS_CAPS, IDPF_CAP_RSS)) {
98 		err = -EOPNOTSUPP;
99 		goto unlock_mutex;
100 	}
101 
102 	rss_data = &adapter->vport_config[np->vport_idx]->user_config.rss_data;
103 	if (np->state != __IDPF_VPORT_UP)
104 		goto unlock_mutex;
105 
106 	if (hfunc)
107 		*hfunc = ETH_RSS_HASH_TOP;
108 
109 	if (key)
110 		memcpy(key, rss_data->rss_key, rss_data->rss_key_size);
111 
112 	if (indir) {
113 		for (i = 0; i < rss_data->rss_lut_size; i++)
114 			indir[i] = rss_data->rss_lut[i];
115 	}
116 
117 unlock_mutex:
118 	idpf_vport_ctrl_unlock(netdev);
119 
120 	return err;
121 }
122 
123 /**
124  * idpf_set_rxfh - set the rx flow hash indirection table
125  * @netdev: network interface device structure
126  * @indir: indirection table
127  * @key: hash key
128  * @hfunc: hash function to use
129  *
130  * Returns -EINVAL if the table specifies an invalid queue id, otherwise
131  * returns 0 after programming the table.
132  */
133 static int idpf_set_rxfh(struct net_device *netdev, const u32 *indir,
134 			 const u8 *key, const u8 hfunc)
135 {
136 	struct idpf_netdev_priv *np = netdev_priv(netdev);
137 	struct idpf_rss_data *rss_data;
138 	struct idpf_adapter *adapter;
139 	struct idpf_vport *vport;
140 	int err = 0;
141 	u16 lut;
142 
143 	idpf_vport_ctrl_lock(netdev);
144 	vport = idpf_netdev_to_vport(netdev);
145 
146 	adapter = vport->adapter;
147 
148 	if (!idpf_is_cap_ena_all(adapter, IDPF_RSS_CAPS, IDPF_CAP_RSS)) {
149 		err = -EOPNOTSUPP;
150 		goto unlock_mutex;
151 	}
152 
153 	rss_data = &adapter->vport_config[vport->idx]->user_config.rss_data;
154 	if (np->state != __IDPF_VPORT_UP)
155 		goto unlock_mutex;
156 
157 	if (hfunc != ETH_RSS_HASH_NO_CHANGE && hfunc != ETH_RSS_HASH_TOP) {
158 		err = -EOPNOTSUPP;
159 		goto unlock_mutex;
160 	}
161 
162 	if (key)
163 		memcpy(rss_data->rss_key, key, rss_data->rss_key_size);
164 
165 	if (indir) {
166 		for (lut = 0; lut < rss_data->rss_lut_size; lut++)
167 			rss_data->rss_lut[lut] = indir[lut];
168 	}
169 
170 	err = idpf_config_rss(vport);
171 
172 unlock_mutex:
173 	idpf_vport_ctrl_unlock(netdev);
174 
175 	return err;
176 }
177 
178 /**
179  * idpf_get_channels: get the number of channels supported by the device
180  * @netdev: network interface device structure
181  * @ch: channel information structure
182  *
183  * Report maximum of TX and RX. Report one extra channel to match our MailBox
184  * Queue.
185  */
186 static void idpf_get_channels(struct net_device *netdev,
187 			      struct ethtool_channels *ch)
188 {
189 	struct idpf_netdev_priv *np = netdev_priv(netdev);
190 	struct idpf_vport_config *vport_config;
191 	u16 num_txq, num_rxq;
192 	u16 combined;
193 
194 	vport_config = np->adapter->vport_config[np->vport_idx];
195 
196 	num_txq = vport_config->user_config.num_req_tx_qs;
197 	num_rxq = vport_config->user_config.num_req_rx_qs;
198 
199 	combined = min(num_txq, num_rxq);
200 
201 	/* Report maximum channels */
202 	ch->max_combined = min_t(u16, vport_config->max_q.max_txq,
203 				 vport_config->max_q.max_rxq);
204 	ch->max_rx = vport_config->max_q.max_rxq;
205 	ch->max_tx = vport_config->max_q.max_txq;
206 
207 	ch->max_other = IDPF_MAX_MBXQ;
208 	ch->other_count = IDPF_MAX_MBXQ;
209 
210 	ch->combined_count = combined;
211 	ch->rx_count = num_rxq - combined;
212 	ch->tx_count = num_txq - combined;
213 }
214 
215 /**
216  * idpf_set_channels: set the new channel count
217  * @netdev: network interface device structure
218  * @ch: channel information structure
219  *
220  * Negotiate a new number of channels with CP. Returns 0 on success, negative
221  * on failure.
222  */
223 static int idpf_set_channels(struct net_device *netdev,
224 			     struct ethtool_channels *ch)
225 {
226 	struct idpf_vport_config *vport_config;
227 	u16 combined, num_txq, num_rxq;
228 	unsigned int num_req_tx_q;
229 	unsigned int num_req_rx_q;
230 	struct idpf_vport *vport;
231 	struct device *dev;
232 	int err = 0;
233 	u16 idx;
234 
235 	idpf_vport_ctrl_lock(netdev);
236 	vport = idpf_netdev_to_vport(netdev);
237 
238 	idx = vport->idx;
239 	vport_config = vport->adapter->vport_config[idx];
240 
241 	num_txq = vport_config->user_config.num_req_tx_qs;
242 	num_rxq = vport_config->user_config.num_req_rx_qs;
243 
244 	combined = min(num_txq, num_rxq);
245 
246 	/* these checks are for cases where user didn't specify a particular
247 	 * value on cmd line but we get non-zero value anyway via
248 	 * get_channels(); look at ethtool.c in ethtool repository (the user
249 	 * space part), particularly, do_schannels() routine
250 	 */
251 	if (ch->combined_count == combined)
252 		ch->combined_count = 0;
253 	if (ch->combined_count && ch->rx_count == num_rxq - combined)
254 		ch->rx_count = 0;
255 	if (ch->combined_count && ch->tx_count == num_txq - combined)
256 		ch->tx_count = 0;
257 
258 	num_req_tx_q = ch->combined_count + ch->tx_count;
259 	num_req_rx_q = ch->combined_count + ch->rx_count;
260 
261 	dev = &vport->adapter->pdev->dev;
262 	/* It's possible to specify number of queues that exceeds max.
263 	 * Stack checks max combined_count and max [tx|rx]_count but not the
264 	 * max combined_count + [tx|rx]_count. These checks should catch that.
265 	 */
266 	if (num_req_tx_q > vport_config->max_q.max_txq) {
267 		dev_info(dev, "Maximum TX queues is %d\n",
268 			 vport_config->max_q.max_txq);
269 		err = -EINVAL;
270 		goto unlock_mutex;
271 	}
272 	if (num_req_rx_q > vport_config->max_q.max_rxq) {
273 		dev_info(dev, "Maximum RX queues is %d\n",
274 			 vport_config->max_q.max_rxq);
275 		err = -EINVAL;
276 		goto unlock_mutex;
277 	}
278 
279 	if (num_req_tx_q == num_txq && num_req_rx_q == num_rxq)
280 		goto unlock_mutex;
281 
282 	vport_config->user_config.num_req_tx_qs = num_req_tx_q;
283 	vport_config->user_config.num_req_rx_qs = num_req_rx_q;
284 
285 	err = idpf_initiate_soft_reset(vport, IDPF_SR_Q_CHANGE);
286 	if (err) {
287 		/* roll back queue change */
288 		vport_config->user_config.num_req_tx_qs = num_txq;
289 		vport_config->user_config.num_req_rx_qs = num_rxq;
290 	}
291 
292 unlock_mutex:
293 	idpf_vport_ctrl_unlock(netdev);
294 
295 	return err;
296 }
297 
298 /**
299  * idpf_get_ringparam - Get ring parameters
300  * @netdev: network interface device structure
301  * @ring: ethtool ringparam structure
302  * @kring: unused
303  * @ext_ack: unused
304  *
305  * Returns current ring parameters. TX and RX rings are reported separately,
306  * but the number of rings is not reported.
307  */
308 static void idpf_get_ringparam(struct net_device *netdev,
309 			       struct ethtool_ringparam *ring,
310 			       struct kernel_ethtool_ringparam *kring,
311 			       struct netlink_ext_ack *ext_ack)
312 {
313 	struct idpf_vport *vport;
314 
315 	idpf_vport_ctrl_lock(netdev);
316 	vport = idpf_netdev_to_vport(netdev);
317 
318 	ring->rx_max_pending = IDPF_MAX_RXQ_DESC;
319 	ring->tx_max_pending = IDPF_MAX_TXQ_DESC;
320 	ring->rx_pending = vport->rxq_desc_count;
321 	ring->tx_pending = vport->txq_desc_count;
322 
323 	idpf_vport_ctrl_unlock(netdev);
324 }
325 
326 /**
327  * idpf_set_ringparam - Set ring parameters
328  * @netdev: network interface device structure
329  * @ring: ethtool ringparam structure
330  * @kring: unused
331  * @ext_ack: unused
332  *
333  * Sets ring parameters. TX and RX rings are controlled separately, but the
334  * number of rings is not specified, so all rings get the same settings.
335  */
336 static int idpf_set_ringparam(struct net_device *netdev,
337 			      struct ethtool_ringparam *ring,
338 			      struct kernel_ethtool_ringparam *kring,
339 			      struct netlink_ext_ack *ext_ack)
340 {
341 	struct idpf_vport_user_config_data *config_data;
342 	u32 new_rx_count, new_tx_count;
343 	struct idpf_vport *vport;
344 	int i, err = 0;
345 	u16 idx;
346 
347 	idpf_vport_ctrl_lock(netdev);
348 	vport = idpf_netdev_to_vport(netdev);
349 
350 	idx = vport->idx;
351 
352 	if (ring->tx_pending < IDPF_MIN_TXQ_DESC) {
353 		netdev_err(netdev, "Descriptors requested (Tx: %u) is less than min supported (%u)\n",
354 			   ring->tx_pending,
355 			   IDPF_MIN_TXQ_DESC);
356 		err = -EINVAL;
357 		goto unlock_mutex;
358 	}
359 
360 	if (ring->rx_pending < IDPF_MIN_RXQ_DESC) {
361 		netdev_err(netdev, "Descriptors requested (Rx: %u) is less than min supported (%u)\n",
362 			   ring->rx_pending,
363 			   IDPF_MIN_RXQ_DESC);
364 		err = -EINVAL;
365 		goto unlock_mutex;
366 	}
367 
368 	new_rx_count = ALIGN(ring->rx_pending, IDPF_REQ_RXQ_DESC_MULTIPLE);
369 	if (new_rx_count != ring->rx_pending)
370 		netdev_info(netdev, "Requested Rx descriptor count rounded up to %u\n",
371 			    new_rx_count);
372 
373 	new_tx_count = ALIGN(ring->tx_pending, IDPF_REQ_DESC_MULTIPLE);
374 	if (new_tx_count != ring->tx_pending)
375 		netdev_info(netdev, "Requested Tx descriptor count rounded up to %u\n",
376 			    new_tx_count);
377 
378 	if (new_tx_count == vport->txq_desc_count &&
379 	    new_rx_count == vport->rxq_desc_count)
380 		goto unlock_mutex;
381 
382 	config_data = &vport->adapter->vport_config[idx]->user_config;
383 	config_data->num_req_txq_desc = new_tx_count;
384 	config_data->num_req_rxq_desc = new_rx_count;
385 
386 	/* Since we adjusted the RX completion queue count, the RX buffer queue
387 	 * descriptor count needs to be adjusted as well
388 	 */
389 	for (i = 0; i < vport->num_bufqs_per_qgrp; i++)
390 		vport->bufq_desc_count[i] =
391 			IDPF_RX_BUFQ_DESC_COUNT(new_rx_count,
392 						vport->num_bufqs_per_qgrp);
393 
394 	err = idpf_initiate_soft_reset(vport, IDPF_SR_Q_DESC_CHANGE);
395 
396 unlock_mutex:
397 	idpf_vport_ctrl_unlock(netdev);
398 
399 	return err;
400 }
401 
402 /**
403  * struct idpf_stats - definition for an ethtool statistic
404  * @stat_string: statistic name to display in ethtool -S output
405  * @sizeof_stat: the sizeof() the stat, must be no greater than sizeof(u64)
406  * @stat_offset: offsetof() the stat from a base pointer
407  *
408  * This structure defines a statistic to be added to the ethtool stats buffer.
409  * It defines a statistic as offset from a common base pointer. Stats should
410  * be defined in constant arrays using the IDPF_STAT macro, with every element
411  * of the array using the same _type for calculating the sizeof_stat and
412  * stat_offset.
413  *
414  * The @sizeof_stat is expected to be sizeof(u8), sizeof(u16), sizeof(u32) or
415  * sizeof(u64). Other sizes are not expected and will produce a WARN_ONCE from
416  * the idpf_add_ethtool_stat() helper function.
417  *
418  * The @stat_string is interpreted as a format string, allowing formatted
419  * values to be inserted while looping over multiple structures for a given
420  * statistics array. Thus, every statistic string in an array should have the
421  * same type and number of format specifiers, to be formatted by variadic
422  * arguments to the idpf_add_stat_string() helper function.
423  */
424 struct idpf_stats {
425 	char stat_string[ETH_GSTRING_LEN];
426 	int sizeof_stat;
427 	int stat_offset;
428 };
429 
430 /* Helper macro to define an idpf_stat structure with proper size and type.
431  * Use this when defining constant statistics arrays. Note that @_type expects
432  * only a type name and is used multiple times.
433  */
434 #define IDPF_STAT(_type, _name, _stat) { \
435 	.stat_string = _name, \
436 	.sizeof_stat = sizeof_field(_type, _stat), \
437 	.stat_offset = offsetof(_type, _stat) \
438 }
439 
440 /* Helper macro for defining some statistics related to queues */
441 #define IDPF_QUEUE_STAT(_name, _stat) \
442 	IDPF_STAT(struct idpf_queue, _name, _stat)
443 
444 /* Stats associated with a Tx queue */
445 static const struct idpf_stats idpf_gstrings_tx_queue_stats[] = {
446 	IDPF_QUEUE_STAT("pkts", q_stats.tx.packets),
447 	IDPF_QUEUE_STAT("bytes", q_stats.tx.bytes),
448 	IDPF_QUEUE_STAT("lso_pkts", q_stats.tx.lso_pkts),
449 };
450 
451 /* Stats associated with an Rx queue */
452 static const struct idpf_stats idpf_gstrings_rx_queue_stats[] = {
453 	IDPF_QUEUE_STAT("pkts", q_stats.rx.packets),
454 	IDPF_QUEUE_STAT("bytes", q_stats.rx.bytes),
455 	IDPF_QUEUE_STAT("rx_gro_hw_pkts", q_stats.rx.rsc_pkts),
456 };
457 
458 #define IDPF_TX_QUEUE_STATS_LEN		ARRAY_SIZE(idpf_gstrings_tx_queue_stats)
459 #define IDPF_RX_QUEUE_STATS_LEN		ARRAY_SIZE(idpf_gstrings_rx_queue_stats)
460 
461 #define IDPF_PORT_STAT(_name, _stat) \
462 	IDPF_STAT(struct idpf_vport,  _name, _stat)
463 
464 static const struct idpf_stats idpf_gstrings_port_stats[] = {
465 	IDPF_PORT_STAT("rx-csum_errors", port_stats.rx_hw_csum_err),
466 	IDPF_PORT_STAT("rx-hsplit", port_stats.rx_hsplit),
467 	IDPF_PORT_STAT("rx-hsplit_hbo", port_stats.rx_hsplit_hbo),
468 	IDPF_PORT_STAT("rx-bad_descs", port_stats.rx_bad_descs),
469 	IDPF_PORT_STAT("tx-skb_drops", port_stats.tx_drops),
470 	IDPF_PORT_STAT("tx-dma_map_errs", port_stats.tx_dma_map_errs),
471 	IDPF_PORT_STAT("tx-linearized_pkts", port_stats.tx_linearize),
472 	IDPF_PORT_STAT("tx-busy_events", port_stats.tx_busy),
473 	IDPF_PORT_STAT("rx-unicast_pkts", port_stats.vport_stats.rx_unicast),
474 	IDPF_PORT_STAT("rx-multicast_pkts", port_stats.vport_stats.rx_multicast),
475 	IDPF_PORT_STAT("rx-broadcast_pkts", port_stats.vport_stats.rx_broadcast),
476 	IDPF_PORT_STAT("rx-unknown_protocol", port_stats.vport_stats.rx_unknown_protocol),
477 	IDPF_PORT_STAT("tx-unicast_pkts", port_stats.vport_stats.tx_unicast),
478 	IDPF_PORT_STAT("tx-multicast_pkts", port_stats.vport_stats.tx_multicast),
479 	IDPF_PORT_STAT("tx-broadcast_pkts", port_stats.vport_stats.tx_broadcast),
480 };
481 
482 #define IDPF_PORT_STATS_LEN ARRAY_SIZE(idpf_gstrings_port_stats)
483 
484 /**
485  * __idpf_add_qstat_strings - copy stat strings into ethtool buffer
486  * @p: ethtool supplied buffer
487  * @stats: stat definitions array
488  * @size: size of the stats array
489  * @type: stat type
490  * @idx: stat index
491  *
492  * Format and copy the strings described by stats into the buffer pointed at
493  * by p.
494  */
495 static void __idpf_add_qstat_strings(u8 **p, const struct idpf_stats *stats,
496 				     const unsigned int size, const char *type,
497 				     unsigned int idx)
498 {
499 	unsigned int i;
500 
501 	for (i = 0; i < size; i++)
502 		ethtool_sprintf(p, "%s_q-%u_%s",
503 				type, idx, stats[i].stat_string);
504 }
505 
506 /**
507  * idpf_add_qstat_strings - Copy queue stat strings into ethtool buffer
508  * @p: ethtool supplied buffer
509  * @stats: stat definitions array
510  * @type: stat type
511  * @idx: stat idx
512  *
513  * Format and copy the strings described by the const static stats value into
514  * the buffer pointed at by p.
515  *
516  * The parameter @stats is evaluated twice, so parameters with side effects
517  * should be avoided. Additionally, stats must be an array such that
518  * ARRAY_SIZE can be called on it.
519  */
520 #define idpf_add_qstat_strings(p, stats, type, idx) \
521 	__idpf_add_qstat_strings(p, stats, ARRAY_SIZE(stats), type, idx)
522 
523 /**
524  * idpf_add_stat_strings - Copy port stat strings into ethtool buffer
525  * @p: ethtool buffer
526  * @stats: struct to copy from
527  * @size: size of stats array to copy from
528  */
529 static void idpf_add_stat_strings(u8 **p, const struct idpf_stats *stats,
530 				  const unsigned int size)
531 {
532 	unsigned int i;
533 
534 	for (i = 0; i < size; i++)
535 		ethtool_sprintf(p, "%s", stats[i].stat_string);
536 }
537 
538 /**
539  * idpf_get_stat_strings - Get stat strings
540  * @netdev: network interface device structure
541  * @data: buffer for string data
542  *
543  * Builds the statistics string table
544  */
545 static void idpf_get_stat_strings(struct net_device *netdev, u8 *data)
546 {
547 	struct idpf_netdev_priv *np = netdev_priv(netdev);
548 	struct idpf_vport_config *vport_config;
549 	unsigned int i;
550 
551 	idpf_add_stat_strings(&data, idpf_gstrings_port_stats,
552 			      IDPF_PORT_STATS_LEN);
553 
554 	vport_config = np->adapter->vport_config[np->vport_idx];
555 	/* It's critical that we always report a constant number of strings and
556 	 * that the strings are reported in the same order regardless of how
557 	 * many queues are actually in use.
558 	 */
559 	for (i = 0; i < vport_config->max_q.max_txq; i++)
560 		idpf_add_qstat_strings(&data, idpf_gstrings_tx_queue_stats,
561 				       "tx", i);
562 
563 	for (i = 0; i < vport_config->max_q.max_rxq; i++)
564 		idpf_add_qstat_strings(&data, idpf_gstrings_rx_queue_stats,
565 				       "rx", i);
566 
567 	page_pool_ethtool_stats_get_strings(data);
568 }
569 
570 /**
571  * idpf_get_strings - Get string set
572  * @netdev: network interface device structure
573  * @sset: id of string set
574  * @data: buffer for string data
575  *
576  * Builds string tables for various string sets
577  */
578 static void idpf_get_strings(struct net_device *netdev, u32 sset, u8 *data)
579 {
580 	switch (sset) {
581 	case ETH_SS_STATS:
582 		idpf_get_stat_strings(netdev, data);
583 		break;
584 	default:
585 		break;
586 	}
587 }
588 
589 /**
590  * idpf_get_sset_count - Get length of string set
591  * @netdev: network interface device structure
592  * @sset: id of string set
593  *
594  * Reports size of various string tables.
595  */
596 static int idpf_get_sset_count(struct net_device *netdev, int sset)
597 {
598 	struct idpf_netdev_priv *np = netdev_priv(netdev);
599 	struct idpf_vport_config *vport_config;
600 	u16 max_txq, max_rxq;
601 	unsigned int size;
602 
603 	if (sset != ETH_SS_STATS)
604 		return -EINVAL;
605 
606 	vport_config = np->adapter->vport_config[np->vport_idx];
607 	/* This size reported back here *must* be constant throughout the
608 	 * lifecycle of the netdevice, i.e. we must report the maximum length
609 	 * even for queues that don't technically exist.  This is due to the
610 	 * fact that this userspace API uses three separate ioctl calls to get
611 	 * stats data but has no way to communicate back to userspace when that
612 	 * size has changed, which can typically happen as a result of changing
613 	 * number of queues. If the number/order of stats change in the middle
614 	 * of this call chain it will lead to userspace crashing/accessing bad
615 	 * data through buffer under/overflow.
616 	 */
617 	max_txq = vport_config->max_q.max_txq;
618 	max_rxq = vport_config->max_q.max_rxq;
619 
620 	size = IDPF_PORT_STATS_LEN + (IDPF_TX_QUEUE_STATS_LEN * max_txq) +
621 	       (IDPF_RX_QUEUE_STATS_LEN * max_rxq);
622 	size += page_pool_ethtool_stats_get_count();
623 
624 	return size;
625 }
626 
627 /**
628  * idpf_add_one_ethtool_stat - copy the stat into the supplied buffer
629  * @data: location to store the stat value
630  * @pstat: old stat pointer to copy from
631  * @stat: the stat definition
632  *
633  * Copies the stat data defined by the pointer and stat structure pair into
634  * the memory supplied as data. If the pointer is null, data will be zero'd.
635  */
636 static void idpf_add_one_ethtool_stat(u64 *data, void *pstat,
637 				      const struct idpf_stats *stat)
638 {
639 	char *p;
640 
641 	if (!pstat) {
642 		/* Ensure that the ethtool data buffer is zero'd for any stats
643 		 * which don't have a valid pointer.
644 		 */
645 		*data = 0;
646 		return;
647 	}
648 
649 	p = (char *)pstat + stat->stat_offset;
650 	switch (stat->sizeof_stat) {
651 	case sizeof(u64):
652 		*data = *((u64 *)p);
653 		break;
654 	case sizeof(u32):
655 		*data = *((u32 *)p);
656 		break;
657 	case sizeof(u16):
658 		*data = *((u16 *)p);
659 		break;
660 	case sizeof(u8):
661 		*data = *((u8 *)p);
662 		break;
663 	default:
664 		WARN_ONCE(1, "unexpected stat size for %s",
665 			  stat->stat_string);
666 		*data = 0;
667 	}
668 }
669 
670 /**
671  * idpf_add_queue_stats - copy queue statistics into supplied buffer
672  * @data: ethtool stats buffer
673  * @q: the queue to copy
674  *
675  * Queue statistics must be copied while protected by u64_stats_fetch_begin,
676  * so we can't directly use idpf_add_ethtool_stats. Assumes that queue stats
677  * are defined in idpf_gstrings_queue_stats. If the queue pointer is null,
678  * zero out the queue stat values and update the data pointer. Otherwise
679  * safely copy the stats from the queue into the supplied buffer and update
680  * the data pointer when finished.
681  *
682  * This function expects to be called while under rcu_read_lock().
683  */
684 static void idpf_add_queue_stats(u64 **data, struct idpf_queue *q)
685 {
686 	const struct idpf_stats *stats;
687 	unsigned int start;
688 	unsigned int size;
689 	unsigned int i;
690 
691 	if (q->q_type == VIRTCHNL2_QUEUE_TYPE_RX) {
692 		size = IDPF_RX_QUEUE_STATS_LEN;
693 		stats = idpf_gstrings_rx_queue_stats;
694 	} else {
695 		size = IDPF_TX_QUEUE_STATS_LEN;
696 		stats = idpf_gstrings_tx_queue_stats;
697 	}
698 
699 	/* To avoid invalid statistics values, ensure that we keep retrying
700 	 * the copy until we get a consistent value according to
701 	 * u64_stats_fetch_retry.
702 	 */
703 	do {
704 		start = u64_stats_fetch_begin(&q->stats_sync);
705 		for (i = 0; i < size; i++)
706 			idpf_add_one_ethtool_stat(&(*data)[i], q, &stats[i]);
707 	} while (u64_stats_fetch_retry(&q->stats_sync, start));
708 
709 	/* Once we successfully copy the stats in, update the data pointer */
710 	*data += size;
711 }
712 
713 /**
714  * idpf_add_empty_queue_stats - Add stats for a non-existent queue
715  * @data: pointer to data buffer
716  * @qtype: type of data queue
717  *
718  * We must report a constant length of stats back to userspace regardless of
719  * how many queues are actually in use because stats collection happens over
720  * three separate ioctls and there's no way to notify userspace the size
721  * changed between those calls. This adds empty to data to the stats since we
722  * don't have a real queue to refer to for this stats slot.
723  */
724 static void idpf_add_empty_queue_stats(u64 **data, u16 qtype)
725 {
726 	unsigned int i;
727 	int stats_len;
728 
729 	if (qtype == VIRTCHNL2_QUEUE_TYPE_RX)
730 		stats_len = IDPF_RX_QUEUE_STATS_LEN;
731 	else
732 		stats_len = IDPF_TX_QUEUE_STATS_LEN;
733 
734 	for (i = 0; i < stats_len; i++)
735 		(*data)[i] = 0;
736 	*data += stats_len;
737 }
738 
739 /**
740  * idpf_add_port_stats - Copy port stats into ethtool buffer
741  * @vport: virtual port struct
742  * @data: ethtool buffer to copy into
743  */
744 static void idpf_add_port_stats(struct idpf_vport *vport, u64 **data)
745 {
746 	unsigned int size = IDPF_PORT_STATS_LEN;
747 	unsigned int start;
748 	unsigned int i;
749 
750 	do {
751 		start = u64_stats_fetch_begin(&vport->port_stats.stats_sync);
752 		for (i = 0; i < size; i++)
753 			idpf_add_one_ethtool_stat(&(*data)[i], vport,
754 						  &idpf_gstrings_port_stats[i]);
755 	} while (u64_stats_fetch_retry(&vport->port_stats.stats_sync, start));
756 
757 	*data += size;
758 }
759 
760 /**
761  * idpf_collect_queue_stats - accumulate various per queue stats
762  * into port level stats
763  * @vport: pointer to vport struct
764  **/
765 static void idpf_collect_queue_stats(struct idpf_vport *vport)
766 {
767 	struct idpf_port_stats *pstats = &vport->port_stats;
768 	int i, j;
769 
770 	/* zero out port stats since they're actually tracked in per
771 	 * queue stats; this is only for reporting
772 	 */
773 	u64_stats_update_begin(&pstats->stats_sync);
774 	u64_stats_set(&pstats->rx_hw_csum_err, 0);
775 	u64_stats_set(&pstats->rx_hsplit, 0);
776 	u64_stats_set(&pstats->rx_hsplit_hbo, 0);
777 	u64_stats_set(&pstats->rx_bad_descs, 0);
778 	u64_stats_set(&pstats->tx_linearize, 0);
779 	u64_stats_set(&pstats->tx_busy, 0);
780 	u64_stats_set(&pstats->tx_drops, 0);
781 	u64_stats_set(&pstats->tx_dma_map_errs, 0);
782 	u64_stats_update_end(&pstats->stats_sync);
783 
784 	for (i = 0; i < vport->num_rxq_grp; i++) {
785 		struct idpf_rxq_group *rxq_grp = &vport->rxq_grps[i];
786 		u16 num_rxq;
787 
788 		if (idpf_is_queue_model_split(vport->rxq_model))
789 			num_rxq = rxq_grp->splitq.num_rxq_sets;
790 		else
791 			num_rxq = rxq_grp->singleq.num_rxq;
792 
793 		for (j = 0; j < num_rxq; j++) {
794 			u64 hw_csum_err, hsplit, hsplit_hbo, bad_descs;
795 			struct idpf_rx_queue_stats *stats;
796 			struct idpf_queue *rxq;
797 			unsigned int start;
798 
799 			if (idpf_is_queue_model_split(vport->rxq_model))
800 				rxq = &rxq_grp->splitq.rxq_sets[j]->rxq;
801 			else
802 				rxq = rxq_grp->singleq.rxqs[j];
803 
804 			if (!rxq)
805 				continue;
806 
807 			do {
808 				start = u64_stats_fetch_begin(&rxq->stats_sync);
809 
810 				stats = &rxq->q_stats.rx;
811 				hw_csum_err = u64_stats_read(&stats->hw_csum_err);
812 				hsplit = u64_stats_read(&stats->hsplit_pkts);
813 				hsplit_hbo = u64_stats_read(&stats->hsplit_buf_ovf);
814 				bad_descs = u64_stats_read(&stats->bad_descs);
815 			} while (u64_stats_fetch_retry(&rxq->stats_sync, start));
816 
817 			u64_stats_update_begin(&pstats->stats_sync);
818 			u64_stats_add(&pstats->rx_hw_csum_err, hw_csum_err);
819 			u64_stats_add(&pstats->rx_hsplit, hsplit);
820 			u64_stats_add(&pstats->rx_hsplit_hbo, hsplit_hbo);
821 			u64_stats_add(&pstats->rx_bad_descs, bad_descs);
822 			u64_stats_update_end(&pstats->stats_sync);
823 		}
824 	}
825 
826 	for (i = 0; i < vport->num_txq_grp; i++) {
827 		struct idpf_txq_group *txq_grp = &vport->txq_grps[i];
828 
829 		for (j = 0; j < txq_grp->num_txq; j++) {
830 			u64 linearize, qbusy, skb_drops, dma_map_errs;
831 			struct idpf_queue *txq = txq_grp->txqs[j];
832 			struct idpf_tx_queue_stats *stats;
833 			unsigned int start;
834 
835 			if (!txq)
836 				continue;
837 
838 			do {
839 				start = u64_stats_fetch_begin(&txq->stats_sync);
840 
841 				stats = &txq->q_stats.tx;
842 				linearize = u64_stats_read(&stats->linearize);
843 				qbusy = u64_stats_read(&stats->q_busy);
844 				skb_drops = u64_stats_read(&stats->skb_drops);
845 				dma_map_errs = u64_stats_read(&stats->dma_map_errs);
846 			} while (u64_stats_fetch_retry(&txq->stats_sync, start));
847 
848 			u64_stats_update_begin(&pstats->stats_sync);
849 			u64_stats_add(&pstats->tx_linearize, linearize);
850 			u64_stats_add(&pstats->tx_busy, qbusy);
851 			u64_stats_add(&pstats->tx_drops, skb_drops);
852 			u64_stats_add(&pstats->tx_dma_map_errs, dma_map_errs);
853 			u64_stats_update_end(&pstats->stats_sync);
854 		}
855 	}
856 }
857 
858 /**
859  * idpf_get_ethtool_stats - report device statistics
860  * @netdev: network interface device structure
861  * @stats: ethtool statistics structure
862  * @data: pointer to data buffer
863  *
864  * All statistics are added to the data buffer as an array of u64.
865  */
866 static void idpf_get_ethtool_stats(struct net_device *netdev,
867 				   struct ethtool_stats __always_unused *stats,
868 				   u64 *data)
869 {
870 	struct idpf_netdev_priv *np = netdev_priv(netdev);
871 	struct idpf_vport_config *vport_config;
872 	struct page_pool_stats pp_stats = { };
873 	struct idpf_vport *vport;
874 	unsigned int total = 0;
875 	unsigned int i, j;
876 	bool is_splitq;
877 	u16 qtype;
878 
879 	idpf_vport_ctrl_lock(netdev);
880 	vport = idpf_netdev_to_vport(netdev);
881 
882 	if (np->state != __IDPF_VPORT_UP) {
883 		idpf_vport_ctrl_unlock(netdev);
884 
885 		return;
886 	}
887 
888 	rcu_read_lock();
889 
890 	idpf_collect_queue_stats(vport);
891 	idpf_add_port_stats(vport, &data);
892 
893 	for (i = 0; i < vport->num_txq_grp; i++) {
894 		struct idpf_txq_group *txq_grp = &vport->txq_grps[i];
895 
896 		qtype = VIRTCHNL2_QUEUE_TYPE_TX;
897 
898 		for (j = 0; j < txq_grp->num_txq; j++, total++) {
899 			struct idpf_queue *txq = txq_grp->txqs[j];
900 
901 			if (!txq)
902 				idpf_add_empty_queue_stats(&data, qtype);
903 			else
904 				idpf_add_queue_stats(&data, txq);
905 		}
906 	}
907 
908 	vport_config = vport->adapter->vport_config[vport->idx];
909 	/* It is critical we provide a constant number of stats back to
910 	 * userspace regardless of how many queues are actually in use because
911 	 * there is no way to inform userspace the size has changed between
912 	 * ioctl calls. This will fill in any missing stats with zero.
913 	 */
914 	for (; total < vport_config->max_q.max_txq; total++)
915 		idpf_add_empty_queue_stats(&data, VIRTCHNL2_QUEUE_TYPE_TX);
916 	total = 0;
917 
918 	is_splitq = idpf_is_queue_model_split(vport->rxq_model);
919 
920 	for (i = 0; i < vport->num_rxq_grp; i++) {
921 		struct idpf_rxq_group *rxq_grp = &vport->rxq_grps[i];
922 		u16 num_rxq;
923 
924 		qtype = VIRTCHNL2_QUEUE_TYPE_RX;
925 
926 		if (is_splitq)
927 			num_rxq = rxq_grp->splitq.num_rxq_sets;
928 		else
929 			num_rxq = rxq_grp->singleq.num_rxq;
930 
931 		for (j = 0; j < num_rxq; j++, total++) {
932 			struct idpf_queue *rxq;
933 
934 			if (is_splitq)
935 				rxq = &rxq_grp->splitq.rxq_sets[j]->rxq;
936 			else
937 				rxq = rxq_grp->singleq.rxqs[j];
938 			if (!rxq)
939 				idpf_add_empty_queue_stats(&data, qtype);
940 			else
941 				idpf_add_queue_stats(&data, rxq);
942 
943 			/* In splitq mode, don't get page pool stats here since
944 			 * the pools are attached to the buffer queues
945 			 */
946 			if (is_splitq)
947 				continue;
948 
949 			if (rxq)
950 				page_pool_get_stats(rxq->pp, &pp_stats);
951 		}
952 	}
953 
954 	for (i = 0; i < vport->num_rxq_grp; i++) {
955 		for (j = 0; j < vport->num_bufqs_per_qgrp; j++) {
956 			struct idpf_queue *rxbufq =
957 				&vport->rxq_grps[i].splitq.bufq_sets[j].bufq;
958 
959 			page_pool_get_stats(rxbufq->pp, &pp_stats);
960 		}
961 	}
962 
963 	for (; total < vport_config->max_q.max_rxq; total++)
964 		idpf_add_empty_queue_stats(&data, VIRTCHNL2_QUEUE_TYPE_RX);
965 
966 	page_pool_ethtool_stats_get(data, &pp_stats);
967 
968 	rcu_read_unlock();
969 
970 	idpf_vport_ctrl_unlock(netdev);
971 }
972 
973 /**
974  * idpf_find_rxq - find rxq from q index
975  * @vport: virtual port associated to queue
976  * @q_num: q index used to find queue
977  *
978  * returns pointer to rx queue
979  */
980 static struct idpf_queue *idpf_find_rxq(struct idpf_vport *vport, int q_num)
981 {
982 	int q_grp, q_idx;
983 
984 	if (!idpf_is_queue_model_split(vport->rxq_model))
985 		return vport->rxq_grps->singleq.rxqs[q_num];
986 
987 	q_grp = q_num / IDPF_DFLT_SPLITQ_RXQ_PER_GROUP;
988 	q_idx = q_num % IDPF_DFLT_SPLITQ_RXQ_PER_GROUP;
989 
990 	return &vport->rxq_grps[q_grp].splitq.rxq_sets[q_idx]->rxq;
991 }
992 
993 /**
994  * idpf_find_txq - find txq from q index
995  * @vport: virtual port associated to queue
996  * @q_num: q index used to find queue
997  *
998  * returns pointer to tx queue
999  */
1000 static struct idpf_queue *idpf_find_txq(struct idpf_vport *vport, int q_num)
1001 {
1002 	int q_grp;
1003 
1004 	if (!idpf_is_queue_model_split(vport->txq_model))
1005 		return vport->txqs[q_num];
1006 
1007 	q_grp = q_num / IDPF_DFLT_SPLITQ_TXQ_PER_GROUP;
1008 
1009 	return vport->txq_grps[q_grp].complq;
1010 }
1011 
1012 /**
1013  * __idpf_get_q_coalesce - get ITR values for specific queue
1014  * @ec: ethtool structure to fill with driver's coalesce settings
1015  * @q: quuee of Rx or Tx
1016  */
1017 static void __idpf_get_q_coalesce(struct ethtool_coalesce *ec,
1018 				  struct idpf_queue *q)
1019 {
1020 	if (q->q_type == VIRTCHNL2_QUEUE_TYPE_RX) {
1021 		ec->use_adaptive_rx_coalesce =
1022 				IDPF_ITR_IS_DYNAMIC(q->q_vector->rx_intr_mode);
1023 		ec->rx_coalesce_usecs = q->q_vector->rx_itr_value;
1024 	} else {
1025 		ec->use_adaptive_tx_coalesce =
1026 				IDPF_ITR_IS_DYNAMIC(q->q_vector->tx_intr_mode);
1027 		ec->tx_coalesce_usecs = q->q_vector->tx_itr_value;
1028 	}
1029 }
1030 
1031 /**
1032  * idpf_get_q_coalesce - get ITR values for specific queue
1033  * @netdev: pointer to the netdev associated with this query
1034  * @ec: coalesce settings to program the device with
1035  * @q_num: update ITR/INTRL (coalesce) settings for this queue number/index
1036  *
1037  * Return 0 on success, and negative on failure
1038  */
1039 static int idpf_get_q_coalesce(struct net_device *netdev,
1040 			       struct ethtool_coalesce *ec,
1041 			       u32 q_num)
1042 {
1043 	struct idpf_netdev_priv *np = netdev_priv(netdev);
1044 	struct idpf_vport *vport;
1045 	int err = 0;
1046 
1047 	idpf_vport_ctrl_lock(netdev);
1048 	vport = idpf_netdev_to_vport(netdev);
1049 
1050 	if (np->state != __IDPF_VPORT_UP)
1051 		goto unlock_mutex;
1052 
1053 	if (q_num >= vport->num_rxq && q_num >= vport->num_txq) {
1054 		err = -EINVAL;
1055 		goto unlock_mutex;
1056 	}
1057 
1058 	if (q_num < vport->num_rxq)
1059 		__idpf_get_q_coalesce(ec, idpf_find_rxq(vport, q_num));
1060 
1061 	if (q_num < vport->num_txq)
1062 		__idpf_get_q_coalesce(ec, idpf_find_txq(vport, q_num));
1063 
1064 unlock_mutex:
1065 	idpf_vport_ctrl_unlock(netdev);
1066 
1067 	return err;
1068 }
1069 
1070 /**
1071  * idpf_get_coalesce - get ITR values as requested by user
1072  * @netdev: pointer to the netdev associated with this query
1073  * @ec: coalesce settings to be filled
1074  * @kec: unused
1075  * @extack: unused
1076  *
1077  * Return 0 on success, and negative on failure
1078  */
1079 static int idpf_get_coalesce(struct net_device *netdev,
1080 			     struct ethtool_coalesce *ec,
1081 			     struct kernel_ethtool_coalesce *kec,
1082 			     struct netlink_ext_ack *extack)
1083 {
1084 	/* Return coalesce based on queue number zero */
1085 	return idpf_get_q_coalesce(netdev, ec, 0);
1086 }
1087 
1088 /**
1089  * idpf_get_per_q_coalesce - get ITR values as requested by user
1090  * @netdev: pointer to the netdev associated with this query
1091  * @q_num: queue for which the itr values has to retrieved
1092  * @ec: coalesce settings to be filled
1093  *
1094  * Return 0 on success, and negative on failure
1095  */
1096 
1097 static int idpf_get_per_q_coalesce(struct net_device *netdev, u32 q_num,
1098 				   struct ethtool_coalesce *ec)
1099 {
1100 	return idpf_get_q_coalesce(netdev, ec, q_num);
1101 }
1102 
1103 /**
1104  * __idpf_set_q_coalesce - set ITR values for specific queue
1105  * @ec: ethtool structure from user to update ITR settings
1106  * @q: queue for which itr values has to be set
1107  * @is_rxq: is queue type rx
1108  *
1109  * Returns 0 on success, negative otherwise.
1110  */
1111 static int __idpf_set_q_coalesce(struct ethtool_coalesce *ec,
1112 				 struct idpf_queue *q, bool is_rxq)
1113 {
1114 	u32 use_adaptive_coalesce, coalesce_usecs;
1115 	struct idpf_q_vector *qv = q->q_vector;
1116 	bool is_dim_ena = false;
1117 	u16 itr_val;
1118 
1119 	if (is_rxq) {
1120 		is_dim_ena = IDPF_ITR_IS_DYNAMIC(qv->rx_intr_mode);
1121 		use_adaptive_coalesce = ec->use_adaptive_rx_coalesce;
1122 		coalesce_usecs = ec->rx_coalesce_usecs;
1123 		itr_val = qv->rx_itr_value;
1124 	} else {
1125 		is_dim_ena = IDPF_ITR_IS_DYNAMIC(qv->tx_intr_mode);
1126 		use_adaptive_coalesce = ec->use_adaptive_tx_coalesce;
1127 		coalesce_usecs = ec->tx_coalesce_usecs;
1128 		itr_val = qv->tx_itr_value;
1129 	}
1130 	if (coalesce_usecs != itr_val && use_adaptive_coalesce) {
1131 		netdev_err(q->vport->netdev, "Cannot set coalesce usecs if adaptive enabled\n");
1132 
1133 		return -EINVAL;
1134 	}
1135 
1136 	if (is_dim_ena && use_adaptive_coalesce)
1137 		return 0;
1138 
1139 	if (coalesce_usecs > IDPF_ITR_MAX) {
1140 		netdev_err(q->vport->netdev,
1141 			   "Invalid value, %d-usecs range is 0-%d\n",
1142 			   coalesce_usecs, IDPF_ITR_MAX);
1143 
1144 		return -EINVAL;
1145 	}
1146 
1147 	if (coalesce_usecs % 2) {
1148 		coalesce_usecs--;
1149 		netdev_info(q->vport->netdev,
1150 			    "HW only supports even ITR values, ITR rounded to %d\n",
1151 			    coalesce_usecs);
1152 	}
1153 
1154 	if (is_rxq) {
1155 		qv->rx_itr_value = coalesce_usecs;
1156 		if (use_adaptive_coalesce) {
1157 			qv->rx_intr_mode = IDPF_ITR_DYNAMIC;
1158 		} else {
1159 			qv->rx_intr_mode = !IDPF_ITR_DYNAMIC;
1160 			idpf_vport_intr_write_itr(qv, qv->rx_itr_value,
1161 						  false);
1162 		}
1163 	} else {
1164 		qv->tx_itr_value = coalesce_usecs;
1165 		if (use_adaptive_coalesce) {
1166 			qv->tx_intr_mode = IDPF_ITR_DYNAMIC;
1167 		} else {
1168 			qv->tx_intr_mode = !IDPF_ITR_DYNAMIC;
1169 			idpf_vport_intr_write_itr(qv, qv->tx_itr_value, true);
1170 		}
1171 	}
1172 
1173 	/* Update of static/dynamic itr will be taken care when interrupt is
1174 	 * fired
1175 	 */
1176 	return 0;
1177 }
1178 
1179 /**
1180  * idpf_set_q_coalesce - set ITR values for specific queue
1181  * @vport: vport associated to the queue that need updating
1182  * @ec: coalesce settings to program the device with
1183  * @q_num: update ITR/INTRL (coalesce) settings for this queue number/index
1184  * @is_rxq: is queue type rx
1185  *
1186  * Return 0 on success, and negative on failure
1187  */
1188 static int idpf_set_q_coalesce(struct idpf_vport *vport,
1189 			       struct ethtool_coalesce *ec,
1190 			       int q_num, bool is_rxq)
1191 {
1192 	struct idpf_queue *q;
1193 
1194 	q = is_rxq ? idpf_find_rxq(vport, q_num) : idpf_find_txq(vport, q_num);
1195 
1196 	if (q && __idpf_set_q_coalesce(ec, q, is_rxq))
1197 		return -EINVAL;
1198 
1199 	return 0;
1200 }
1201 
1202 /**
1203  * idpf_set_coalesce - set ITR values as requested by user
1204  * @netdev: pointer to the netdev associated with this query
1205  * @ec: coalesce settings to program the device with
1206  * @kec: unused
1207  * @extack: unused
1208  *
1209  * Return 0 on success, and negative on failure
1210  */
1211 static int idpf_set_coalesce(struct net_device *netdev,
1212 			     struct ethtool_coalesce *ec,
1213 			     struct kernel_ethtool_coalesce *kec,
1214 			     struct netlink_ext_ack *extack)
1215 {
1216 	struct idpf_netdev_priv *np = netdev_priv(netdev);
1217 	struct idpf_vport *vport;
1218 	int i, err = 0;
1219 
1220 	idpf_vport_ctrl_lock(netdev);
1221 	vport = idpf_netdev_to_vport(netdev);
1222 
1223 	if (np->state != __IDPF_VPORT_UP)
1224 		goto unlock_mutex;
1225 
1226 	for (i = 0; i < vport->num_txq; i++) {
1227 		err = idpf_set_q_coalesce(vport, ec, i, false);
1228 		if (err)
1229 			goto unlock_mutex;
1230 	}
1231 
1232 	for (i = 0; i < vport->num_rxq; i++) {
1233 		err = idpf_set_q_coalesce(vport, ec, i, true);
1234 		if (err)
1235 			goto unlock_mutex;
1236 	}
1237 
1238 unlock_mutex:
1239 	idpf_vport_ctrl_unlock(netdev);
1240 
1241 	return err;
1242 }
1243 
1244 /**
1245  * idpf_set_per_q_coalesce - set ITR values as requested by user
1246  * @netdev: pointer to the netdev associated with this query
1247  * @q_num: queue for which the itr values has to be set
1248  * @ec: coalesce settings to program the device with
1249  *
1250  * Return 0 on success, and negative on failure
1251  */
1252 static int idpf_set_per_q_coalesce(struct net_device *netdev, u32 q_num,
1253 				   struct ethtool_coalesce *ec)
1254 {
1255 	struct idpf_vport *vport;
1256 	int err;
1257 
1258 	idpf_vport_ctrl_lock(netdev);
1259 	vport = idpf_netdev_to_vport(netdev);
1260 
1261 	err = idpf_set_q_coalesce(vport, ec, q_num, false);
1262 	if (err) {
1263 		idpf_vport_ctrl_unlock(netdev);
1264 
1265 		return err;
1266 	}
1267 
1268 	err = idpf_set_q_coalesce(vport, ec, q_num, true);
1269 
1270 	idpf_vport_ctrl_unlock(netdev);
1271 
1272 	return err;
1273 }
1274 
1275 /**
1276  * idpf_get_msglevel - Get debug message level
1277  * @netdev: network interface device structure
1278  *
1279  * Returns current debug message level.
1280  */
1281 static u32 idpf_get_msglevel(struct net_device *netdev)
1282 {
1283 	struct idpf_adapter *adapter = idpf_netdev_to_adapter(netdev);
1284 
1285 	return adapter->msg_enable;
1286 }
1287 
1288 /**
1289  * idpf_set_msglevel - Set debug message level
1290  * @netdev: network interface device structure
1291  * @data: message level
1292  *
1293  * Set current debug message level. Higher values cause the driver to
1294  * be noisier.
1295  */
1296 static void idpf_set_msglevel(struct net_device *netdev, u32 data)
1297 {
1298 	struct idpf_adapter *adapter = idpf_netdev_to_adapter(netdev);
1299 
1300 	adapter->msg_enable = data;
1301 }
1302 
1303 /**
1304  * idpf_get_link_ksettings - Get Link Speed and Duplex settings
1305  * @netdev: network interface device structure
1306  * @cmd: ethtool command
1307  *
1308  * Reports speed/duplex settings.
1309  **/
1310 static int idpf_get_link_ksettings(struct net_device *netdev,
1311 				   struct ethtool_link_ksettings *cmd)
1312 {
1313 	struct idpf_vport *vport;
1314 
1315 	idpf_vport_ctrl_lock(netdev);
1316 	vport = idpf_netdev_to_vport(netdev);
1317 
1318 	ethtool_link_ksettings_zero_link_mode(cmd, supported);
1319 	cmd->base.autoneg = AUTONEG_DISABLE;
1320 	cmd->base.port = PORT_NONE;
1321 	if (vport->link_up) {
1322 		cmd->base.duplex = DUPLEX_FULL;
1323 		cmd->base.speed = vport->link_speed_mbps;
1324 	} else {
1325 		cmd->base.duplex = DUPLEX_UNKNOWN;
1326 		cmd->base.speed = SPEED_UNKNOWN;
1327 	}
1328 
1329 	idpf_vport_ctrl_unlock(netdev);
1330 
1331 	return 0;
1332 }
1333 
1334 static const struct ethtool_ops idpf_ethtool_ops = {
1335 	.supported_coalesce_params = ETHTOOL_COALESCE_USECS |
1336 				     ETHTOOL_COALESCE_USE_ADAPTIVE,
1337 	.get_msglevel		= idpf_get_msglevel,
1338 	.set_msglevel		= idpf_set_msglevel,
1339 	.get_link		= ethtool_op_get_link,
1340 	.get_coalesce		= idpf_get_coalesce,
1341 	.set_coalesce		= idpf_set_coalesce,
1342 	.get_per_queue_coalesce = idpf_get_per_q_coalesce,
1343 	.set_per_queue_coalesce = idpf_set_per_q_coalesce,
1344 	.get_ethtool_stats	= idpf_get_ethtool_stats,
1345 	.get_strings		= idpf_get_strings,
1346 	.get_sset_count		= idpf_get_sset_count,
1347 	.get_channels		= idpf_get_channels,
1348 	.get_rxnfc		= idpf_get_rxnfc,
1349 	.get_rxfh_key_size	= idpf_get_rxfh_key_size,
1350 	.get_rxfh_indir_size	= idpf_get_rxfh_indir_size,
1351 	.get_rxfh		= idpf_get_rxfh,
1352 	.set_rxfh		= idpf_set_rxfh,
1353 	.set_channels		= idpf_set_channels,
1354 	.get_ringparam		= idpf_get_ringparam,
1355 	.set_ringparam		= idpf_set_ringparam,
1356 	.get_link_ksettings	= idpf_get_link_ksettings,
1357 };
1358 
1359 /**
1360  * idpf_set_ethtool_ops - Initialize ethtool ops struct
1361  * @netdev: network interface device structure
1362  *
1363  * Sets ethtool ops struct in our netdev so that ethtool can call
1364  * our functions.
1365  */
1366 void idpf_set_ethtool_ops(struct net_device *netdev)
1367 {
1368 	netdev->ethtool_ops = &idpf_ethtool_ops;
1369 }
1370