mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-17 02:15:57 +00:00
mfd: intel-m10-bmc: Create m10bmc_platform_info for type specific info
BMC type specific info is currently set by a switch/case block. The size of this info is expected to grow as more dev types and features are added which would have made the switch block bloaty. Store type specific info into struct and place them into .driver_data instead because it makes things a bit cleaner. The m10bmc_type enum can be dropped as the differentiation is now fully handled by the platform info. The info member of struct intel_m10bmc that is added here is not used yet in this change but its addition logically still belongs to this change. The CSR map change that comes after this change needs to have the info member. Reviewed-by: Russ Weight <russell.h.weight@intel.com> Reviewed-by: Xu Yilun <yilun.xu@intel.com> Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> Signed-off-by: Lee Jones <lee@kernel.org> Link: https://lore.kernel.org/r/20230116100845.6153-3-ilpo.jarvinen@linux.intel.com
This commit is contained in:
parent
206351c5c2
commit
16e5d95a5c
@ -13,12 +13,6 @@
|
|||||||
#include <linux/regmap.h>
|
#include <linux/regmap.h>
|
||||||
#include <linux/spi/spi.h>
|
#include <linux/spi/spi.h>
|
||||||
|
|
||||||
enum m10bmc_type {
|
|
||||||
M10_N3000,
|
|
||||||
M10_D5005,
|
|
||||||
M10_N5010,
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct mfd_cell m10bmc_d5005_subdevs[] = {
|
static struct mfd_cell m10bmc_d5005_subdevs[] = {
|
||||||
{ .name = "d5005bmc-hwmon" },
|
{ .name = "d5005bmc-hwmon" },
|
||||||
{ .name = "d5005bmc-sec-update" }
|
{ .name = "d5005bmc-sec-update" }
|
||||||
@ -162,15 +156,17 @@ static int check_m10bmc_version(struct intel_m10bmc *ddata)
|
|||||||
static int intel_m10_bmc_spi_probe(struct spi_device *spi)
|
static int intel_m10_bmc_spi_probe(struct spi_device *spi)
|
||||||
{
|
{
|
||||||
const struct spi_device_id *id = spi_get_device_id(spi);
|
const struct spi_device_id *id = spi_get_device_id(spi);
|
||||||
|
const struct intel_m10bmc_platform_info *info;
|
||||||
struct device *dev = &spi->dev;
|
struct device *dev = &spi->dev;
|
||||||
struct mfd_cell *cells;
|
|
||||||
struct intel_m10bmc *ddata;
|
struct intel_m10bmc *ddata;
|
||||||
int ret, n_cell;
|
int ret;
|
||||||
|
|
||||||
ddata = devm_kzalloc(dev, sizeof(*ddata), GFP_KERNEL);
|
ddata = devm_kzalloc(dev, sizeof(*ddata), GFP_KERNEL);
|
||||||
if (!ddata)
|
if (!ddata)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
|
info = (struct intel_m10bmc_platform_info *)id->driver_data;
|
||||||
|
ddata->info = info;
|
||||||
ddata->dev = dev;
|
ddata->dev = dev;
|
||||||
|
|
||||||
ddata->regmap =
|
ddata->regmap =
|
||||||
@ -189,24 +185,8 @@ static int intel_m10_bmc_spi_probe(struct spi_device *spi)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (id->driver_data) {
|
ret = devm_mfd_add_devices(dev, PLATFORM_DEVID_AUTO,
|
||||||
case M10_N3000:
|
info->cells, info->n_cells,
|
||||||
cells = m10bmc_pacn3000_subdevs;
|
|
||||||
n_cell = ARRAY_SIZE(m10bmc_pacn3000_subdevs);
|
|
||||||
break;
|
|
||||||
case M10_D5005:
|
|
||||||
cells = m10bmc_d5005_subdevs;
|
|
||||||
n_cell = ARRAY_SIZE(m10bmc_d5005_subdevs);
|
|
||||||
break;
|
|
||||||
case M10_N5010:
|
|
||||||
cells = m10bmc_n5010_subdevs;
|
|
||||||
n_cell = ARRAY_SIZE(m10bmc_n5010_subdevs);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return -ENODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = devm_mfd_add_devices(dev, PLATFORM_DEVID_AUTO, cells, n_cell,
|
|
||||||
NULL, 0, NULL);
|
NULL, 0, NULL);
|
||||||
if (ret)
|
if (ret)
|
||||||
dev_err(dev, "Failed to register sub-devices: %d\n", ret);
|
dev_err(dev, "Failed to register sub-devices: %d\n", ret);
|
||||||
@ -214,10 +194,25 @@ static int intel_m10_bmc_spi_probe(struct spi_device *spi)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const struct intel_m10bmc_platform_info m10bmc_spi_n3000 = {
|
||||||
|
.cells = m10bmc_pacn3000_subdevs,
|
||||||
|
.n_cells = ARRAY_SIZE(m10bmc_pacn3000_subdevs),
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct intel_m10bmc_platform_info m10bmc_spi_d5005 = {
|
||||||
|
.cells = m10bmc_d5005_subdevs,
|
||||||
|
.n_cells = ARRAY_SIZE(m10bmc_d5005_subdevs),
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct intel_m10bmc_platform_info m10bmc_spi_n5010 = {
|
||||||
|
.cells = m10bmc_n5010_subdevs,
|
||||||
|
.n_cells = ARRAY_SIZE(m10bmc_n5010_subdevs),
|
||||||
|
};
|
||||||
|
|
||||||
static const struct spi_device_id m10bmc_spi_id[] = {
|
static const struct spi_device_id m10bmc_spi_id[] = {
|
||||||
{ "m10-n3000", M10_N3000 },
|
{ "m10-n3000", (kernel_ulong_t)&m10bmc_spi_n3000 },
|
||||||
{ "m10-d5005", M10_D5005 },
|
{ "m10-d5005", (kernel_ulong_t)&m10bmc_spi_d5005 },
|
||||||
{ "m10-n5010", M10_N5010 },
|
{ "m10-n5010", (kernel_ulong_t)&m10bmc_spi_n5010 },
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(spi, m10bmc_spi_id);
|
MODULE_DEVICE_TABLE(spi, m10bmc_spi_id);
|
||||||
|
@ -121,14 +121,26 @@
|
|||||||
/* Address of 4KB inverted bit vector containing staging area FLASH count */
|
/* Address of 4KB inverted bit vector containing staging area FLASH count */
|
||||||
#define STAGING_FLASH_COUNT 0x17ffb000
|
#define STAGING_FLASH_COUNT 0x17ffb000
|
||||||
|
|
||||||
|
/**
|
||||||
|
* struct intel_m10bmc_platform_info - Intel MAX 10 BMC platform specific information
|
||||||
|
* @cells: MFD cells
|
||||||
|
* @n_cells: MFD cells ARRAY_SIZE()
|
||||||
|
*/
|
||||||
|
struct intel_m10bmc_platform_info {
|
||||||
|
struct mfd_cell *cells;
|
||||||
|
int n_cells;
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct intel_m10bmc - Intel MAX 10 BMC parent driver data structure
|
* struct intel_m10bmc - Intel MAX 10 BMC parent driver data structure
|
||||||
* @dev: this device
|
* @dev: this device
|
||||||
* @regmap: the regmap used to access registers by m10bmc itself
|
* @regmap: the regmap used to access registers by m10bmc itself
|
||||||
|
* @info: the platform information for MAX10 BMC
|
||||||
*/
|
*/
|
||||||
struct intel_m10bmc {
|
struct intel_m10bmc {
|
||||||
struct device *dev;
|
struct device *dev;
|
||||||
struct regmap *regmap;
|
struct regmap *regmap;
|
||||||
|
const struct intel_m10bmc_platform_info *info;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user