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
  * @dev: device pointer for the consumer device
 
 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);
 void icc_put(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 void icc_put(struct icc_path *path)
 {
 }