Thomas Bogendoerfer 38385a
From: Sakari Ailus <sakari.ailus@linux.intel.com>
Thomas Bogendoerfer 38385a
Date: Tue, 6 Jun 2017 12:37:39 +0300
Thomas Bogendoerfer 38385a
Subject: device property: Introduce fwnode_device_is_available()
Thomas Bogendoerfer 38385a
Patch-mainline: v4.13-rc1
Thomas Bogendoerfer 38385a
Git-commit: 2294b3af05e9b3fe0b84a78971e709037bd7593c
Thomas Bogendoerfer 38385a
References: bsc#1098633
Thomas Bogendoerfer 38385a
Thomas Bogendoerfer 38385a
Add fwnode_device_is_available() to tell whether the device corresponding
Thomas Bogendoerfer 38385a
to a certain fwnode_handle is available for use.
Thomas Bogendoerfer 38385a
Thomas Bogendoerfer 38385a
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Thomas Bogendoerfer 38385a
Reviewed-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Thomas Bogendoerfer 38385a
Acked-by: Rob Herring <robh@kernel.org>
Thomas Bogendoerfer 38385a
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Thomas Bogendoerfer 38385a
Acked-by: Thomas Bogendoerfer <tbogendoerfer@suse.de>
Thomas Bogendoerfer 38385a
---
Thomas Bogendoerfer 38385a
 drivers/acpi/property.c  |    9 +++++++++
Thomas Bogendoerfer 38385a
 drivers/base/property.c  |   10 ++++++++++
Thomas Bogendoerfer 38385a
 drivers/of/base.c        |    6 ++++++
Thomas Bogendoerfer 38385a
 include/linux/fwnode.h   |    1 +
Thomas Bogendoerfer 38385a
 include/linux/property.h |    1 +
Thomas Bogendoerfer 38385a
 5 files changed, 27 insertions(+)
Thomas Bogendoerfer 38385a
Thomas Bogendoerfer 38385a
--- a/drivers/acpi/property.c
Thomas Bogendoerfer 38385a
+++ b/drivers/acpi/property.c
Thomas Bogendoerfer 38385a
@@ -1121,6 +1121,14 @@ int acpi_graph_get_remote_endpoint(struc
Thomas Bogendoerfer 38385a
 	return 0;
Thomas Bogendoerfer 38385a
 }
Thomas Bogendoerfer 38385a
 
Thomas Bogendoerfer 38385a
+static bool acpi_fwnode_device_is_available(struct fwnode_handle *fwnode)
Thomas Bogendoerfer 38385a
+{
Thomas Bogendoerfer 38385a
+	if (!is_acpi_device_node(fwnode))
Thomas Bogendoerfer 38385a
+		return false;
Thomas Bogendoerfer 38385a
+
Thomas Bogendoerfer 38385a
+	return acpi_device_is_present(to_acpi_device_node(fwnode));
Thomas Bogendoerfer 38385a
+}
Thomas Bogendoerfer 38385a
+
Thomas Bogendoerfer 38385a
 static bool acpi_fwnode_property_present(struct fwnode_handle *fwnode,
Thomas Bogendoerfer 38385a
 					 const char *propname)
Thomas Bogendoerfer 38385a
 {
Thomas Bogendoerfer 38385a
@@ -1216,6 +1224,7 @@ static int acpi_fwnode_graph_parse_endpo
Thomas Bogendoerfer 38385a
 }
Thomas Bogendoerfer 38385a
 
