mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-27 17:36:25 +07:00
95711cd5f0
This driver (currently) only takes control of the switch chip over SPI and configures it to route packages around when connected to a CPU port. But Vitesse chip support also parallel interface. This patch split driver into two parts: core and spi. It is required for add support to another managing interface. Tested-by: Linus Walleij <linus.walleij@linaro.org> Signed-off-by: Pawel Dembicki <paweldembicki@gmail.com> Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
30 lines
707 B
C
30 lines
707 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#include <linux/device.h>
|
|
#include <linux/etherdevice.h>
|
|
#include <linux/gpio/driver.h>
|
|
|
|
/**
|
|
* struct vsc73xx - VSC73xx state container
|
|
*/
|
|
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_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);
|
|
};
|
|
|
|
int vsc73xx_is_addr_valid(u8 block, u8 subblock);
|
|
int vsc73xx_probe(struct vsc73xx *vsc);
|
|
int vsc73xx_remove(struct vsc73xx *vsc);
|