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> 22b63e78fcSVladimir 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 933762ec05SDavid Wei struct nsim_rq { 943762ec05SDavid Wei struct napi_struct napi; 953762ec05SDavid Wei struct sk_buff_head skb_queue; 963762ec05SDavid Wei struct page_pool *page_pool; 973762ec05SDavid Wei }; 983762ec05SDavid Wei 9983c9e13aSJakub Kicinski struct netdevsim { 10031d3ad83SJakub Kicinski struct net_device *netdev; 101a60f9e48SJiri Pirko struct nsim_dev *nsim_dev; 102e05b2d14SJiri Pirko struct nsim_dev_port *nsim_dev_port; 103b63e78fcSVladimir Oltean struct mock_phc *phc; 104915c82f8SJakub Kicinski struct nsim_rq **rq; 10531d3ad83SJakub Kicinski 106*5bc8e8dbSJakub Kicinski int rq_reset_mode; 107*5bc8e8dbSJakub Kicinski 10883c9e13aSJakub Kicinski u64 tx_packets; 10983c9e13aSJakub Kicinski u64 tx_bytes; 1109eb95228SDavid Wei u64 tx_dropped; 11183c9e13aSJakub Kicinski struct u64_stats_sync syncp; 11231d3ad83SJakub Kicinski 11340e4fe4cSJiri Pirko struct nsim_bus_dev *nsim_bus_dev; 11479579220SJakub Kicinski 11531d3ad83SJakub Kicinski struct bpf_prog *bpf_offloaded; 11631d3ad83SJakub Kicinski u32 bpf_offloaded_id; 11731d3ad83SJakub Kicinski 11805296620SJakub Kicinski struct xdp_attachment_info xdp; 119799e173dSJakub Kicinski struct xdp_attachment_info xdp_hw; 12031d3ad83SJakub Kicinski 12131d3ad83SJakub Kicinski bool bpf_tc_accept; 12231d3ad83SJakub Kicinski bool bpf_tc_non_bound_accept; 12331d3ad83SJakub Kicinski bool bpf_xdpdrv_accept; 12431d3ad83SJakub Kicinski bool bpf_xdpoffload_accept; 125395cacb5SJakub Kicinski 126395cacb5SJakub Kicinski bool bpf_map_accept; 1277699353dSShannon Nelson struct nsim_ipsec ipsec; 12802b34d03SSabrina Dubroca struct nsim_macsec macsec; 129424be63aSJakub Kicinski struct { 130424be63aSJakub Kicinski u32 inject_error; 131424be63aSJakub Kicinski u32 sleep; 132dc9c0753SJakub Kicinski u32 __ports[2][NSIM_UDP_TUNNEL_N_PORTS]; 133dc9c0753SJakub Kicinski u32 (*ports)[NSIM_UDP_TUNNEL_N_PORTS]; 134424be63aSJakub Kicinski struct debugfs_u32_array dfs_ports[2]; 135424be63aSJakub Kicinski } udp_ports; 136ff1f7c17SJakub Kicinski 1371580cbcbSJakub Kicinski struct page *page; 1381580cbcbSJakub Kicinski struct dentry *pp_dfs; 1391580cbcbSJakub Kicinski 140ff1f7c17SJakub Kicinski struct nsim_ethtool ethtool; 141f532957dSDavid Wei struct netdevsim __rcu *peer; 14283c9e13aSJakub Kicinski }; 14331d3ad83SJakub Kicinski 144e05b2d14SJiri Pirko struct netdevsim * 145e05b2d14SJiri Pirko nsim_create(struct nsim_dev *nsim_dev, struct nsim_dev_port *nsim_dev_port); 146e05b2d14SJiri Pirko void nsim_destroy(struct netdevsim *ns); 147f532957dSDavid Wei bool netdev_is_nsim(struct net_device *dev); 148e05b2d14SJiri Pirko 149ff1f7c17SJakub Kicinski void nsim_ethtool_init(struct netdevsim *ns); 150ff1f7c17SJakub Kicinski 151424be63aSJakub Kicinski void nsim_udp_tunnels_debugfs_create(struct nsim_dev *nsim_dev); 152424be63aSJakub Kicinski int nsim_udp_tunnels_info_create(struct nsim_dev *nsim_dev, 153424be63aSJakub Kicinski struct net_device *dev); 154424be63aSJakub Kicinski void nsim_udp_tunnels_info_destroy(struct net_device *dev); 155424be63aSJakub Kicinski 1567c5db7e7SJakub Kicinski #ifdef CONFIG_BPF_SYSCALL 157d514f41eSJiri Pirko int nsim_bpf_dev_init(struct nsim_dev *nsim_dev); 158d514f41eSJiri Pirko void nsim_bpf_dev_exit(struct nsim_dev *nsim_dev); 15931d3ad83SJakub Kicinski int nsim_bpf_init(struct netdevsim *ns); 16031d3ad83SJakub Kicinski void nsim_bpf_uninit(struct netdevsim *ns); 16131d3ad83SJakub Kicinski int nsim_bpf(struct net_device *dev, struct netdev_bpf *bpf); 16231d3ad83SJakub Kicinski int nsim_bpf_disable_tc(struct netdevsim *ns); 16331d3ad83SJakub Kicinski int nsim_bpf_setup_tc_block_cb(enum tc_setup_type type, 16431d3ad83SJakub Kicinski void *type_data, void *cb_priv); 1657c5db7e7SJakub Kicinski #else 166d514f41eSJiri Pirko 167d514f41eSJiri Pirko static inline int nsim_bpf_dev_init(struct nsim_dev *nsim_dev) 168d514f41eSJiri Pirko { 169d514f41eSJiri Pirko return 0; 170d514f41eSJiri Pirko } 171d514f41eSJiri Pirko 172d514f41eSJiri Pirko static inline void nsim_bpf_dev_exit(struct nsim_dev *nsim_dev) 173d514f41eSJiri Pirko { 174d514f41eSJiri Pirko } 1757c5db7e7SJakub Kicinski static inline int nsim_bpf_init(struct netdevsim *ns) 1767c5db7e7SJakub Kicinski { 1777c5db7e7SJakub Kicinski return 0; 1787c5db7e7SJakub Kicinski } 1797c5db7e7SJakub Kicinski 1807c5db7e7SJakub Kicinski static inline void nsim_bpf_uninit(struct netdevsim *ns) 1817c5db7e7SJakub Kicinski { 1827c5db7e7SJakub Kicinski } 1837c5db7e7SJakub Kicinski 1847c5db7e7SJakub Kicinski static inline int nsim_bpf(struct net_device *dev, struct netdev_bpf *bpf) 1857c5db7e7SJakub Kicinski { 186e8407fdeSAndrii Nakryiko return -EOPNOTSUPP; 1877c5db7e7SJakub Kicinski } 1887c5db7e7SJakub Kicinski 1897c5db7e7SJakub Kicinski static inline int nsim_bpf_disable_tc(struct netdevsim *ns) 1907c5db7e7SJakub Kicinski { 1917c5db7e7SJakub Kicinski return 0; 1927c5db7e7SJakub Kicinski } 1937c5db7e7SJakub Kicinski 1947c5db7e7SJakub Kicinski static inline int 1957c5db7e7SJakub Kicinski nsim_bpf_setup_tc_block_cb(enum tc_setup_type type, void *type_data, 1967c5db7e7SJakub Kicinski void *cb_priv) 1977c5db7e7SJakub Kicinski { 1987c5db7e7SJakub Kicinski return -EOPNOTSUPP; 1997c5db7e7SJakub Kicinski } 2007c5db7e7SJakub Kicinski #endif 20179579220SJakub Kicinski 20237923ed6SDavid Ahern enum nsim_resource_id { 20337923ed6SDavid Ahern NSIM_RESOURCE_NONE, /* DEVLINK_RESOURCE_ID_PARENT_TOP */ 20437923ed6SDavid Ahern NSIM_RESOURCE_IPV4, 20537923ed6SDavid Ahern NSIM_RESOURCE_IPV4_FIB, 20637923ed6SDavid Ahern NSIM_RESOURCE_IPV4_FIB_RULES, 20737923ed6SDavid Ahern NSIM_RESOURCE_IPV6, 20837923ed6SDavid Ahern NSIM_RESOURCE_IPV6_FIB, 20937923ed6SDavid Ahern NSIM_RESOURCE_IPV6_FIB_RULES, 21035266255SIdo Schimmel NSIM_RESOURCE_NEXTHOPS, 21137923ed6SDavid Ahern }; 21237923ed6SDavid Ahern 21382c93a87SJiri Pirko struct nsim_dev_health { 21482c93a87SJiri Pirko struct devlink_health_reporter *empty_reporter; 21582c93a87SJiri Pirko struct devlink_health_reporter *dummy_reporter; 21682c93a87SJiri Pirko struct dentry *ddir; 21782c93a87SJiri Pirko char *recovered_break_msg; 21882c93a87SJiri Pirko u32 binary_len; 21982c93a87SJiri Pirko bool fail_recover; 22082c93a87SJiri Pirko }; 22182c93a87SJiri Pirko 22282c93a87SJiri Pirko int nsim_dev_health_init(struct nsim_dev *nsim_dev, struct devlink *devlink); 22382c93a87SJiri Pirko void nsim_dev_health_exit(struct nsim_dev *nsim_dev); 22482c93a87SJiri Pirko 2251a6d7ae7SPetr Machata struct nsim_dev_hwstats_netdev { 2261a6d7ae7SPetr Machata struct list_head list; 2271a6d7ae7SPetr Machata struct net_device *netdev; 2281a6d7ae7SPetr Machata struct rtnl_hw_stats64 stats; 2291a6d7ae7SPetr Machata bool enabled; 2301a6d7ae7SPetr Machata bool fail_enable; 2311a6d7ae7SPetr Machata }; 2321a6d7ae7SPetr Machata 2331a6d7ae7SPetr Machata struct nsim_dev_hwstats { 2341a6d7ae7SPetr Machata struct dentry *ddir; 2351a6d7ae7SPetr Machata struct dentry *l3_ddir; 2361a6d7ae7SPetr Machata 2371a6d7ae7SPetr Machata struct mutex hwsdev_list_lock; /* protects hwsdev list(s) */ 2381a6d7ae7SPetr Machata struct list_head l3_list; 2391a6d7ae7SPetr Machata 2401a6d7ae7SPetr Machata struct notifier_block netdevice_nb; 2411a6d7ae7SPetr Machata struct delayed_work traffic_dw; 2421a6d7ae7SPetr Machata }; 2431a6d7ae7SPetr Machata 2441a6d7ae7SPetr Machata int nsim_dev_hwstats_init(struct nsim_dev *nsim_dev); 2451a6d7ae7SPetr Machata void nsim_dev_hwstats_exit(struct nsim_dev *nsim_dev); 2461a6d7ae7SPetr Machata 247a8700c3dSIdo Schimmel #if IS_ENABLED(CONFIG_PSAMPLE) 248a8700c3dSIdo Schimmel int nsim_dev_psample_init(struct nsim_dev *nsim_dev); 249a8700c3dSIdo Schimmel void nsim_dev_psample_exit(struct nsim_dev *nsim_dev); 250a8700c3dSIdo Schimmel #else 251a8700c3dSIdo Schimmel static inline int nsim_dev_psample_init(struct nsim_dev *nsim_dev) 252a8700c3dSIdo Schimmel { 253a8700c3dSIdo Schimmel return 0; 254a8700c3dSIdo Schimmel } 255a8700c3dSIdo Schimmel 256a8700c3dSIdo Schimmel static inline void nsim_dev_psample_exit(struct nsim_dev *nsim_dev) 257a8700c3dSIdo Schimmel { 258a8700c3dSIdo Schimmel } 259a8700c3dSIdo Schimmel #endif 260a8700c3dSIdo Schimmel 261814b9ce6SDmytro Linkin enum nsim_dev_port_type { 262814b9ce6SDmytro Linkin NSIM_DEV_PORT_TYPE_PF, 263814b9ce6SDmytro Linkin NSIM_DEV_PORT_TYPE_VF, 264814b9ce6SDmytro Linkin }; 265814b9ce6SDmytro Linkin 266814b9ce6SDmytro Linkin #define NSIM_DEV_VF_PORT_INDEX_BASE 128 267814b9ce6SDmytro Linkin #define NSIM_DEV_VF_PORT_INDEX_MAX UINT_MAX 268814b9ce6SDmytro Linkin 2698320d145SJiri Pirko struct nsim_dev_port { 2708320d145SJiri Pirko struct list_head list; 2718320d145SJiri Pirko struct devlink_port devlink_port; 2728320d145SJiri Pirko unsigned int port_index; 273814b9ce6SDmytro Linkin enum nsim_dev_port_type port_type; 2748320d145SJiri Pirko struct dentry *ddir; 275f3d101b4SDmytro Linkin struct dentry *rate_parent; 276f3d101b4SDmytro Linkin char *parent_name; 277e05b2d14SJiri Pirko struct netdevsim *ns; 2788320d145SJiri Pirko }; 2798320d145SJiri Pirko 2805e388f3dSJakub Kicinski struct nsim_vf_config { 2815e388f3dSJakub Kicinski int link_state; 2825e388f3dSJakub Kicinski u16 min_tx_rate; 2835e388f3dSJakub Kicinski u16 max_tx_rate; 2845e388f3dSJakub Kicinski u16 vlan; 2855e388f3dSJakub Kicinski __be16 vlan_proto; 2865e388f3dSJakub Kicinski u16 qos; 2875e388f3dSJakub Kicinski u8 vf_mac[ETH_ALEN]; 2885e388f3dSJakub Kicinski bool spoofchk_enabled; 2895e388f3dSJakub Kicinski bool trusted; 2905e388f3dSJakub Kicinski bool rss_query_enabled; 2915e388f3dSJakub Kicinski }; 2925e388f3dSJakub Kicinski 293a60f9e48SJiri Pirko struct nsim_dev { 294d514f41eSJiri Pirko struct nsim_bus_dev *nsim_bus_dev; 295a60f9e48SJiri Pirko struct nsim_fib_data *fib_data; 296da58f90fSIdo Schimmel struct nsim_trap_data *trap_data; 297d514f41eSJiri Pirko struct dentry *ddir; 298ab1d0cc0SJiri Pirko struct dentry *ports_ddir; 2998526ad96STaehee Yoo struct dentry *take_snapshot; 300885226f5SDmytro Linkin struct dentry *nodes_ddir; 3015e388f3dSJakub Kicinski 3025e388f3dSJakub Kicinski struct nsim_vf_config *vfconfigs; 3035e388f3dSJakub Kicinski 304d514f41eSJiri Pirko struct bpf_offload_dev *bpf_dev; 305d514f41eSJiri Pirko bool bpf_bind_accept; 306e4ff5aa4SToke Høiland-Jørgensen bool bpf_bind_verifier_accept; 307d514f41eSJiri Pirko u32 bpf_bind_verifier_delay; 308d514f41eSJiri Pirko struct dentry *ddir_bpf_bound_progs; 309d514f41eSJiri Pirko u32 prog_id_gen; 310d514f41eSJiri Pirko struct list_head bpf_bound_progs; 311d514f41eSJiri Pirko struct list_head bpf_bound_maps; 312514cf64cSJiri Pirko struct netdev_phys_item_id switch_id; 3138320d145SJiri Pirko struct list_head port_list; 314fa4dfc4aSJiri Pirko bool fw_update_status; 315cbb58368SJacob Keller u32 fw_update_overwrite_mask; 316150e8f8aSJiri Pirko u32 max_macs; 317150e8f8aSJiri Pirko bool test1; 318155ddfc5SJiri Pirko bool dont_allow_reload; 319155ddfc5SJiri Pirko bool fail_reload; 3204418f862SJiri Pirko struct devlink_region *dummy_region; 32182c93a87SJiri Pirko struct nsim_dev_health health; 3221a6d7ae7SPetr Machata struct nsim_dev_hwstats hwstats; 323d3cbb907SJiri Pirko struct flow_action_cookie *fa_cookie; 324d3cbb907SJiri Pirko spinlock_t fa_cookie_lock; /* protects fa_cookie */ 3250dc8249aSIdo Schimmel bool fail_trap_group_set; 326ad188458SIdo Schimmel bool fail_trap_policer_set; 327ad188458SIdo Schimmel bool fail_trap_policer_counter_get; 328275b51c2SOleksandr Mazur bool fail_trap_drop_counter_get; 329424be63aSJakub Kicinski struct { 330dc9c0753SJakub Kicinski struct udp_tunnel_nic_shared utn_shared; 331dc9c0753SJakub Kicinski u32 __ports[2][NSIM_UDP_TUNNEL_N_PORTS]; 332424be63aSJakub Kicinski bool sync_all; 333424be63aSJakub Kicinski bool open_only; 334424be63aSJakub Kicinski bool ipv4_only; 335dc9c0753SJakub Kicinski bool shared; 336dda75173SJakub Kicinski bool static_iana_vxlan; 337424be63aSJakub Kicinski u32 sleep; 338424be63aSJakub Kicinski } udp_ports; 339a8700c3dSIdo Schimmel struct nsim_dev_psample *psample; 340160dc373SDmytro Linkin u16 esw_mode; 341a60f9e48SJiri Pirko }; 342a60f9e48SJiri Pirko 343160dc373SDmytro Linkin static inline bool nsim_esw_mode_is_legacy(struct nsim_dev *nsim_dev) 344160dc373SDmytro Linkin { 345160dc373SDmytro Linkin return nsim_dev->esw_mode == DEVLINK_ESWITCH_MODE_LEGACY; 346160dc373SDmytro Linkin } 347160dc373SDmytro Linkin 348160dc373SDmytro Linkin static inline bool nsim_esw_mode_is_switchdev(struct nsim_dev *nsim_dev) 349160dc373SDmytro Linkin { 350160dc373SDmytro Linkin return nsim_dev->esw_mode == DEVLINK_ESWITCH_MODE_SWITCHDEV; 351160dc373SDmytro Linkin } 352160dc373SDmytro Linkin 35390d29913SJiri Pirko static inline struct net *nsim_dev_net(struct nsim_dev *nsim_dev) 35490d29913SJiri Pirko { 35590d29913SJiri Pirko return devlink_net(priv_to_devlink(nsim_dev)); 35690d29913SJiri Pirko } 35790d29913SJiri Pirko 358d514f41eSJiri Pirko int nsim_dev_init(void); 359d514f41eSJiri Pirko void nsim_dev_exit(void); 360a66f64b8SJakub Kicinski int nsim_drv_probe(struct nsim_bus_dev *nsim_bus_dev); 361a66f64b8SJakub Kicinski void nsim_drv_remove(struct nsim_bus_dev *nsim_bus_dev); 362a66f64b8SJakub Kicinski int nsim_drv_port_add(struct nsim_bus_dev *nsim_bus_dev, 363814b9ce6SDmytro Linkin enum nsim_dev_port_type type, 364794b2c05SJiri Pirko unsigned int port_index); 365a66f64b8SJakub Kicinski int nsim_drv_port_del(struct nsim_bus_dev *nsim_bus_dev, 366814b9ce6SDmytro Linkin enum nsim_dev_port_type type, 367794b2c05SJiri Pirko unsigned int port_index); 3681c401078SJakub Kicinski int nsim_drv_configure_vfs(struct nsim_bus_dev *nsim_bus_dev, 3691c401078SJakub Kicinski unsigned int num_vfs); 37037923ed6SDavid Ahern 3715e388f3dSJakub Kicinski unsigned int nsim_dev_get_vfs(struct nsim_dev *nsim_dev); 3725e388f3dSJakub Kicinski 37375ba029fSJiri Pirko struct nsim_fib_data *nsim_fib_create(struct devlink *devlink, 37475ba029fSJiri Pirko struct netlink_ext_ack *extack); 37575ba029fSJiri Pirko void nsim_fib_destroy(struct devlink *devlink, struct nsim_fib_data *fib_data); 376a5facc4cSJiri Pirko u64 nsim_fib_get_val(struct nsim_fib_data *fib_data, 377a5facc4cSJiri Pirko enum nsim_resource_id res_id, bool max); 37837923ed6SDavid Ahern 379814b9ce6SDmytro Linkin static inline bool nsim_dev_port_is_pf(struct nsim_dev_port *nsim_dev_port) 380814b9ce6SDmytro Linkin { 381814b9ce6SDmytro Linkin return nsim_dev_port->port_type == NSIM_DEV_PORT_TYPE_PF; 382814b9ce6SDmytro Linkin } 383814b9ce6SDmytro Linkin 384814b9ce6SDmytro Linkin static inline bool nsim_dev_port_is_vf(struct nsim_dev_port *nsim_dev_port) 385814b9ce6SDmytro Linkin { 386814b9ce6SDmytro Linkin return nsim_dev_port->port_type == NSIM_DEV_PORT_TYPE_VF; 387814b9ce6SDmytro Linkin } 3887699353dSShannon Nelson #if IS_ENABLED(CONFIG_XFRM_OFFLOAD) 3897699353dSShannon Nelson void nsim_ipsec_init(struct netdevsim *ns); 3907699353dSShannon Nelson void nsim_ipsec_teardown(struct netdevsim *ns); 3917699353dSShannon Nelson bool nsim_ipsec_tx(struct netdevsim *ns, struct sk_buff *skb); 3927699353dSShannon Nelson #else 3937699353dSShannon Nelson static inline void nsim_ipsec_init(struct netdevsim *ns) 3947699353dSShannon Nelson { 3957699353dSShannon Nelson } 3967699353dSShannon Nelson 3977699353dSShannon Nelson static inline void nsim_ipsec_teardown(struct netdevsim *ns) 3987699353dSShannon Nelson { 3997699353dSShannon Nelson } 4007699353dSShannon Nelson 4017699353dSShannon Nelson static inline bool nsim_ipsec_tx(struct netdevsim *ns, struct sk_buff *skb) 4027699353dSShannon Nelson { 4037699353dSShannon Nelson return true; 4047699353dSShannon Nelson } 4057699353dSShannon Nelson #endif 4067699353dSShannon Nelson 40702b34d03SSabrina Dubroca #if IS_ENABLED(CONFIG_MACSEC) 40802b34d03SSabrina Dubroca void nsim_macsec_init(struct netdevsim *ns); 40902b34d03SSabrina Dubroca void nsim_macsec_teardown(struct netdevsim *ns); 41002b34d03SSabrina Dubroca #else 41102b34d03SSabrina Dubroca static inline void nsim_macsec_init(struct netdevsim *ns) 41202b34d03SSabrina Dubroca { 41302b34d03SSabrina Dubroca } 41402b34d03SSabrina Dubroca 41502b34d03SSabrina Dubroca static inline void nsim_macsec_teardown(struct netdevsim *ns) 41602b34d03SSabrina Dubroca { 41702b34d03SSabrina Dubroca } 41802b34d03SSabrina Dubroca #endif 41902b34d03SSabrina Dubroca 42040e4fe4cSJiri Pirko struct nsim_bus_dev { 42140e4fe4cSJiri Pirko struct device dev; 422f9d9db47SJiri Pirko struct list_head list; 423f9d9db47SJiri Pirko unsigned int port_count; 424d4861fc6SPeilin Ye unsigned int num_queues; /* Number of queues for each port on this bus */ 4257b60027bSJiri Pirko struct net *initial_net; /* Purpose of this is to carry net pointer 4267b60027bSJiri Pirko * during the probe time only. 4277b60027bSJiri Pirko */ 428d3953819SDmytro Linkin unsigned int max_vfs; 42940e4fe4cSJiri Pirko unsigned int num_vfs; 430f5cd2160STaehee Yoo bool init; 43140e4fe4cSJiri Pirko }; 432925f5afeSJiri Pirko 433925f5afeSJiri Pirko int nsim_bus_init(void); 434925f5afeSJiri Pirko void nsim_bus_exit(void); 435