xen: arm: add two new device tree helpers
authorIan Campbell <ian.campbell@citrix.com>
Tue, 17 Sep 2013 01:27:49 +0000 (02:27 +0100)
committerIan Campbell <ian.campbell@citrix.com>
Fri, 27 Sep 2013 15:39:03 +0000 (16:39 +0100)
 - dt_property_read_u64
 - dt_find_node_by_type

Signed-off-by: Ian Campbell <ian.campbell@citrix.com>
Acked-by: Julien Grall <julien.grall@linaro.org>
xen/common/device_tree.c
xen/include/xen/device_tree.h

index 4a1391cfc25e86e3b99dd6e8f82608ec000b9862..27ee70875cab7fa4080275842f74d8a28a3eef49 100644 (file)
@@ -511,6 +511,21 @@ bool_t dt_property_read_u32(const struct dt_device_node *np,
     return 1;
 }
 
+
+bool_t dt_property_read_u64(const struct dt_device_node *np,
+                         const char *name, u64 *out_value)
+{
+    u32 len;
+    const __be32 *val;
+
+    val = dt_get_property(np, name, &len);
+    if ( !val || len < sizeof(*out_value) )
+        return 0;
+
+    *out_value = dt_read_number(val, 2);
+
+    return 1;
+}
 int dt_property_read_string(const struct dt_device_node *np,
                             const char *propname, const char **out_string)
 {
@@ -576,6 +591,20 @@ struct dt_device_node *dt_find_node_by_name(struct dt_device_node *from,
     return np;
 }
 
+struct dt_device_node *dt_find_node_by_type(struct dt_device_node *from,
+                                            const char *type)
+{
+    struct dt_device_node *np;
+    struct dt_device_node *dt;
+
+    dt = from ? from->allnext : dt_host;
+    dt_for_each_device_node(dt, np)
+        if ( np->type && (dt_node_cmp(np->type, type) == 0) )
+            break;
+
+    return np;
+}
+
 struct dt_device_node *dt_find_node_by_path(const char *path)
 {
     struct dt_device_node *np;
index a665c9760e208c648549d942a05275209b1d3dbf..da78c9f0d40bd21e4e145d602673e3f120671014 100644 (file)
@@ -351,6 +351,17 @@ const void *dt_get_property(const struct dt_device_node *np,
  */
 bool_t dt_property_read_u32(const struct dt_device_node *np,
                             const char *name, u32 *out_value);
+/**
+ * dt_property_read_u64 - Helper to read a u64 property.
+ * @np: node to get the value
+ * @name: name of the property
+ * @out_value: pointer to return value
+ *
+ * Return true if get the desired value.
+ */
+bool_t dt_property_read_u64(const struct dt_device_node *np,
+                            const char *name, u64 *out_value);
+
 /**
  * dt_property_read_string - Find and read a string from a property
  * @np:         Device node from which the property value is to be read
@@ -399,6 +410,12 @@ bool_t dt_machine_is_compatible(const char *compat);
 struct dt_device_node *dt_find_node_by_name(struct dt_device_node *node,
                                             const char *name);
 
+/**
+ * dt_find_node_by_type - Find a node by its "type" property
+ */
+struct dt_device_node *dt_find_node_by_type(struct dt_device_node *from,
+                                            const char *type);
+
 /**
  * df_find_node_by_alias - Find a node matching an alias
  * @alias: The alias to match