hc
2024-10-12 a5969cabbb4660eab42b6ef0412cbbd1200cf14d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright 2019 NXP Semiconductors
 */
#ifndef _MSCC_FELIX_H
#define _MSCC_FELIX_H
 
#define ocelot_to_felix(o)        container_of((o), struct felix, ocelot)
#define FELIX_NUM_TC            8
 
/* Platform-specific information */
struct felix_info {
   const struct resource        *target_io_res;
   const struct resource        *port_io_res;
   const struct resource        *imdio_res;
   const struct reg_field        *regfields;
   const u32 *const        *map;
   const struct ocelot_ops        *ops;
   int                shared_queue_sz;
   int                num_mact_rows;
   const struct ocelot_stat_layout    *stats_layout;
   unsigned int            num_stats;
   int                num_ports;
   int                num_tx_queues;
   struct vcap_props        *vcap;
   int                switch_pci_bar;
   int                imdio_pci_bar;
   const struct ptp_clock_info    *ptp_caps;
   int    (*mdio_bus_alloc)(struct ocelot *ocelot);
   void    (*mdio_bus_free)(struct ocelot *ocelot);
   void    (*phylink_validate)(struct ocelot *ocelot, int port,
                   unsigned long *supported,
                   struct phylink_link_state *state);
   int    (*prevalidate_phy_mode)(struct ocelot *ocelot, int port,
                   phy_interface_t phy_mode);
   int    (*port_setup_tc)(struct dsa_switch *ds, int port,
                enum tc_setup_type type, void *type_data);
   void    (*port_sched_speed_set)(struct ocelot *ocelot, int port,
                   u32 speed);
   void    (*xmit_template_populate)(struct ocelot *ocelot, int port);
};
 
extern const struct dsa_switch_ops felix_switch_ops;
 
/* DSA glue / front-end for struct ocelot */
struct felix {
   struct dsa_switch        *ds;
   const struct felix_info        *info;
   struct ocelot            ocelot;
   struct mii_bus            *imdio;
   struct lynx_pcs            **pcs;
   resource_size_t            switch_base;
   resource_size_t            imdio_base;
};
 
struct net_device *felix_port_to_netdev(struct ocelot *ocelot, int port);
int felix_netdev_to_port(struct net_device *dev);
 
#endif