return node;
  }
  
 +static void devm_icc_release(struct device *dev, void *res)
 +{
 +      icc_put(*(struct icc_path **)res);
 +}
 +
 +struct icc_path *devm_of_icc_get(struct device *dev, const char *name)
 +{
 +      struct icc_path **ptr, *path;
 +
 +      ptr = devres_alloc(devm_icc_release, sizeof(**ptr), GFP_KERNEL);
 +      if (!ptr)
 +              return ERR_PTR(-ENOMEM);
 +
 +      path = of_icc_get(dev, name);
 +      if (!IS_ERR(path)) {
 +              *ptr = path;
 +              devres_add(dev, ptr);
 +      } else {
 +              devres_free(ptr);
 +      }
 +
 +      return path;
 +}
 +EXPORT_SYMBOL_GPL(devm_of_icc_get);
 +
  /**
-  * of_icc_get() - get a path handle from a DT node based on name
+  * of_icc_get_by_index() - get a path handle from a DT node based on index
   * @dev: device pointer for the consumer device
-  * @name: interconnect path name
+  * @idx: interconnect path index
   *
   * This function will search for a path between two endpoints and return an
   * icc_path handle on success. Use icc_put() to release constraints when they
 
  struct icc_path *icc_get(struct device *dev, const int src_id,
                         const int dst_id);
  struct icc_path *of_icc_get(struct device *dev, const char *name);
 +struct icc_path *devm_of_icc_get(struct device *dev, const char *name);
+ struct icc_path *of_icc_get_by_index(struct device *dev, int idx);
  void icc_put(struct icc_path *path);
 +int icc_enable(struct icc_path *path);
 +int icc_disable(struct icc_path *path);
  int icc_set_bw(struct icc_path *path, u32 avg_bw, u32 peak_bw);
  void icc_set_tag(struct icc_path *path, u32 tag);
  
        return NULL;
  }
  
 +static inline struct icc_path *devm_of_icc_get(struct device *dev,
 +                                              const char *name)
 +{
 +      return NULL;
 +}
 +
+ static inline struct icc_path *of_icc_get_by_index(struct device *dev, int idx)
+ {
+       return NULL;
+ }
+ 
  static inline void icc_put(struct icc_path *path)
  {
  }