root/drivers/net/dsa/vitesse-vsc73xx.h
/* SPDX-License-Identifier: GPL-2.0 */
#include <linux/device.h>
#include <linux/etherdevice.h>
#include <linux/gpio/driver.h>

/* The VSC7395 switch chips have 5+1 ports which means 5 ordinary ports and
 * a sixth CPU port facing the processor with an RGMII interface. These ports
 * are numbered 0..4 and 6, so they leave a "hole" in the port map for port 5,
 * which is invalid.
 *
 * The VSC7398 has 8 ports, port 7 is again the CPU port.
 *
 * We allocate 8 ports and avoid access to the nonexistent ports.
 */
#define VSC73XX_MAX_NUM_PORTS   8

/**
 * struct vsc73xx_portinfo - port data structure: contains storage data
 * @pvid_vlan_filtering: pvid vlan number used in vlan filtering mode
 * @pvid_tag_8021q: pvid vlan number used in tag_8021q mode
 * @pvid_vlan_filtering_configured: informs if port has configured pvid in vlan
 *      filtering mode
 * @pvid_tag_8021q_configured: imforms if port have configured pvid in tag_8021q
 *      mode
 */
struct vsc73xx_portinfo {
        u16             pvid_vlan_filtering;
        u16             pvid_tag_8021q;
        bool            pvid_vlan_filtering_configured;
        bool            pvid_tag_8021q_configured;
};

/**
 * struct vsc73xx - VSC73xx state container: main data structure
 * @dev: The device pointer
 * @reset: The descriptor for the GPIO line tied to the reset pin
 * @ds: Pointer to the DSA core structure
 * @gc: Main structure of the GPIO controller
 * @chipid: Storage for the Chip ID value read from the CHIPID register of the
 *      switch
 * @addr: MAC address used in flow control frames
 * @ops: Structure with hardware-dependent operations
 * @priv: Pointer to the configuration interface structure
 * @portinfo: Storage table portinfo structructures
 * @vlans: List of configured vlans. Contains port mask and untagged status of
 *      every vlan configured in port vlan operation. It doesn't cover tag_8021q
 *      vlans.
 * @fdb_lock: Mutex protects fdb access
 */
struct vsc73xx {
        struct device                   *dev;
        struct gpio_desc                *reset;
        struct dsa_switch               *ds;
        struct gpio_chip                gc;
        u16                             chipid;
        u8                              addr[ETH_ALEN];
        const struct vsc73xx_ops        *ops;
        void                            *priv;
        struct vsc73xx_portinfo         portinfo[VSC73XX_MAX_NUM_PORTS];
        struct list_head                vlans;
        struct mutex                    fdb_lock;
};

/**
 * struct vsc73xx_ops - VSC73xx methods container
 * @read: Method for register reading over the hardware-dependent interface
 * @write: Method for register writing over the hardware-dependent interface
 */
struct vsc73xx_ops {
        int (*read)(struct vsc73xx *vsc, u8 block, u8 subblock, u8 reg,
                    u32 *val);
        int (*write)(struct vsc73xx *vsc, u8 block, u8 subblock, u8 reg,
                     u32 val);
};

/**
 * struct vsc73xx_bridge_vlan - VSC73xx driver structure which keeps vlan
 *      database copy
 * @vid: VLAN number
 * @portmask: each bit represents one port
 * @untagged: each bit represents one port configured with @vid untagged
 * @list: list structure
 */
struct vsc73xx_bridge_vlan {
        u16 vid;
        u8 portmask;
        u8 untagged;
        struct list_head list;
};

int vsc73xx_is_addr_valid(u8 block, u8 subblock);
int vsc73xx_probe(struct vsc73xx *vsc);
void vsc73xx_remove(struct vsc73xx *vsc);
void vsc73xx_shutdown(struct vsc73xx *vsc);