spi: Add support for software nodes
Making it possible for the drivers to assign complete software fwnodes to the devices instead of only the device properties in those nodes. Signed-off-by: Heikki Krogerus <heikki.krogerus@linux.intel.com> Link: https://lore.kernel.org/r/20210303152814.35070-2-heikki.krogerus@linux.intel.com Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
a38fd87484
commit
47afc77bbf
@ -686,6 +686,15 @@ struct spi_device *spi_new_device(struct spi_controller *ctlr,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (chip->swnode) {
|
||||||
|
status = device_add_software_node(&proxy->dev, chip->swnode);
|
||||||
|
if (status) {
|
||||||
|
dev_err(&ctlr->dev, "failed to add softwade node to '%s': %d\n",
|
||||||
|
chip->modalias, status);
|
||||||
|
goto err_remove_props;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
status = spi_add_device(proxy);
|
status = spi_add_device(proxy);
|
||||||
if (status < 0)
|
if (status < 0)
|
||||||
goto err_remove_props;
|
goto err_remove_props;
|
||||||
@ -693,8 +702,7 @@ struct spi_device *spi_new_device(struct spi_controller *ctlr,
|
|||||||
return proxy;
|
return proxy;
|
||||||
|
|
||||||
err_remove_props:
|
err_remove_props:
|
||||||
if (chip->properties)
|
device_remove_software_node(&proxy->dev);
|
||||||
device_remove_properties(&proxy->dev);
|
|
||||||
err_dev_put:
|
err_dev_put:
|
||||||
spi_dev_put(proxy);
|
spi_dev_put(proxy);
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -719,6 +727,7 @@ void spi_unregister_device(struct spi_device *spi)
|
|||||||
}
|
}
|
||||||
if (ACPI_COMPANION(&spi->dev))
|
if (ACPI_COMPANION(&spi->dev))
|
||||||
acpi_device_clear_enumerated(ACPI_COMPANION(&spi->dev));
|
acpi_device_clear_enumerated(ACPI_COMPANION(&spi->dev));
|
||||||
|
device_remove_software_node(&spi->dev);
|
||||||
device_unregister(&spi->dev);
|
device_unregister(&spi->dev);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(spi_unregister_device);
|
EXPORT_SYMBOL_GPL(spi_unregister_device);
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
struct dma_chan;
|
struct dma_chan;
|
||||||
struct property_entry;
|
struct property_entry;
|
||||||
|
struct software_node;
|
||||||
struct spi_controller;
|
struct spi_controller;
|
||||||
struct spi_transfer;
|
struct spi_transfer;
|
||||||
struct spi_controller_mem_ops;
|
struct spi_controller_mem_ops;
|
||||||
@ -1409,7 +1410,8 @@ static inline ssize_t spi_w8r16be(struct spi_device *spi, u8 cmd)
|
|||||||
* @modalias: Initializes spi_device.modalias; identifies the driver.
|
* @modalias: Initializes spi_device.modalias; identifies the driver.
|
||||||
* @platform_data: Initializes spi_device.platform_data; the particular
|
* @platform_data: Initializes spi_device.platform_data; the particular
|
||||||
* data stored there is driver-specific.
|
* data stored there is driver-specific.
|
||||||
* @properties: Additional device properties for the device.
|
* @properties: Deprecated - use software node instead.
|
||||||
|
* @swnode: Software node for the device.
|
||||||
* @controller_data: Initializes spi_device.controller_data; some
|
* @controller_data: Initializes spi_device.controller_data; some
|
||||||
* controllers need hints about hardware setup, e.g. for DMA.
|
* controllers need hints about hardware setup, e.g. for DMA.
|
||||||
* @irq: Initializes spi_device.irq; depends on how the board is wired.
|
* @irq: Initializes spi_device.irq; depends on how the board is wired.
|
||||||
@ -1448,6 +1450,7 @@ struct spi_board_info {
|
|||||||
char modalias[SPI_NAME_SIZE];
|
char modalias[SPI_NAME_SIZE];
|
||||||
const void *platform_data;
|
const void *platform_data;
|
||||||
const struct property_entry *properties;
|
const struct property_entry *properties;
|
||||||
|
const struct software_node *swnode;
|
||||||
void *controller_data;
|
void *controller_data;
|
||||||
int irq;
|
int irq;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user