mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-18 11:17:07 +00:00
f3e893626a
The VSC7512 is a networking chip that contains several peripherals. Many of these peripherals are currently supported by the VSC7513 and VSC7514 chips, but those run on an internal CPU. The VSC7512 lacks this CPU, and must be controlled externally. Utilize the existing drivers by referencing the chip as an MFD. Add support for the two MDIO buses, the internal phys, pinctrl, and serial GPIO. Signed-off-by: Colin Foster <colin.foster@in-advantage.com> Reviewed-by: Vladimir Oltean <vladimir.oltean@nxp.com> Signed-off-by: Lee Jones <lee@kernel.org> Link: https://lore.kernel.org/r/20220905162132.2943088-9-colin.foster@in-advantage.com
50 lines
1.4 KiB
C
50 lines
1.4 KiB
C
/* SPDX-License-Identifier: GPL-2.0 OR MIT */
|
|
/* Copyright 2021, 2022 Innovative Advantage Inc. */
|
|
|
|
#ifndef _MFD_OCELOT_H
|
|
#define _MFD_OCELOT_H
|
|
|
|
#include <linux/kconfig.h>
|
|
|
|
struct device;
|
|
struct regmap;
|
|
struct resource;
|
|
|
|
/**
|
|
* struct ocelot_ddata - Private data for an external Ocelot chip
|
|
* @gcb_regmap: General Configuration Block regmap. Used for
|
|
* operations like chip reset.
|
|
* @cpuorg_regmap: CPU Device Origin Block regmap. Used for operations
|
|
* like SPI bus configuration.
|
|
* @spi_padding_bytes: Number of padding bytes that must be thrown out before
|
|
* read data gets returned. This is calculated during
|
|
* initialization based on bus speed.
|
|
* @dummy_buf: Zero-filled buffer of spi_padding_bytes size. The dummy
|
|
* bytes that will be sent out between the address and
|
|
* data of a SPI read operation.
|
|
*/
|
|
struct ocelot_ddata {
|
|
struct regmap *gcb_regmap;
|
|
struct regmap *cpuorg_regmap;
|
|
int spi_padding_bytes;
|
|
void *dummy_buf;
|
|
};
|
|
|
|
int ocelot_chip_reset(struct device *dev);
|
|
int ocelot_core_init(struct device *dev);
|
|
|
|
/* SPI-specific routines that won't be necessary for other interfaces */
|
|
struct regmap *ocelot_spi_init_regmap(struct device *dev,
|
|
const struct resource *res);
|
|
|
|
#define OCELOT_SPI_BYTE_ORDER_LE 0x00000000
|
|
#define OCELOT_SPI_BYTE_ORDER_BE 0x81818181
|
|
|
|
#ifdef __LITTLE_ENDIAN
|
|
#define OCELOT_SPI_BYTE_ORDER OCELOT_SPI_BYTE_ORDER_LE
|
|
#else
|
|
#define OCELOT_SPI_BYTE_ORDER OCELOT_SPI_BYTE_ORDER_BE
|
|
#endif
|
|
|
|
#endif
|