Thomas Bogendoerfer 38385a
 const struct fwnode_operations acpi_fwnode_ops = {
Thomas Bogendoerfer 38385a
+	.device_is_available = acpi_fwnode_device_is_available,
Thomas Bogendoerfer 38385a
 	.property_present = acpi_fwnode_property_present,
Thomas Bogendoerfer 38385a
 	.property_read_int_array = acpi_fwnode_property_read_int_array,
Thomas Bogendoerfer 38385a
 	.property_read_string_array = acpi_fwnode_property_read_string_array,
Thomas Bogendoerfer 38385a
--- a/drivers/base/property.c
Thomas Bogendoerfer 38385a
+++ b/drivers/base/property.c
Thomas Bogendoerfer 38385a
@@ -1022,6 +1022,16 @@ void fwnode_handle_put(struct fwnode_han
Thomas Bogendoerfer 38385a
 EXPORT_SYMBOL_GPL(fwnode_handle_put);
Thomas Bogendoerfer 38385a
 
Thomas Bogendoerfer 38385a
 /**
Thomas Bogendoerfer 38385a
+ * fwnode_device_is_available - check if a device is available for use
Thomas Bogendoerfer 38385a
+ * @fwnode: Pointer to the fwnode of the device.
Thomas Bogendoerfer 38385a
+ */
Thomas Bogendoerfer 38385a
+bool fwnode_device_is_available(struct fwnode_handle *fwnode)
Thomas Bogendoerfer 38385a
+{
Thomas Bogendoerfer 38385a
+	return fwnode_call_int_op(fwnode, device_is_available);
Thomas Bogendoerfer 38385a
+}
Thomas Bogendoerfer 38385a
+EXPORT_SYMBOL_GPL(fwnode_device_is_available);
Thomas Bogendoerfer 38385a
+
Thomas Bogendoerfer 38385a
+/**
Thomas Bogendoerfer 38385a
  * device_get_child_node_count - return the number of child nodes for device
Thomas Bogendoerfer 38385a
  * @dev: Device to cound the child nodes for
Thomas Bogendoerfer 38385a
  */
Thomas Bogendoerfer 38385a
--- a/drivers/of/base.c
Thomas Bogendoerfer 38385a
+++ b/drivers/of/base.c
Thomas Bogendoerfer 38385a
@@ -2576,6 +2576,11 @@ static void of_fwnode_put(struct fwnode_
Thomas Bogendoerfer 38385a
 	of_node_put(to_of_node(fwnode));
Thomas Bogendoerfer 38385a
 }
Thomas Bogendoerfer 38385a
 
Thomas Bogendoerfer 38385a
+static bool of_fwnode_device_is_available(struct fwnode_handle *fwnode)
Thomas Bogendoerfer 38385a
+{
Thomas Bogendoerfer 38385a
+	return of_device_is_available(to_of_node(fwnode));
Thomas Bogendoerfer 38385a
+}
Thomas Bogendoerfer 38385a
+
Thomas Bogendoerfer 38385a
 static bool of_fwnode_property_present(struct fwnode_handle *fwnode,
Thomas Bogendoerfer 38385a
 				       const char *propname)
Thomas Bogendoerfer 38385a
 {
Thomas Bogendoerfer 38385a
@@ -2696,6 +2701,7 @@ static int of_fwnode_graph_parse_endpoin
Thomas Bogendoerfer 38385a
 const struct fwnode_operations of_fwnode_ops = {
Thomas Bogendoerfer 38385a
 	.get = of_fwnode_get,
Thomas Bogendoerfer 38385a
 	.put = of_fwnode_put,
Thomas Bogendoerfer 38385a
+	.device_is_available = of_fwnode_device_is_available,
Thomas Bogendoerfer 38385a
 	.property_present = of_fwnode_property_present,
Thomas Bogendoerfer 38385a
 	.property_read_int_array = of_fwnode_property_read_int_array,
Thomas Bogendoerfer 38385a
 	.property_read_string_array = of_fwnode_property_read_string_array,
Thomas Bogendoerfer 38385a
--- a/include/linux/fwnode.h
Thomas Bogendoerfer 38385a
+++ b/include/linux/fwnode.h
Thomas Bogendoerfer 38385a
@@ -66,6 +66,7 @@ struct fwnode_endpoint {
Thomas Bogendoerfer 38385a
 struct fwnode_operations {
Thomas Bogendoerfer 38385a
 	void (*get)(struct fwnode_handle *fwnode);
Thomas Bogendoerfer 38385a
 	void (*put)(struct fwnode_handle *fwnode);
Thomas Bogendoerfer 38385a
+	bool (*device_is_available)(struct fwnode_handle *fwnode);
Thomas Bogendoerfer 38385a
 	bool (*property_present)(struct fwnode_handle *fwnode,
Thomas Bogendoerfer 38385a
 				 const char *propname);
Thomas Bogendoerfer 38385a
 	int (*property_read_int_array)(struct fwnode_handle *fwnode,
Thomas Bogendoerfer 38385a
--- a/include/linux/property.h
Thomas Bogendoerfer 38385a
+++ b/include/linux/property.h
Thomas Bogendoerfer 38385a
@@ -51,6 +51,7 @@ int device_property_read_string(struct d
Thomas Bogendoerfer 38385a
 int device_property_match_string(struct device *dev,
Thomas Bogendoerfer 38385a
 				 const char *propname, const char *string);
Thomas Bogendoerfer 38385a
 
Thomas Bogendoerfer 38385a
+bool fwnode_device_is_available(struct fwnode_handle *fwnode);
Thomas Bogendoerfer 38385a
 bool fwnode_property_present(struct fwnode_handle *fwnode, const char *propname);
Thomas Bogendoerfer 38385a
 int fwnode_property_read_u8_array(struct fwnode_handle *fwnode,
Thomas Bogendoerfer 38385a
 				  const char *propname, u8 *val,