Commit 88a28519 authored by Andy Shevchenko's avatar Andy Shevchenko Committed by Mark Brown

spi: spidev: Replace OF specific code by device property API

Instead of calling the OF specific APIs, use device property ones.

It also prevents misusing PRP0001 in ACPI when trying to instantiate
spidev directly. We only support special SPI test devices there.
Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20220323140215.2568-4-andriy.shevchenko@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 2a7f669d
...@@ -20,8 +20,6 @@ ...@@ -20,8 +20,6 @@
#include <linux/property.h> #include <linux/property.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/compat.h> #include <linux/compat.h>
#include <linux/of.h>
#include <linux/of_device.h>
#include <linux/spi/spi.h> #include <linux/spi/spi.h>
#include <linux/spi/spidev.h> #include <linux/spi/spidev.h>
...@@ -695,20 +693,31 @@ static const struct spi_device_id spidev_spi_ids[] = { ...@@ -695,20 +693,31 @@ static const struct spi_device_id spidev_spi_ids[] = {
}; };
MODULE_DEVICE_TABLE(spi, spidev_spi_ids); MODULE_DEVICE_TABLE(spi, spidev_spi_ids);
#ifdef CONFIG_OF /*
* spidev should never be referenced in DT without a specific compatible string,
* it is a Linux implementation thing rather than a description of the hardware.
*/
static int spidev_of_check(struct device *dev)
{
if (device_property_match_string(dev, "compatible", "spidev") < 0)
return 0;
dev_err(dev, "spidev listed directly in DT is not supported\n");
return -EINVAL;
}
static const struct of_device_id spidev_dt_ids[] = { static const struct of_device_id spidev_dt_ids[] = {
{ .compatible = "rohm,dh2228fv" }, { .compatible = "rohm,dh2228fv", .data = &spidev_of_check },
{ .compatible = "lineartechnology,ltc2488" }, { .compatible = "lineartechnology,ltc2488", .data = &spidev_of_check },
{ .compatible = "semtech,sx1301" }, { .compatible = "semtech,sx1301", .data = &spidev_of_check },
{ .compatible = "lwn,bk4" }, { .compatible = "lwn,bk4", .data = &spidev_of_check },
{ .compatible = "dh,dhcom-board" }, { .compatible = "dh,dhcom-board", .data = &spidev_of_check },
{ .compatible = "menlo,m53cpld" }, { .compatible = "menlo,m53cpld", .data = &spidev_of_check },
{ .compatible = "cisco,spi-petra" }, { .compatible = "cisco,spi-petra", .data = &spidev_of_check },
{ .compatible = "micron,spi-authenta" }, { .compatible = "micron,spi-authenta", .data = &spidev_of_check },
{}, {},
}; };
MODULE_DEVICE_TABLE(of, spidev_dt_ids); MODULE_DEVICE_TABLE(of, spidev_dt_ids);
#endif
/* Dummy SPI devices not to be used in production systems */ /* Dummy SPI devices not to be used in production systems */
static int spidev_acpi_check(struct device *dev) static int spidev_acpi_check(struct device *dev)
...@@ -740,16 +749,6 @@ static int spidev_probe(struct spi_device *spi) ...@@ -740,16 +749,6 @@ static int spidev_probe(struct spi_device *spi)
int status; int status;
unsigned long minor; unsigned long minor;
/*
* spidev should never be referenced in DT without a specific
* compatible string, it is a Linux implementation thing
* rather than a description of the hardware.
*/
if (spi->dev.of_node && of_device_is_compatible(spi->dev.of_node, "spidev")) {
dev_err(&spi->dev, "spidev listed directly in DT is not supported\n");
return -EINVAL;
}
match = device_get_match_data(&spi->dev); match = device_get_match_data(&spi->dev);
if (match) { if (match) {
status = match(&spi->dev); status = match(&spi->dev);
...@@ -824,7 +823,7 @@ static void spidev_remove(struct spi_device *spi) ...@@ -824,7 +823,7 @@ static void spidev_remove(struct spi_device *spi)
static struct spi_driver spidev_spi_driver = { static struct spi_driver spidev_spi_driver = {
.driver = { .driver = {
.name = "spidev", .name = "spidev",
.of_match_table = of_match_ptr(spidev_dt_ids), .of_match_table = spidev_dt_ids,
.acpi_match_table = spidev_acpi_ids, .acpi_match_table = spidev_acpi_ids,
}, },
.probe = spidev_probe, .probe = spidev_probe,
......
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