Do not overwrite error codes returned from of_iio_channel_get().
Error codes are used to distinguish between "io-channel-names"
not present in DT bindings, property is optional, and IIO channel
provider driver still not being loaded, defer probe.

Signed-off-by: Ivan T. Ivanov <[email protected]>
---
 drivers/iio/inkern.c | 24 ++++++++++++------------
 1 file changed, 12 insertions(+), 12 deletions(-)

diff --git a/drivers/iio/inkern.c b/drivers/iio/inkern.c
index c749700..66a6cde 100644
--- a/drivers/iio/inkern.c
+++ b/drivers/iio/inkern.c
@@ -162,7 +162,7 @@ err_free_channel:
 static struct iio_channel *of_iio_channel_get_by_name(struct device_node *np,
                                                      const char *name)
 {
-       struct iio_channel *chan = NULL;
+       struct iio_channel *chan = ERR_PTR(-ENODEV);
 
        /* Walk up the tree of devices looking for a matching iio channel */
        while (np) {
@@ -183,7 +183,7 @@ static struct iio_channel 
*of_iio_channel_get_by_name(struct device_node *np,
                else if (name && index >= 0) {
                        pr_err("ERROR: could not get IIO channel %s:%s(%i)\n",
                                np->full_name, name ? name : "", index);
-                       return NULL;
+                       break;
                }
 
                /*
@@ -193,7 +193,7 @@ static struct iio_channel 
*of_iio_channel_get_by_name(struct device_node *np,
                 */
                np = np->parent;
                if (np && !of_get_property(np, "io-channel-ranges", NULL))
-                       return NULL;
+                       break;
        }
 
        return chan;
@@ -243,12 +243,12 @@ error_free_chans:
 static inline struct iio_channel *
 of_iio_channel_get_by_name(struct device_node *np, const char *name)
 {
-       return NULL;
+       return ERR_PTR(-ENODEV);
 }
 
 static inline struct iio_channel *of_iio_channel_get_all(struct device *dev)
 {
-       return NULL;
+       return ERR_PTR(-ENODEV);
 }
 
 #endif /* CONFIG_OF */
@@ -312,14 +312,14 @@ struct iio_channel *iio_channel_get(struct device *dev,
        const char *name = dev ? dev_name(dev) : NULL;
        struct iio_channel *channel;
 
-       if (dev) {
-               channel = of_iio_channel_get_by_name(dev->of_node,
-                                                    channel_name);
-               if (channel != NULL)
-                       return channel;
-       }
+       channel = iio_channel_get_sys(name, channel_name);
+       if (!IS_ERR(channel))
+               return channel;
+
+       if (!dev)
+               return channel;
 
-       return iio_channel_get_sys(name, channel_name);
+       return of_iio_channel_get_by_name(dev->of_node, channel_name);
 }
 EXPORT_SYMBOL_GPL(iio_channel_get);
 
-- 
1.9.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to