Commit 28d03251 authored by Andy Shevchenko's avatar Andy Shevchenko Committed by Greg Kroah-Hartman

pps: clients: gpio: Make use of device properties

Device property API allows to gather device resources from different sources,
such as ACPI. Convert the drivers to unleash the power of device property API.
Acked-by: default avatarRodolfo Giometti <giometti@enneenne.com>
Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20210318130321.24227-5-andriy.shevchenko@linux.intel.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ee896466
...@@ -12,14 +12,14 @@ ...@@ -12,14 +12,14 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/mod_devicetable.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/pps_kernel.h> #include <linux/pps_kernel.h>
#include <linux/gpio/consumer.h> #include <linux/gpio/consumer.h>
#include <linux/list.h> #include <linux/list.h>
#include <linux/of_device.h> #include <linux/property.h>
#include <linux/of_gpio.h>
#include <linux/timer.h> #include <linux/timer.h>
#include <linux/jiffies.h> #include <linux/jiffies.h>
...@@ -102,7 +102,6 @@ static void pps_gpio_echo_timer_callback(struct timer_list *t) ...@@ -102,7 +102,6 @@ static void pps_gpio_echo_timer_callback(struct timer_list *t)
static int pps_gpio_setup(struct platform_device *pdev) static int pps_gpio_setup(struct platform_device *pdev)
{ {
struct pps_gpio_device_data *data = platform_get_drvdata(pdev); struct pps_gpio_device_data *data = platform_get_drvdata(pdev);
struct device_node *np = pdev->dev.of_node;
int ret; int ret;
u32 value; u32 value;
...@@ -121,26 +120,24 @@ static int pps_gpio_setup(struct platform_device *pdev) ...@@ -121,26 +120,24 @@ static int pps_gpio_setup(struct platform_device *pdev)
"failed to request ECHO GPIO\n"); "failed to request ECHO GPIO\n");
if (data->echo_pin) { if (data->echo_pin) {
ret = of_property_read_u32(np, ret = device_property_read_u32(&pdev->dev, "echo-active-ms", &value);
"echo-active-ms",
&value);
if (ret) { if (ret) {
dev_err(&pdev->dev, dev_err(&pdev->dev,
"failed to get echo-active-ms from OF\n"); "failed to get echo-active-ms from FW\n");
return ret; return ret;
} }
data->echo_active_ms = value; data->echo_active_ms = value;
/* sanity check on echo_active_ms */ /* sanity check on echo_active_ms */
if (!data->echo_active_ms || data->echo_active_ms > 999) { if (!data->echo_active_ms || data->echo_active_ms > 999) {
dev_err(&pdev->dev, dev_err(&pdev->dev,
"echo-active-ms: %u - bad value from OF\n", "echo-active-ms: %u - bad value from FW\n",
data->echo_active_ms); data->echo_active_ms);
return -EINVAL; return -EINVAL;
} }
} }
if (of_property_read_bool(np, "assert-falling-edge")) data->assert_falling_edge =
data->assert_falling_edge = true; device_property_read_bool(&pdev->dev, "assert-falling-edge");
return 0; return 0;
} }
......
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