183c9e13aSJakub Kicinski /* 283c9e13aSJakub Kicinski * Copyright (C) 2017 Netronome Systems, Inc. 383c9e13aSJakub Kicinski * 483c9e13aSJakub Kicinski * This software is licensed under the GNU General License Version 2, 583c9e13aSJakub Kicinski * June 1991 as shown in the file COPYING in the top-level directory of this 683c9e13aSJakub Kicinski * source tree. 783c9e13aSJakub Kicinski * 883c9e13aSJakub Kicinski * THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" 983c9e13aSJakub Kicinski * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, 1083c9e13aSJakub Kicinski * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 1183c9e13aSJakub Kicinski * FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE 1283c9e13aSJakub Kicinski * OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME 1383c9e13aSJakub Kicinski * THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 1483c9e13aSJakub Kicinski */ 1583c9e13aSJakub Kicinski 16424be63aSJakub Kicinski #include <linux/debugfs.h> 1779579220SJakub Kicinski #include <linux/device.h> 18a7fc6db0SAntonio Cardace #include <linux/ethtool.h> 1983c9e13aSJakub Kicinski #include <linux/kernel.h> 2031d3ad83SJakub Kicinski #include <linux/list.h> 2183c9e13aSJakub Kicinski #include <linux/netdevice.h> 22*b63e78fcSVladimir Oltean #include <linux/ptp_mock.h> 2383c9e13aSJakub Kicinski #include <linux/u64_stats_sync.h> 248320d145SJiri Pirko #include <net/devlink.h> 25dc9c0753SJakub Kicinski #include <net/udp_tunnel.h> 2605296620SJakub Kicinski #include <net/xdp.h> 2702b34d03SSabrina Dubroca #include <net/macsec.h> 2883c9e13aSJakub Kicinski 2983c9e13aSJakub Kicinski #define DRV_NAME "netdevsim" 3083c9e13aSJakub Kicinski 3131d3ad83SJakub Kicinski #define NSIM_XDP_MAX_MTU 4000 3231d3ad83SJakub Kicinski 3331d3ad83SJakub Kicinski #define NSIM_EA(extack, msg) NL_SET_ERR_MSG_MOD((extack), msg) 3431d3ad83SJakub Kicinski 357699353dSShannon Nelson #define NSIM_IPSEC_MAX_SA_COUNT 33 367699353dSShannon Nelson #define NSIM_IPSEC_VALID BIT(31) 37424be63aSJakub Kicinski #define NSIM_UDP_TUNNEL_N_PORTS 4 387699353dSShannon Nelson 397699353dSShannon Nelson struct nsim_sa { 407699353dSShannon Nelson struct xfrm_state *xs; 417699353dSShannon Nelson __be32 ipaddr[4]; 427699353dSShannon Nelson u32 key[4]; 437699353dSShannon Nelson u32 salt; 447699353dSShannon Nelson bool used; 457699353dSShannon Nelson bool crypt; 467699353dSShannon Nelson bool rx; 477699353dSShannon Nelson }; 487699353dSShannon Nelson 497699353dSShannon Nelson struct nsim_ipsec { 507699353dSShannon Nelson struct nsim_sa sa[NSIM_IPSEC_MAX_SA_COUNT]; 517699353dSShannon Nelson struct dentry *pfile; 527699353dSShannon Nelson u32 count; 537699353dSShannon Nelson u32 tx; 547699353dSShannon Nelson u32 ok; 557699353dSShannon Nelson }; 567699353dSShannon Nelson 5702b34d03SSabrina Dubroca #define NSIM_MACSEC_MAX_SECY_COUNT 3 5802b34d03SSabrina Dubroca #define NSIM_MACSEC_MAX_RXSC_COUNT 1 5902b34d03SSabrina Dubroca struct nsim_rxsc { 6002b34d03SSabrina Dubroca sci_t sci; 6102b34d03SSabrina Dubroca bool used; 6202b34d03SSabrina Dubroca }; 6302b34d03SSabrina Dubroca 6402b34d03SSabrina Dubroca struct nsim_secy { 6502b34d03SSabrina Dubroca sci_t sci; 6602b34d03SSabrina Dubroca struct nsim_rxsc nsim_rxsc[NSIM_MACSEC_MAX_RXSC_COUNT]; 6702b34d03SSabrina Dubroca u8 nsim_rxsc_count; 6802b34d03SSabrina Dubroca bool used; 6902b34d03SSabrina Dubroca }; 7002b34d03SSabrina Dubroca 7102b34d03SSabrina Dubroca struct nsim_macsec { 7202b34d03SSabrina Dubroca struct nsim_secy nsim_secy[NSIM_MACSEC_MAX_SECY_COUNT]; 7302b34d03SSabrina Dubroca u8 nsim_secy_count; 7402b34d03SSabrina Dubroca }; 7502b34d03SSabrina Dubroca 7677f9591bSAntonio Cardace struct nsim_ethtool_pauseparam { 77ff1f7c17SJakub Kicinski bool rx; 78ff1f7c17SJakub Kicinski bool tx; 79ff1f7c17SJakub Kicinski bool report_stats_rx; 80ff1f7c17SJakub Kicinski bool report_stats_tx; 81ff1f7c17SJakub Kicinski }; 82ff1f7c17SJakub Kicinski 8377f9591bSAntonio Cardace struct nsim_ethtool { 840d7f76dcSJakub Kicinski u32 get_err; 850d7f76dcSJakub Kicinski u32 set_err; 862e367522SJakub Kicinski u32 channels; 8777f9591bSAntonio Cardace struct nsim_ethtool_pauseparam pauseparam; 88a7fc6db0SAntonio Cardace struct ethtool_coalesce coalesce; 89a7fc6db0SAntonio Cardace struct ethtool_ringparam ring; 900d7f76dcSJakub Kicinski struct ethtool_fecparam fec; 9177f9591bSAntonio Cardace }; 9277f9591bSAntonio Cardace 9383c9e13aSJakub Kicinski struct netdevsim { 9431d3ad83SJakub Kicinski struct net_device *netdev; 95a60f9e48SJiri Pirko struct nsim_dev *nsim_dev; 96e05b2d14SJiri Pirko struct nsim_dev_port *nsim_dev_port; 97*b63e78fcSVladimir Oltean struct mock_phc *phc; 9831d3ad83SJakub Kicinski 9983c9e13aSJakub Kicinski u64 tx_packets; 10083c9e13aSJakub Kicinski u64 tx_bytes; 10183c9e13aSJakub Kicinski struct u64_stats_sync syncp; 10231d3ad83SJakub Kicinski 10340e4fe4cSJiri Pirko struct nsim_bus_dev *nsim_bus_dev; 10479579220SJakub Kicinski 10531d3ad83SJakub Kicinski struct bpf_prog *bpf_offloaded; 10631d3ad83SJakub Kicinski u32 bpf_offloaded_id; 10731d3ad83SJakub Kicinski 10805296620SJakub Kicinski struct xdp_attachment_info xdp; 109799e173dSJakub Kicinski struct xdp_attachment_info xdp_hw; 11031d3ad83SJakub Kicinski 11131d3ad83SJakub Kicinski bool bpf_tc_accept; 11231d3ad83SJakub Kicinski bool bpf_tc_non_bound_accept; 11331d3ad83SJakub Kicinski bool bpf_xdpdrv_accept; 11431d3ad83SJakub Kicinski bool bpf_xdpoffload_accept; 115395cacb5SJakub Kicinski 116395cacb5SJakub Kicinski bool bpf_map_accept; 1177699353dSShannon Nelson struct nsim_ipsec ipsec; 11802b34d03SSabrina Dubroca struct nsim_macsec macsec; 119424be63aSJakub Kicinski struct { 120424be63aSJakub Kicinski u32 inject_error; 121424be63aSJakub Kicinski u32 sleep; 122dc9c0753SJakub Kicinski u32 __ports[2][NSIM_UDP_TUNNEL_N_PORTS]; 123dc9c0753SJakub Kicinski u32 (*ports)[NSIM_UDP_TUNNEL_N_PORTS]; 124424be63aSJakub Kicinski struct debugfs_u32_array dfs_ports[2]; 125424be63aSJakub Kicinski } udp_ports; 126ff1f7c17SJakub Kicinski 127ff1f7c17SJakub Kicinski struct nsim_ethtool ethtool; 12883c9e13aSJakub Kicinski }; 12931d3ad83SJakub Kicinski 130e05b2d14SJiri Pirko struct netdevsim * 131e05b2d14SJiri Pirko nsim_create(struct nsim_dev *nsim_dev, struct nsim_dev_port *nsim_dev_port); 132e05b2d14SJiri Pirko void nsim_destroy(struct netdevsim *ns); 133e05b2d14SJiri Pirko 134ff1f7c17SJakub Kicinski void nsim_ethtool_init(struct netdevsim *ns); 135ff1f7c17SJakub Kicinski 136424be63aSJakub Kicinski void nsim_udp_tunnels_debugfs_create(struct nsim_dev *nsim_dev); 137424be63aSJakub Kicinski int nsim_udp_tunnels_info_create(struct nsim_dev *nsim_dev, 138424be63aSJakub Kicinski struct net_device *dev); 139424be63aSJakub Kicinski void nsim_udp_tunnels_info_destroy(struct net_device *dev); 140424be63aSJakub Kicinski 1417c5db7e7SJakub Kicinski #ifdef CONFIG_BPF_SYSCALL 142d514f41eSJiri Pirko int nsim_bpf_dev_init(struct nsim_dev *nsim_dev); 143d514f41eSJiri Pirko void nsim_bpf_dev_exit(struct nsim_dev *nsim_dev); 14431d3ad83SJakub Kicinski int nsim_bpf_init(struct netdevsim *ns); 14531d3ad83SJakub Kicinski void nsim_bpf_uninit(struct netdevsim *ns); 14631d3ad83SJakub Kicinski int nsim_bpf(struct net_device *dev, struct netdev_bpf *bpf); 14731d3ad83SJakub Kicinski int nsim_bpf_disable_tc(struct netdevsim *ns); 14831d3ad83SJakub Kicinski int nsim_bpf_setup_tc_block_cb(enum tc_setup_type type, 14931d3ad83SJakub Kicinski void *type_data, void *cb_priv); 1507c5db7e7SJakub Kicinski #else 151d514f41eSJiri Pirko 152d514f41eSJiri Pirko static inline int nsim_bpf_dev_init(struct nsim_dev *nsim_dev) 153d514f41eSJiri Pirko { 154d514f41eSJiri Pirko return 0; 155d514f41eSJiri Pirko } 156d514f41eSJiri Pirko 157d514f41eSJiri Pirko static inline void nsim_bpf_dev_exit(struct nsim_dev *nsim_dev) 158d514f41eSJiri Pirko { 159d514f41eSJiri Pirko } 1607c5db7e7SJakub Kicinski static inline int nsim_bpf_init(struct netdevsim *ns) 1617c5db7e7SJakub Kicinski { 1627c5db7e7SJakub Kicinski return 0; 1637c5db7e7SJakub Kicinski } 1647c5db7e7SJakub Kicinski 1657c5db7e7SJakub Kicinski static inline void nsim_bpf_uninit(struct netdevsim *ns) 1667c5db7e7SJakub Kicinski { 1677c5db7e7SJakub Kicinski } 1687c5db7e7SJakub Kicinski 1697c5db7e7SJakub Kicinski static inline int nsim_bpf(struct net_device *dev, struct netdev_bpf *bpf) 1707c5db7e7SJakub Kicinski { 171e8407fdeSAndrii Nakryiko return -EOPNOTSUPP; 1727c5db7e7SJakub Kicinski } 1737c5db7e7SJakub Kicinski 1747c5db7e7SJakub Kicinski static inline int nsim_bpf_disable_tc(struct netdevsim *ns) 1757c5db7e7SJakub Kicinski { 1767c5db7e7SJakub Kicinski return 0; 1777c5db7e7SJakub Kicinski } 1787c5db7e7SJakub Kicinski 1797c5db7e7SJakub Kicinski static inline int 1807c5db7e7SJakub Kicinski nsim_bpf_setup_tc_block_cb(enum tc_setup_type type, void *type_data, 1817c5db7e7SJakub Kicinski void *cb_priv) 1827c5db7e7SJakub Kicinski { 1837c5db7e7SJakub Kicinski return -EOPNOTSUPP; 1847c5db7e7SJakub Kicinski } 1857c5db7e7SJakub Kicinski #endif 18679579220SJakub Kicinski 18737923ed6SDavid Ahern enum nsim_resource_id { 18837923ed6SDavid Ahern NSIM_RESOURCE_NONE, /* DEVLINK_RESOURCE_ID_PARENT_TOP */ 18937923ed6SDavid Ahern NSIM_RESOURCE_IPV4, 19037923ed6SDavid Ahern NSIM_RESOURCE_IPV4_FIB, 19137923ed6SDavid Ahern NSIM_RESOURCE_IPV4_FIB_RULES, 19237923ed6SDavid Ahern NSIM_RESOURCE_IPV6, 19337923ed6SDavid Ahern NSIM_RESOURCE_IPV6_FIB, 19437923ed6SDavid Ahern NSIM_RESOURCE_IPV6_FIB_RULES, 19535266255SIdo Schimmel NSIM_RESOURCE_NEXTHOPS, 19637923ed6SDavid Ahern }; 19737923ed6SDavid Ahern 19882c93a87SJiri Pirko struct nsim_dev_health { 19982c93a87SJiri Pirko struct devlink_health_reporter *empty_reporter; 20082c93a87SJiri Pirko struct devlink_health_reporter *dummy_reporter; 20182c93a87SJiri Pirko struct dentry *ddir; 20282c93a87SJiri Pirko char *recovered_break_msg; 20382c93a87SJiri Pirko u32 binary_len; 20482c93a87SJiri Pirko bool fail_recover; 20582c93a87SJiri Pirko }; 20682c93a87SJiri Pirko 20782c93a87SJiri Pirko int nsim_dev_health_init(struct nsim_dev *nsim_dev, struct devlink *devlink); 20882c93a87SJiri Pirko void nsim_dev_health_exit(struct nsim_dev *nsim_dev); 20982c93a87SJiri Pirko 2101a6d7ae7SPetr Machata struct nsim_dev_hwstats_netdev { 2111a6d7ae7SPetr Machata struct list_head list; 2121a6d7ae7SPetr Machata struct net_device *netdev; 2131a6d7ae7SPetr Machata struct rtnl_hw_stats64 stats; 2141a6d7ae7SPetr Machata bool enabled; 2151a6d7ae7SPetr Machata bool fail_enable; 2161a6d7ae7SPetr Machata }; 2171a6d7ae7SPetr Machata 2181a6d7ae7SPetr Machata struct nsim_dev_hwstats { 2191a6d7ae7SPetr Machata struct dentry *ddir; 2201a6d7ae7SPetr Machata struct dentry *l3_ddir; 2211a6d7ae7SPetr Machata 2221a6d7ae7SPetr Machata struct mutex hwsdev_list_lock; /* protects hwsdev list(s) */ 2231a6d7ae7SPetr Machata struct list_head l3_list; 2241a6d7ae7SPetr Machata 2251a6d7ae7SPetr Machata struct notifier_block netdevice_nb; 2261a6d7ae7SPetr Machata struct delayed_work traffic_dw; 2271a6d7ae7SPetr Machata }; 2281a6d7ae7SPetr Machata 2291a6d7ae7SPetr Machata int nsim_dev_hwstats_init(struct nsim_dev *nsim_dev); 2301a6d7ae7SPetr Machata void nsim_dev_hwstats_exit(struct nsim_dev *nsim_dev); 2311a6d7ae7SPetr Machata 232a8700c3dSIdo Schimmel #if IS_ENABLED(CONFIG_PSAMPLE) 233a8700c3dSIdo Schimmel int nsim_dev_psample_init(struct nsim_dev *nsim_dev); 234a8700c3dSIdo Schimmel void nsim_dev_psample_exit(struct nsim_dev *nsim_dev); 235a8700c3dSIdo Schimmel #else 236a8700c3dSIdo Schimmel static inline int nsim_dev_psample_init(struct nsim_dev *nsim_dev) 237a8700c3dSIdo Schimmel { 238a8700c3dSIdo Schimmel return 0; 239a8700c3dSIdo Schimmel } 240a8700c3dSIdo Schimmel 241a8700c3dSIdo Schimmel static inline void nsim_dev_psample_exit(struct nsim_dev *nsim_dev) 242a8700c3dSIdo Schimmel { 243a8700c3dSIdo Schimmel } 244a8700c3dSIdo Schimmel #endif 245a8700c3dSIdo Schimmel 246814b9ce6SDmytro Linkin enum nsim_dev_port_type { 247814b9ce6SDmytro Linkin NSIM_DEV_PORT_TYPE_PF, 248814b9ce6SDmytro Linkin NSIM_DEV_PORT_TYPE_VF, 249814b9ce6SDmytro Linkin }; 250814b9ce6SDmytro Linkin 251814b9ce6SDmytro Linkin #define NSIM_DEV_VF_PORT_INDEX_BASE 128 252814b9ce6SDmytro Linkin #define NSIM_DEV_VF_PORT_INDEX_MAX UINT_MAX 253814b9ce6SDmytro Linkin 2548320d145SJiri Pirko struct nsim_dev_port { 2558320d145SJiri Pirko struct list_head list; 2568320d145SJiri Pirko struct devlink_port devlink_port; 2578320d145SJiri Pirko unsigned int port_index; 258814b9ce6SDmytro Linkin enum nsim_dev_port_type port_type; 2598320d145SJiri Pirko struct dentry *ddir; 260f3d101b4SDmytro Linkin struct dentry *rate_parent; 261f3d101b4SDmytro Linkin char *parent_name; 262e05b2d14SJiri Pirko struct netdevsim *ns; 2638320d145SJiri Pirko }; 2648320d145SJiri Pirko 2655e388f3dSJakub Kicinski struct nsim_vf_config { 2665e388f3dSJakub Kicinski int link_state; 2675e388f3dSJakub Kicinski u16 min_tx_rate; 2685e388f3dSJakub Kicinski u16 max_tx_rate; 2695e388f3dSJakub Kicinski u16 vlan; 2705e388f3dSJakub Kicinski __be16 vlan_proto; 2715e388f3dSJakub Kicinski u16 qos; 2725e388f3dSJakub Kicinski u8 vf_mac[ETH_ALEN]; 2735e388f3dSJakub Kicinski bool spoofchk_enabled; 2745e388f3dSJakub Kicinski bool trusted; 2755e388f3dSJakub Kicinski bool rss_query_enabled; 2765e388f3dSJakub Kicinski }; 2775e388f3dSJakub Kicinski 278a60f9e48SJiri Pirko struct nsim_dev { 279d514f41eSJiri Pirko struct nsim_bus_dev *nsim_bus_dev; 280a60f9e48SJiri Pirko struct nsim_fib_data *fib_data; 281da58f90fSIdo Schimmel struct nsim_trap_data *trap_data; 282d514f41eSJiri Pirko struct dentry *ddir; 283ab1d0cc0SJiri Pirko struct dentry *ports_ddir; 2848526ad96STaehee Yoo struct dentry *take_snapshot; 285885226f5SDmytro Linkin struct dentry *nodes_ddir; 2865e388f3dSJakub Kicinski 2875e388f3dSJakub Kicinski struct nsim_vf_config *vfconfigs; 2885e388f3dSJakub Kicinski 289d514f41eSJiri Pirko struct bpf_offload_dev *bpf_dev; 290d514f41eSJiri Pirko bool bpf_bind_accept; 291e4ff5aa4SToke Høiland-Jørgensen bool bpf_bind_verifier_accept; 292d514f41eSJiri Pirko u32 bpf_bind_verifier_delay; 293d514f41eSJiri Pirko struct dentry *ddir_bpf_bound_progs; 294d514f41eSJiri Pirko u32 prog_id_gen; 295d514f41eSJiri Pirko struct list_head bpf_bound_progs; 296d514f41eSJiri Pirko struct list_head bpf_bound_maps; 297514cf64cSJiri Pirko struct netdev_phys_item_id switch_id; 2988320d145SJiri Pirko struct list_head port_list; 299fa4dfc4aSJiri Pirko bool fw_update_status; 300cbb58368SJacob Keller u32 fw_update_overwrite_mask; 301150e8f8aSJiri Pirko u32 max_macs; 302150e8f8aSJiri Pirko bool test1; 303155ddfc5SJiri Pirko bool dont_allow_reload; 304155ddfc5SJiri Pirko bool fail_reload; 3054418f862SJiri Pirko struct devlink_region *dummy_region; 30682c93a87SJiri Pirko struct nsim_dev_health health; 3071a6d7ae7SPetr Machata struct nsim_dev_hwstats hwstats; 308d3cbb907SJiri Pirko struct flow_action_cookie *fa_cookie; 309d3cbb907SJiri Pirko spinlock_t fa_cookie_lock; /* protects fa_cookie */ 3100dc8249aSIdo Schimmel bool fail_trap_group_set; 311ad188458SIdo Schimmel bool fail_trap_policer_set; 312ad188458SIdo Schimmel bool fail_trap_policer_counter_get; 313275b51c2SOleksandr Mazur bool fail_trap_drop_counter_get; 314424be63aSJakub Kicinski struct { 315dc9c0753SJakub Kicinski struct udp_tunnel_nic_shared utn_shared; 316dc9c0753SJakub Kicinski u32 __ports[2][NSIM_UDP_TUNNEL_N_PORTS]; 317424be63aSJakub Kicinski bool sync_all; 318424be63aSJakub Kicinski bool open_only; 319424be63aSJakub Kicinski bool ipv4_only; 320dc9c0753SJakub Kicinski bool shared; 321dda75173SJakub Kicinski bool static_iana_vxlan; 322424be63aSJakub Kicinski u32 sleep; 323424be63aSJakub Kicinski } udp_ports; 324a8700c3dSIdo Schimmel struct nsim_dev_psample *psample; 325160dc373SDmytro Linkin u16 esw_mode; 326a60f9e48SJiri Pirko }; 327a60f9e48SJiri Pirko 328160dc373SDmytro Linkin static inline bool nsim_esw_mode_is_legacy(struct nsim_dev *nsim_dev) 329160dc373SDmytro Linkin { 330160dc373SDmytro Linkin return nsim_dev->esw_mode == DEVLINK_ESWITCH_MODE_LEGACY; 331160dc373SDmytro Linkin } 332160dc373SDmytro Linkin 333160dc373SDmytro Linkin static inline bool nsim_esw_mode_is_switchdev(struct nsim_dev *nsim_dev) 334160dc373SDmytro Linkin { 335160dc373SDmytro Linkin return nsim_dev->esw_mode == DEVLINK_ESWITCH_MODE_SWITCHDEV; 336160dc373SDmytro Linkin } 337160dc373SDmytro Linkin 33890d29913SJiri Pirko static inline struct net *nsim_dev_net(struct nsim_dev *nsim_dev) 33990d29913SJiri Pirko { 34090d29913SJiri Pirko return devlink_net(priv_to_devlink(nsim_dev)); 34190d29913SJiri Pirko } 34290d29913SJiri Pirko 343d514f41eSJiri Pirko int nsim_dev_init(void); 344d514f41eSJiri Pirko void nsim_dev_exit(void); 345a66f64b8SJakub Kicinski int nsim_drv_probe(struct nsim_bus_dev *nsim_bus_dev); 346a66f64b8SJakub Kicinski void nsim_drv_remove(struct nsim_bus_dev *nsim_bus_dev); 347a66f64b8SJakub Kicinski int nsim_drv_port_add(struct nsim_bus_dev *nsim_bus_dev, 348814b9ce6SDmytro Linkin enum nsim_dev_port_type type, 349794b2c05SJiri Pirko unsigned int port_index); 350a66f64b8SJakub Kicinski int nsim_drv_port_del(struct nsim_bus_dev *nsim_bus_dev, 351814b9ce6SDmytro Linkin enum nsim_dev_port_type type, 352794b2c05SJiri Pirko unsigned int port_index); 3531c401078SJakub Kicinski int nsim_drv_configure_vfs(struct nsim_bus_dev *nsim_bus_dev, 3541c401078SJakub Kicinski unsigned int num_vfs); 35537923ed6SDavid Ahern 3565e388f3dSJakub Kicinski unsigned int nsim_dev_get_vfs(struct nsim_dev *nsim_dev); 3575e388f3dSJakub Kicinski 35875ba029fSJiri Pirko struct nsim_fib_data *nsim_fib_create(struct devlink *devlink, 35975ba029fSJiri Pirko struct netlink_ext_ack *extack); 36075ba029fSJiri Pirko void nsim_fib_destroy(struct devlink *devlink, struct nsim_fib_data *fib_data); 361a5facc4cSJiri Pirko u64 nsim_fib_get_val(struct nsim_fib_data *fib_data, 362a5facc4cSJiri Pirko enum nsim_resource_id res_id, bool max); 36337923ed6SDavid Ahern 364814b9ce6SDmytro Linkin static inline bool nsim_dev_port_is_pf(struct nsim_dev_port *nsim_dev_port) 365814b9ce6SDmytro Linkin { 366814b9ce6SDmytro Linkin return nsim_dev_port->port_type == NSIM_DEV_PORT_TYPE_PF; 367814b9ce6SDmytro Linkin } 368814b9ce6SDmytro Linkin 369814b9ce6SDmytro Linkin static inline bool nsim_dev_port_is_vf(struct nsim_dev_port *nsim_dev_port) 370814b9ce6SDmytro Linkin { 371814b9ce6SDmytro Linkin return nsim_dev_port->port_type == NSIM_DEV_PORT_TYPE_VF; 372814b9ce6SDmytro Linkin } 3737699353dSShannon Nelson #if IS_ENABLED(CONFIG_XFRM_OFFLOAD) 3747699353dSShannon Nelson void nsim_ipsec_init(struct netdevsim *ns); 3757699353dSShannon Nelson void nsim_ipsec_teardown(struct netdevsim *ns); 3767699353dSShannon Nelson bool nsim_ipsec_tx(struct netdevsim *ns, struct sk_buff *skb); 3777699353dSShannon Nelson #else 3787699353dSShannon Nelson static inline void nsim_ipsec_init(struct netdevsim *ns) 3797699353dSShannon Nelson { 3807699353dSShannon Nelson } 3817699353dSShannon Nelson 3827699353dSShannon Nelson static inline void nsim_ipsec_teardown(struct netdevsim *ns) 3837699353dSShannon Nelson { 3847699353dSShannon Nelson } 3857699353dSShannon Nelson 3867699353dSShannon Nelson static inline bool nsim_ipsec_tx(struct netdevsim *ns, struct sk_buff *skb) 3877699353dSShannon Nelson { 3887699353dSShannon Nelson return true; 3897699353dSShannon Nelson } 3907699353dSShannon Nelson #endif 3917699353dSShannon Nelson 39202b34d03SSabrina Dubroca #if IS_ENABLED(CONFIG_MACSEC) 39302b34d03SSabrina Dubroca void nsim_macsec_init(struct netdevsim *ns); 39402b34d03SSabrina Dubroca void nsim_macsec_teardown(struct netdevsim *ns); 39502b34d03SSabrina Dubroca #else 39602b34d03SSabrina Dubroca static inline void nsim_macsec_init(struct netdevsim *ns) 39702b34d03SSabrina Dubroca { 39802b34d03SSabrina Dubroca } 39902b34d03SSabrina Dubroca 40002b34d03SSabrina Dubroca static inline void nsim_macsec_teardown(struct netdevsim *ns) 40102b34d03SSabrina Dubroca { 40202b34d03SSabrina Dubroca } 40302b34d03SSabrina Dubroca #endif 40402b34d03SSabrina Dubroca 40540e4fe4cSJiri Pirko struct nsim_bus_dev { 40640e4fe4cSJiri Pirko struct device dev; 407f9d9db47SJiri Pirko struct list_head list; 408f9d9db47SJiri Pirko unsigned int port_count; 409d4861fc6SPeilin Ye unsigned int num_queues; /* Number of queues for each port on this bus */ 4107b60027bSJiri Pirko struct net *initial_net; /* Purpose of this is to carry net pointer 4117b60027bSJiri Pirko * during the probe time only. 4127b60027bSJiri Pirko */ 413d3953819SDmytro Linkin unsigned int max_vfs; 41440e4fe4cSJiri Pirko unsigned int num_vfs; 415f5cd2160STaehee Yoo bool init; 41640e4fe4cSJiri Pirko }; 417925f5afeSJiri Pirko 418925f5afeSJiri Pirko int nsim_bus_init(void); 419925f5afeSJiri Pirko void nsim_bus_exit(void); 420