Make ocelot-core truly bus-agnostic by letting the bus-specific part set an ->init_regmap callback in struct ocelot_ddata, instead of relying on the bus being spi. With this, the only symbol in the MFD_OCELOT_SPI namespace vanishes, and hence ocelot-core should no longer import that. This is preparation for adding support for mdio-based management of the Ocelot chip. Signed-off-by: Rasmus Villemoes <ravi@xxxxxxxxx> --- drivers/mfd/ocelot-core.c | 5 +++-- drivers/mfd/ocelot-spi.c | 4 ++-- drivers/mfd/ocelot.h | 6 ++---- 3 files changed, 7 insertions(+), 8 deletions(-) diff --git a/drivers/mfd/ocelot-core.c b/drivers/mfd/ocelot-core.c index 41aff27088548..78b5fe15efdd2 100644 --- a/drivers/mfd/ocelot-core.c +++ b/drivers/mfd/ocelot-core.c @@ -200,10 +200,12 @@ static const struct mfd_cell vsc7512_devs[] = { static void ocelot_core_try_add_regmap(struct device *dev, const struct resource *res) { + struct ocelot_ddata *ddata = dev_get_drvdata(dev); + if (dev_get_regmap(dev, res->name)) return; - ocelot_spi_init_regmap(dev, res); + ddata->init_regmap(dev, res); } static void ocelot_core_try_add_regmaps(struct device *dev, @@ -231,4 +233,3 @@ EXPORT_SYMBOL_NS(ocelot_core_init, "MFD_OCELOT"); MODULE_DESCRIPTION("Externally Controlled Ocelot Chip Driver"); MODULE_AUTHOR("Colin Foster <colin.foster@xxxxxxxxxxxxxxxx>"); MODULE_LICENSE("GPL"); -MODULE_IMPORT_NS("MFD_OCELOT_SPI"); diff --git a/drivers/mfd/ocelot-spi.c b/drivers/mfd/ocelot-spi.c index 1fed9878c3231..a320a613d00e1 100644 --- a/drivers/mfd/ocelot-spi.c +++ b/drivers/mfd/ocelot-spi.c @@ -181,7 +181,7 @@ static const struct regmap_bus ocelot_spi_regmap_bus = { .read = ocelot_spi_regmap_bus_read, }; -struct regmap *ocelot_spi_init_regmap(struct device *dev, const struct resource *res) +static struct regmap *ocelot_spi_init_regmap(struct device *dev, const struct resource *res) { struct regmap_config regmap_config; @@ -193,7 +193,6 @@ struct regmap *ocelot_spi_init_regmap(struct device *dev, const struct resource return devm_regmap_init(dev, &ocelot_spi_regmap_bus, dev, ®map_config); } -EXPORT_SYMBOL_NS(ocelot_spi_init_regmap, "MFD_OCELOT_SPI"); static int ocelot_spi_probe(struct spi_device *spi) { @@ -207,6 +206,7 @@ static int ocelot_spi_probe(struct spi_device *spi) return -ENOMEM; spi_set_drvdata(spi, ddata); + ddata->init_regmap = ocelot_spi_init_regmap; if (spi->max_speed_hz <= 500000) { ddata->spi_padding_bytes = 0; diff --git a/drivers/mfd/ocelot.h b/drivers/mfd/ocelot.h index b8bc2f1486e24..4305e7a55cb1a 100644 --- a/drivers/mfd/ocelot.h +++ b/drivers/mfd/ocelot.h @@ -12,6 +12,7 @@ struct resource; /** * struct ocelot_ddata - Private data for an external Ocelot chip + * @init_regmap: Bus-specific callback for initializing regmap. * @gcb_regmap: General Configuration Block regmap. Used for * operations like chip reset. * @cpuorg_regmap: CPU Device Origin Block regmap. Used for operations @@ -24,6 +25,7 @@ struct resource; * data of a SPI read operation. */ struct ocelot_ddata { + struct regmap * (*init_regmap)(struct device *dev, const struct resource *res); struct regmap *gcb_regmap; struct regmap *cpuorg_regmap; int spi_padding_bytes; @@ -33,10 +35,6 @@ struct ocelot_ddata { 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 -- 2.49.0