Commit 1172460e authored by Miquel Raynal's avatar Miquel Raynal Committed by Greg Kroah-Hartman

nvmem: Move and rename ->fixup_cell_info()

This hook is meant to be used by any provider and instantiating a layout
just for this is useless. Let's instead move this hook to the nvmem
device and add it to the config structure to be easily shared by the
providers.

While at moving this hook, rename it ->fixup_dt_cell_info() to clarify
its main intended purpose.
Signed-off-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
Signed-off-by: default avatarSrinivas Kandagatla <srinivas.kandagatla@linaro.org>
Link: https://lore.kernel.org/r/20231215111536.316972-6-srinivas.kandagatla@linaro.orgSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 1b7c298a
...@@ -675,7 +675,6 @@ static int nvmem_validate_keepouts(struct nvmem_device *nvmem) ...@@ -675,7 +675,6 @@ static int nvmem_validate_keepouts(struct nvmem_device *nvmem)
static int nvmem_add_cells_from_dt(struct nvmem_device *nvmem, struct device_node *np) static int nvmem_add_cells_from_dt(struct nvmem_device *nvmem, struct device_node *np)
{ {
struct nvmem_layout *layout = nvmem->layout;
struct device *dev = &nvmem->dev; struct device *dev = &nvmem->dev;
struct device_node *child; struct device_node *child;
const __be32 *addr; const __be32 *addr;
...@@ -705,8 +704,8 @@ static int nvmem_add_cells_from_dt(struct nvmem_device *nvmem, struct device_nod ...@@ -705,8 +704,8 @@ static int nvmem_add_cells_from_dt(struct nvmem_device *nvmem, struct device_nod
info.np = of_node_get(child); info.np = of_node_get(child);
if (layout && layout->fixup_cell_info) if (nvmem->fixup_dt_cell_info)
layout->fixup_cell_info(nvmem, layout, &info); nvmem->fixup_dt_cell_info(nvmem, &info);
ret = nvmem_add_one_cell(nvmem, &info); ret = nvmem_add_one_cell(nvmem, &info);
kfree(info.name); kfree(info.name);
...@@ -895,6 +894,7 @@ struct nvmem_device *nvmem_register(const struct nvmem_config *config) ...@@ -895,6 +894,7 @@ struct nvmem_device *nvmem_register(const struct nvmem_config *config)
kref_init(&nvmem->refcnt); kref_init(&nvmem->refcnt);
INIT_LIST_HEAD(&nvmem->cells); INIT_LIST_HEAD(&nvmem->cells);
nvmem->fixup_dt_cell_info = config->fixup_dt_cell_info;
nvmem->owner = config->owner; nvmem->owner = config->owner;
if (!nvmem->owner && config->dev->driver) if (!nvmem->owner && config->dev->driver)
......
...@@ -583,17 +583,12 @@ static const struct of_device_id imx_ocotp_dt_ids[] = { ...@@ -583,17 +583,12 @@ static const struct of_device_id imx_ocotp_dt_ids[] = {
}; };
MODULE_DEVICE_TABLE(of, imx_ocotp_dt_ids); MODULE_DEVICE_TABLE(of, imx_ocotp_dt_ids);
static void imx_ocotp_fixup_cell_info(struct nvmem_device *nvmem, static void imx_ocotp_fixup_dt_cell_info(struct nvmem_device *nvmem,
struct nvmem_layout *layout,
struct nvmem_cell_info *cell) struct nvmem_cell_info *cell)
{ {
cell->read_post_process = imx_ocotp_cell_pp; cell->read_post_process = imx_ocotp_cell_pp;
} }
static struct nvmem_layout imx_ocotp_layout = {
.fixup_cell_info = imx_ocotp_fixup_cell_info,
};
static int imx_ocotp_probe(struct platform_device *pdev) static int imx_ocotp_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
...@@ -619,7 +614,7 @@ static int imx_ocotp_probe(struct platform_device *pdev) ...@@ -619,7 +614,7 @@ static int imx_ocotp_probe(struct platform_device *pdev)
imx_ocotp_nvmem_config.size = 4 * priv->params->nregs; imx_ocotp_nvmem_config.size = 4 * priv->params->nregs;
imx_ocotp_nvmem_config.dev = dev; imx_ocotp_nvmem_config.dev = dev;
imx_ocotp_nvmem_config.priv = priv; imx_ocotp_nvmem_config.priv = priv;
imx_ocotp_nvmem_config.layout = &imx_ocotp_layout; imx_ocotp_nvmem_config.fixup_dt_cell_info = &imx_ocotp_fixup_dt_cell_info;
priv->config = &imx_ocotp_nvmem_config; priv->config = &imx_ocotp_nvmem_config;
......
...@@ -23,6 +23,8 @@ struct nvmem_device { ...@@ -23,6 +23,8 @@ struct nvmem_device {
struct bin_attribute eeprom; struct bin_attribute eeprom;
struct device *base_dev; struct device *base_dev;
struct list_head cells; struct list_head cells;
void (*fixup_dt_cell_info)(struct nvmem_device *nvmem,
struct nvmem_cell_info *cell);
const struct nvmem_keepout *keepout; const struct nvmem_keepout *keepout;
unsigned int nkeepout; unsigned int nkeepout;
nvmem_reg_read_t reg_read; nvmem_reg_read_t reg_read;
......
...@@ -45,8 +45,7 @@ static int mtk_efuse_gpu_speedbin_pp(void *context, const char *id, int index, ...@@ -45,8 +45,7 @@ static int mtk_efuse_gpu_speedbin_pp(void *context, const char *id, int index,
return 0; return 0;
} }
static void mtk_efuse_fixup_cell_info(struct nvmem_device *nvmem, static void mtk_efuse_fixup_dt_cell_info(struct nvmem_device *nvmem,
struct nvmem_layout *layout,
struct nvmem_cell_info *cell) struct nvmem_cell_info *cell)
{ {
size_t sz = strlen(cell->name); size_t sz = strlen(cell->name);
...@@ -61,10 +60,6 @@ static void mtk_efuse_fixup_cell_info(struct nvmem_device *nvmem, ...@@ -61,10 +60,6 @@ static void mtk_efuse_fixup_cell_info(struct nvmem_device *nvmem,
cell->read_post_process = mtk_efuse_gpu_speedbin_pp; cell->read_post_process = mtk_efuse_gpu_speedbin_pp;
} }
static struct nvmem_layout mtk_efuse_layout = {
.fixup_cell_info = mtk_efuse_fixup_cell_info,
};
static int mtk_efuse_probe(struct platform_device *pdev) static int mtk_efuse_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
...@@ -91,7 +86,7 @@ static int mtk_efuse_probe(struct platform_device *pdev) ...@@ -91,7 +86,7 @@ static int mtk_efuse_probe(struct platform_device *pdev)
econfig.priv = priv; econfig.priv = priv;
econfig.dev = dev; econfig.dev = dev;
if (pdata->uses_post_processing) if (pdata->uses_post_processing)
econfig.layout = &mtk_efuse_layout; econfig.fixup_dt_cell_info = &mtk_efuse_fixup_dt_cell_info;
nvmem = devm_nvmem_register(dev, &econfig); nvmem = devm_nvmem_register(dev, &econfig);
return PTR_ERR_OR_ZERO(nvmem); return PTR_ERR_OR_ZERO(nvmem);
......
...@@ -83,6 +83,8 @@ struct nvmem_cell_info { ...@@ -83,6 +83,8 @@ struct nvmem_cell_info {
* @cells: Optional array of pre-defined NVMEM cells. * @cells: Optional array of pre-defined NVMEM cells.
* @ncells: Number of elements in cells. * @ncells: Number of elements in cells.
* @add_legacy_fixed_of_cells: Read fixed NVMEM cells from old OF syntax. * @add_legacy_fixed_of_cells: Read fixed NVMEM cells from old OF syntax.
* @fixup_dt_cell_info: Will be called before a cell is added. Can be
* used to modify the nvmem_cell_info.
* @keepout: Optional array of keepout ranges (sorted ascending by start). * @keepout: Optional array of keepout ranges (sorted ascending by start).
* @nkeepout: Number of elements in the keepout array. * @nkeepout: Number of elements in the keepout array.
* @type: Type of the nvmem storage * @type: Type of the nvmem storage
...@@ -113,6 +115,8 @@ struct nvmem_config { ...@@ -113,6 +115,8 @@ struct nvmem_config {
const struct nvmem_cell_info *cells; const struct nvmem_cell_info *cells;
int ncells; int ncells;
bool add_legacy_fixed_of_cells; bool add_legacy_fixed_of_cells;
void (*fixup_dt_cell_info)(struct nvmem_device *nvmem,
struct nvmem_cell_info *cell);
const struct nvmem_keepout *keepout; const struct nvmem_keepout *keepout;
unsigned int nkeepout; unsigned int nkeepout;
enum nvmem_type type; enum nvmem_type type;
...@@ -158,8 +162,6 @@ struct nvmem_cell_table { ...@@ -158,8 +162,6 @@ struct nvmem_cell_table {
* @of_match_table: Open firmware match table. * @of_match_table: Open firmware match table.
* @add_cells: Called to populate the layout using * @add_cells: Called to populate the layout using
* nvmem_add_one_cell(). * nvmem_add_one_cell().
* @fixup_cell_info: Will be called before a cell is added. Can be
* used to modify the nvmem_cell_info.
* @owner: Pointer to struct module. * @owner: Pointer to struct module.
* @node: List node. * @node: List node.
* *
...@@ -172,9 +174,6 @@ struct nvmem_layout { ...@@ -172,9 +174,6 @@ struct nvmem_layout {
const char *name; const char *name;
const struct of_device_id *of_match_table; const struct of_device_id *of_match_table;
int (*add_cells)(struct device *dev, struct nvmem_device *nvmem); int (*add_cells)(struct device *dev, struct nvmem_device *nvmem);
void (*fixup_cell_info)(struct nvmem_device *nvmem,
struct nvmem_layout *layout,
struct nvmem_cell_info *cell);
/* private */ /* private */
struct module *owner; struct module *owner;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment