Commit 1e942b5b authored by Charles Keepax's avatar Charles Keepax Committed by Mark Brown

spi: cs42l43: Clean up of firmware node

As we get a child node in the OF case, we should also clean up the
reference, add code to do so.
Suggested-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
Reviewed-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
Signed-off-by: default avatarCharles Keepax <ckeepax@opensource.cirrus.com>
Link: https://msgid.link/r/20240202103430.951598-1-ckeepax@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent e6c5812d
...@@ -202,6 +202,11 @@ static size_t cs42l43_spi_max_length(struct spi_device *spi) ...@@ -202,6 +202,11 @@ static size_t cs42l43_spi_max_length(struct spi_device *spi)
return CS42L43_SPI_MAX_LENGTH; return CS42L43_SPI_MAX_LENGTH;
} }
static void cs42l43_release_of_node(void *data)
{
fwnode_handle_put(data);
}
static int cs42l43_spi_probe(struct platform_device *pdev) static int cs42l43_spi_probe(struct platform_device *pdev)
{ {
struct cs42l43 *cs42l43 = dev_get_drvdata(pdev->dev.parent); struct cs42l43 *cs42l43 = dev_get_drvdata(pdev->dev.parent);
...@@ -228,12 +233,6 @@ static int cs42l43_spi_probe(struct platform_device *pdev) ...@@ -228,12 +233,6 @@ static int cs42l43_spi_probe(struct platform_device *pdev)
priv->ctlr->transfer_one = cs42l43_transfer_one; priv->ctlr->transfer_one = cs42l43_transfer_one;
priv->ctlr->set_cs = cs42l43_set_cs; priv->ctlr->set_cs = cs42l43_set_cs;
priv->ctlr->max_transfer_size = cs42l43_spi_max_length; priv->ctlr->max_transfer_size = cs42l43_spi_max_length;
if (is_of_node(fwnode))
fwnode = fwnode_get_named_child_node(fwnode, "spi");
device_set_node(&priv->ctlr->dev, fwnode);
priv->ctlr->mode_bits = SPI_3WIRE | SPI_MODE_X_MASK; priv->ctlr->mode_bits = SPI_3WIRE | SPI_MODE_X_MASK;
priv->ctlr->flags = SPI_CONTROLLER_HALF_DUPLEX; priv->ctlr->flags = SPI_CONTROLLER_HALF_DUPLEX;
priv->ctlr->bits_per_word_mask = SPI_BPW_MASK(8) | SPI_BPW_MASK(16) | priv->ctlr->bits_per_word_mask = SPI_BPW_MASK(8) | SPI_BPW_MASK(16) |
...@@ -257,6 +256,17 @@ static int cs42l43_spi_probe(struct platform_device *pdev) ...@@ -257,6 +256,17 @@ static int cs42l43_spi_probe(struct platform_device *pdev)
regmap_write(priv->regmap, CS42L43_SPI_CONFIG3, 0); regmap_write(priv->regmap, CS42L43_SPI_CONFIG3, 0);
regmap_write(priv->regmap, CS42L43_SPI_CONFIG4, CS42L43_SPI_STALL_ENA_MASK); regmap_write(priv->regmap, CS42L43_SPI_CONFIG4, CS42L43_SPI_STALL_ENA_MASK);
if (is_of_node(fwnode)) {
fwnode = fwnode_get_named_child_node(fwnode, "spi");
ret = devm_add_action(priv->dev, cs42l43_release_of_node, fwnode);
if (ret) {
fwnode_handle_put(fwnode);
return ret;
}
}
device_set_node(&priv->ctlr->dev, fwnode);
ret = devm_spi_register_controller(priv->dev, priv->ctlr); ret = devm_spi_register_controller(priv->dev, priv->ctlr);
if (ret) { if (ret) {
dev_err(priv->dev, "Failed to register SPI controller: %d\n", ret); dev_err(priv->dev, "Failed to register SPI controller: %d\n", ret);
......
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