Linux Audio

Check our new training course

Loading...
v6.13.7
  1/* SPDX-License-Identifier: GPL-2.0 */
  2/* Copyright (C) 2019-2021, Intel Corporation. */
  3
  4#ifndef _ICE_ESWITCH_H_
  5#define _ICE_ESWITCH_H_
  6
  7#include <net/devlink.h>
  8#include "devlink/devlink_port.h"
  9
 10#ifdef CONFIG_ICE_SWITCHDEV
 11void ice_eswitch_detach_vf(struct ice_pf *pf, struct ice_vf *vf);
 12void ice_eswitch_detach_sf(struct ice_pf *pf, struct ice_dynamic_port *sf);
 13int ice_eswitch_attach_vf(struct ice_pf *pf, struct ice_vf *vf);
 14int ice_eswitch_attach_sf(struct ice_pf *pf, struct ice_dynamic_port *sf);
 15
 16int ice_eswitch_mode_get(struct devlink *devlink, u16 *mode);
 17int
 18ice_eswitch_mode_set(struct devlink *devlink, u16 mode,
 19		     struct netlink_ext_ack *extack);
 20bool ice_is_eswitch_mode_switchdev(struct ice_pf *pf);
 21
 22void ice_eswitch_update_repr(unsigned long *repr_id, struct ice_vsi *vsi);
 23
 24void ice_eswitch_stop_all_tx_queues(struct ice_pf *pf);
 25
 26void ice_eswitch_set_target_vsi(struct sk_buff *skb,
 27				struct ice_tx_offload_params *off);
 28netdev_tx_t
 29ice_eswitch_port_start_xmit(struct sk_buff *skb, struct net_device *netdev);
 30struct net_device *ice_eswitch_get_target(struct ice_rx_ring *rx_ring,
 31					  union ice_32b_rx_flex_desc *rx_desc);
 32
 33int ice_eswitch_cfg_vsi(struct ice_vsi *vsi, const u8 *mac);
 34void ice_eswitch_decfg_vsi(struct ice_vsi *vsi, const u8 *mac);
 35#else /* CONFIG_ICE_SWITCHDEV */
 36static inline void
 37ice_eswitch_detach_vf(struct ice_pf *pf, struct ice_vf *vf) { }
 38
 39static inline void
 40ice_eswitch_detach_sf(struct ice_pf *pf, struct ice_dynamic_port *sf) { }
 41
 42static inline int
 43ice_eswitch_attach_vf(struct ice_pf *pf, struct ice_vf *vf)
 44{
 45	return -EOPNOTSUPP;
 46}
 47
 48static inline int
 49ice_eswitch_attach_sf(struct ice_pf *pf, struct ice_dynamic_port *sf)
 50{
 51	return -EOPNOTSUPP;
 52}
 53
 54static inline void ice_eswitch_stop_all_tx_queues(struct ice_pf *pf) { }
 55
 56static inline void
 57ice_eswitch_set_target_vsi(struct sk_buff *skb,
 58			   struct ice_tx_offload_params *off) { }
 59
 60static inline void
 61ice_eswitch_update_repr(unsigned long *repr_id, struct ice_vsi *vsi) { }
 
 
 
 
 
 
 
 
 
 
 62
 63static inline int ice_eswitch_mode_get(struct devlink *devlink, u16 *mode)
 64{
 65	return DEVLINK_ESWITCH_MODE_LEGACY;
 66}
 67
 68static inline int
 69ice_eswitch_mode_set(struct devlink *devlink, u16 mode,
 70		     struct netlink_ext_ack *extack)
 71{
 72	return -EOPNOTSUPP;
 73}
 74
 75static inline bool ice_is_eswitch_mode_switchdev(struct ice_pf *pf)
 76{
 77	return false;
 78}
 79
 80static inline netdev_tx_t
 81ice_eswitch_port_start_xmit(struct sk_buff *skb, struct net_device *netdev)
 82{
 83	return NETDEV_TX_BUSY;
 84}
 85
 86static inline struct net_device *
 87ice_eswitch_get_target(struct ice_rx_ring *rx_ring,
 88		       union ice_32b_rx_flex_desc *rx_desc)
 89{
 90	return rx_ring->netdev;
 91}
 92
 93static inline int ice_eswitch_cfg_vsi(struct ice_vsi *vsi, const u8 *mac)
 94{
 95	return -EOPNOTSUPP;
 96}
 97
 98static inline void ice_eswitch_decfg_vsi(struct ice_vsi *vsi, const u8 *mac) { }
 99#endif /* CONFIG_ICE_SWITCHDEV */
100#endif /* _ICE_ESWITCH_H_ */
v6.8
 1/* SPDX-License-Identifier: GPL-2.0 */
 2/* Copyright (C) 2019-2021, Intel Corporation. */
 3
 4#ifndef _ICE_ESWITCH_H_
 5#define _ICE_ESWITCH_H_
 6
 7#include <net/devlink.h>
 
 8
 9#ifdef CONFIG_ICE_SWITCHDEV
10void ice_eswitch_detach(struct ice_pf *pf, struct ice_vf *vf);
11int
12ice_eswitch_attach(struct ice_pf *pf, struct ice_vf *vf);
13int ice_eswitch_rebuild(struct ice_pf *pf);
14
15int ice_eswitch_mode_get(struct devlink *devlink, u16 *mode);
16int
17ice_eswitch_mode_set(struct devlink *devlink, u16 mode,
18		     struct netlink_ext_ack *extack);
19bool ice_is_eswitch_mode_switchdev(struct ice_pf *pf);
20
21void ice_eswitch_update_repr(unsigned long repr_id, struct ice_vsi *vsi);
22
23void ice_eswitch_stop_all_tx_queues(struct ice_pf *pf);
24
25void ice_eswitch_set_target_vsi(struct sk_buff *skb,
26				struct ice_tx_offload_params *off);
27netdev_tx_t
28ice_eswitch_port_start_xmit(struct sk_buff *skb, struct net_device *netdev);
29void ice_eswitch_reserve_cp_queues(struct ice_pf *pf, int change);
 
 
 
 
30#else /* CONFIG_ICE_SWITCHDEV */
31static inline void ice_eswitch_detach(struct ice_pf *pf, struct ice_vf *vf) { }
 
 
 
 
32
33static inline int
34ice_eswitch_attach(struct ice_pf *pf, struct ice_vf *vf)
 
 
 
 
 
 
35{
36	return -EOPNOTSUPP;
37}
38
39static inline void ice_eswitch_stop_all_tx_queues(struct ice_pf *pf) { }
40
41static inline void
42ice_eswitch_set_target_vsi(struct sk_buff *skb,
43			   struct ice_tx_offload_params *off) { }
44
45static inline void
46ice_eswitch_update_repr(unsigned long repr_id, struct ice_vsi *vsi) { }
47
48static inline int ice_eswitch_configure(struct ice_pf *pf)
49{
50	return 0;
51}
52
53static inline int ice_eswitch_rebuild(struct ice_pf *pf)
54{
55	return -EOPNOTSUPP;
56}
57
58static inline int ice_eswitch_mode_get(struct devlink *devlink, u16 *mode)
59{
60	return DEVLINK_ESWITCH_MODE_LEGACY;
61}
62
63static inline int
64ice_eswitch_mode_set(struct devlink *devlink, u16 mode,
65		     struct netlink_ext_ack *extack)
66{
67	return -EOPNOTSUPP;
68}
69
70static inline bool ice_is_eswitch_mode_switchdev(struct ice_pf *pf)
71{
72	return false;
73}
74
75static inline netdev_tx_t
76ice_eswitch_port_start_xmit(struct sk_buff *skb, struct net_device *netdev)
77{
78	return NETDEV_TX_BUSY;
79}
80
81static inline void
82ice_eswitch_reserve_cp_queues(struct ice_pf *pf, int change) { }
 
 
 
 
 
 
 
 
 
 
 
83#endif /* CONFIG_ICE_SWITCHDEV */
84#endif /* _ICE_ESWITCH_H_ */