Lines Matching +full:sparx5 +full:- +full:switch

1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /* Microchip Sparx5 Switch driver
29 SPX5_TARGET_CT_7546 = 0x7546, /* SparX-5-64 Enterprise */
30 SPX5_TARGET_CT_7549 = 0x7549, /* SparX-5-90 Enterprise */
31 SPX5_TARGET_CT_7552 = 0x7552, /* SparX-5-128 Enterprise */
32 SPX5_TARGET_CT_7556 = 0x7556, /* SparX-5-160 Enterprise */
33 SPX5_TARGET_CT_7558 = 0x7558, /* SparX-5-200 Enterprise */
34 SPX5_TARGET_CT_7546TSN = 0x47546, /* SparX-5-64i Industrial */
35 SPX5_TARGET_CT_7549TSN = 0x47549, /* SparX-5-90i Industrial */
36 SPX5_TARGET_CT_7552TSN = 0x47552, /* SparX-5-128i Industrial */
37 SPX5_TARGET_CT_7556TSN = 0x47556, /* SparX-5-160i Industrial */
38 SPX5_TARGET_CT_7558TSN = 0x47558, /* SparX-5-200i Industrial */
49 SPX5_VLAN_PORT_TYPE_C, /* C-port */
50 SPX5_VLAN_PORT_TYPE_S, /* S-port */
51 SPX5_VLAN_PORT_TYPE_S_CUSTOM /* S-port using custom type */
103 struct sparx5;
147 struct sparx5 *sparx5; member
188 struct sparx5 *sparx5; member
227 ((struct sparx5_skb_cb *)((skb)->cb))
229 struct sparx5 { struct
253 /* Switch state */
299 int sparx5_register_notifier_blocks(struct sparx5 *sparx5); argument
300 void sparx5_unregister_notifier_blocks(struct sparx5 *sparx5);
308 void sparx5_xtr_flush(struct sparx5 *sparx5, u8 grp);
312 int sparx5_manual_injection_mode(struct sparx5 *sparx5);
316 int sparx5_fdma_start(struct sparx5 *sparx5);
317 int sparx5_fdma_stop(struct sparx5 *sparx5);
318 int sparx5_fdma_xmit(struct sparx5 *sparx5, u32 *ifh, struct sk_buff *skb);
323 int sparx5_mact_learn(struct sparx5 *sparx5, int port,
325 bool sparx5_mact_getnext(struct sparx5 *sparx5,
327 int sparx5_mact_find(struct sparx5 *sparx5,
329 int sparx5_mact_forget(struct sparx5 *sparx5,
331 int sparx5_add_mact_entry(struct sparx5 *sparx5,
335 int sparx5_del_mact_entry(struct sparx5 *sparx5,
340 void sparx5_set_ageing(struct sparx5 *sparx5, int msecs);
341 void sparx5_mact_init(struct sparx5 *sparx5);
345 void sparx5_pgid_clear(struct sparx5 *spx5, int pgid);
346 void sparx5_pgid_read_mask(struct sparx5 *sparx5, int pgid, u32 portmask[3]);
347 void sparx5_update_fwd(struct sparx5 *sparx5);
348 void sparx5_vlan_init(struct sparx5 *sparx5);
349 void sparx5_vlan_port_setup(struct sparx5 *sparx5, int portno);
353 void sparx5_vlan_port_apply(struct sparx5 *sparx5, struct sparx5_port *port);
356 int sparx5_config_auto_calendar(struct sparx5 *sparx5);
357 int sparx5_config_dsm_calendar(struct sparx5 *sparx5);
361 int sparx_stats_init(struct sparx5 *sparx5);
365 int sparx5_dcb_init(struct sparx5 *sparx5);
367 static inline int sparx5_dcb_init(struct sparx5 *sparx5) in sparx5_dcb_init() argument
380 struct net_device *sparx5_create_netdev(struct sparx5 *sparx5, u32 portno);
381 int sparx5_register_netdevs(struct sparx5 *sparx5);
382 void sparx5_destroy_netdevs(struct sparx5 *sparx5);
383 void sparx5_unregister_netdevs(struct sparx5 *sparx5);
386 int sparx5_ptp_init(struct sparx5 *sparx5);
387 void sparx5_ptp_deinit(struct sparx5 *sparx5);
393 void sparx5_ptp_rxtstamp(struct sparx5 *sparx5, struct sk_buff *skb,
403 int sparx5_vcap_init(struct sparx5 *sparx5);
404 void sparx5_vcap_destroy(struct sparx5 *sparx5);
413 void sparx5_pgid_init(struct sparx5 *spx5);
414 int sparx5_pgid_alloc_mcast(struct sparx5 *spx5, u16 *idx);
415 int sparx5_pgid_free(struct sparx5 *spx5, u16 idx);
431 #define SPX5_SDLB_PUP_TOKEN_MAX (SPX5_SDLB_PUP_TOKEN_DISABLE - 1)
447 int sparx5_sdlb_pup_token_get(struct sparx5 *sparx5, u32 pup_interval,
450 int sparx5_sdlb_clk_hz_get(struct sparx5 *sparx5);
451 int sparx5_sdlb_group_get_by_rate(struct sparx5 *sparx5, u32 rate, u32 burst);
452 int sparx5_sdlb_group_get_by_index(struct sparx5 *sparx5, u32 idx, u32 *group);
454 int sparx5_sdlb_group_add(struct sparx5 *sparx5, u32 group, u32 idx);
455 int sparx5_sdlb_group_del(struct sparx5 *sparx5, u32 group, u32 idx);
457 void sparx5_sdlb_group_init(struct sparx5 *sparx5, u64 max_rate, u32 min_burst,
475 int sparx5_policer_conf_set(struct sparx5 *sparx5, struct sparx5_policer *pol);
481 #define SPX5_PSFP_SG_MAX_CYCLE_TIME_NS ((1 * NSEC_PER_SEC) - 1)
482 #define SPX5_PSFP_SG_MAX_IPV (SPX5_PRIOS - 1)
483 #define SPX5_PSFP_SG_OPEN (SPX5_PSFP_SG_CNT - 1)
517 int sparx5_psfp_fm_add(struct sparx5 *sparx5, u32 uidx,
519 int sparx5_psfp_fm_del(struct sparx5 *sparx5, u32 id);
521 int sparx5_psfp_sg_add(struct sparx5 *sparx5, u32 uidx,
523 int sparx5_psfp_sg_del(struct sparx5 *sparx5, u32 id);
525 int sparx5_psfp_sf_add(struct sparx5 *sparx5, const struct sparx5_psfp_sf *sf,
527 int sparx5_psfp_sf_del(struct sparx5 *sparx5, u32 id);
529 u32 sparx5_psfp_isdx_get_sf(struct sparx5 *sparx5, u32 isdx);
530 u32 sparx5_psfp_isdx_get_fm(struct sparx5 *sparx5, u32 isdx);
531 u32 sparx5_psfp_sf_get_sg(struct sparx5 *sparx5, u32 sfid);
532 void sparx5_isdx_conf_set(struct sparx5 *sparx5, u32 isdx, u32 sfid, u32 fmid);
534 void sparx5_psfp_init(struct sparx5 *sparx5);
537 void sparx5_new_base_time(struct sparx5 *sparx5, const u32 cycle_time,
549 switch (cclock) { in sparx5_clk_period()
617 static inline u32 spx5_rd(struct sparx5 *sparx5, int id, int tinst, int tcnt, in spx5_rd() argument
621 return readl(spx5_addr(sparx5->regs, id, tinst, tcnt, gbase, ginst, in spx5_rd()
633 static inline void spx5_wr(u32 val, struct sparx5 *sparx5, in spx5_wr() argument
638 writel(val, spx5_addr(sparx5->regs, id, tinst, tcnt, in spx5_wr()
653 static inline void spx5_rmw(u32 val, u32 mask, struct sparx5 *sparx5, in spx5_rmw() argument
660 nval = readl(spx5_addr(sparx5->regs, id, tinst, tcnt, gbase, ginst, in spx5_rmw()
663 writel(nval, spx5_addr(sparx5->regs, id, tinst, tcnt, gbase, ginst, in spx5_rmw()
681 static inline void __iomem *spx5_inst_get(struct sparx5 *sparx5, int id, int tinst) in spx5_inst_get() argument
683 return sparx5->regs[id + tinst]; in spx5_inst_get()
686 static inline void __iomem *spx5_reg_get(struct sparx5 *sparx5, in spx5_reg_get() argument
691 return spx5_addr(sparx5->regs, id, tinst, tcnt, in spx5_reg_get()