mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
075e3d30e4
This commit introduces implementations of three functions: .port_fdb_dump .port_fdb_add .port_fdb_del The FDB database organization is the same as in other old Vitesse chips: It has 2048 rows and 4 columns (buckets). The row index is calculated by the hash function 'vsc73xx_calc_hash' and the FDB entry must be placed exactly into row[hash]. The chip selects the bucket number by itself. Signed-off-by: Pawel Dembicki <paweldembicki@gmail.com> Link: https://patch.msgid.link/20240827123938.582789-1-paweldembicki@gmail.com Signed-off-by: Paolo Abeni <pabeni@redhat.com>
95 lines
3.0 KiB
C
95 lines
3.0 KiB
C
/* 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);
|