Lines Matching full:path

155 	struct icc_path *path;  in path_init()  local
158 path = kzalloc(struct_size(path, reqs, num_nodes), GFP_KERNEL); in path_init()
159 if (!path) in path_init()
162 path->num_nodes = num_nodes; in path_init()
166 hlist_add_head(&path->reqs[i].req_node, &node->req_list); in path_init()
167 path->reqs[i].node = node; in path_init()
168 path->reqs[i].dev = dev; in path_init()
169 path->reqs[i].enabled = true; in path_init()
170 /* reference to previous node was saved during path traversal */ in path_init()
174 return path; in path_init()
180 struct icc_path *path = ERR_PTR(-EPROBE_DEFER); in path_find() local
207 path = ERR_PTR(-ENOENT); in path_find()
238 path = path_init(dev, dst, depth); in path_find()
240 return path; in path_find()
244 * We want the path to honor all bandwidth requests, so the average and peak
283 static int apply_constraints(struct icc_path *path) in apply_constraints() argument
290 for (i = 0; i < path->num_nodes; i++) { in apply_constraints()
291 next = path->reqs[i].node; in apply_constraints()
404 struct icc_path **ptr, *path; in devm_of_icc_get() local
410 path = of_icc_get(dev, name); in devm_of_icc_get()
411 if (!IS_ERR(path)) { in devm_of_icc_get()
412 *ptr = path; in devm_of_icc_get()
418 return path; in devm_of_icc_get()
423 * of_icc_get_by_index() - get a path handle from a DT node based on index
425 * @idx: interconnect path index
427 * This function will search for a path between two endpoints and return an
439 struct icc_path *path; in of_icc_get_by_index() local
452 * return a NULL path to skip setting constraints. in of_icc_get_by_index()
494 path = path_find(dev, src_data->node, dst_data->node); in of_icc_get_by_index()
496 if (IS_ERR(path)) { in of_icc_get_by_index()
497 dev_err(dev, "%s: invalid path=%ld\n", __func__, PTR_ERR(path)); in of_icc_get_by_index()
502 icc_set_tag(path, src_data->tag); in of_icc_get_by_index()
504 path->name = kasprintf(GFP_KERNEL, "%s-%s", in of_icc_get_by_index()
506 if (!path->name) { in of_icc_get_by_index()
507 kfree(path); in of_icc_get_by_index()
508 path = ERR_PTR(-ENOMEM); in of_icc_get_by_index()
514 return path; in of_icc_get_by_index()
519 * of_icc_get() - get a path handle from a DT node based on name
521 * @name: interconnect path name
523 * This function will search for a path between two endpoints and return an
545 * return a NULL path to skip setting constraints. in of_icc_get()
566 * icc_set_tag() - set an optional tag on a path
567 * @path: the path we want to tag
571 * with a path, so that a different aggregation could be done based on this tag.
573 void icc_set_tag(struct icc_path *path, u32 tag) in icc_set_tag() argument
577 if (!path) in icc_set_tag()
582 for (i = 0; i < path->num_nodes; i++) in icc_set_tag()
583 path->reqs[i].tag = tag; in icc_set_tag()
590 * icc_get_name() - Get name of the icc path
591 * @path: reference to the path returned by icc_get()
594 * path.
598 const char *icc_get_name(struct icc_path *path) in icc_get_name() argument
600 if (!path) in icc_get_name()
603 return path->name; in icc_get_name()
608 * icc_set_bw() - set bandwidth constraints on an interconnect path
609 * @path: reference to the path returned by icc_get()
614 * in terms of bandwidth for a previously requested path between two endpoints.
616 * path is locked by a mutex to ensure that the set() is completed.
617 * The @path can be NULL when the "interconnects" DT properties is missing,
622 int icc_set_bw(struct icc_path *path, u32 avg_bw, u32 peak_bw) in icc_set_bw() argument
629 if (!path) in icc_set_bw()
632 if (WARN_ON(IS_ERR(path) || !path->num_nodes)) in icc_set_bw()
637 old_avg = path->reqs[0].avg_bw; in icc_set_bw()
638 old_peak = path->reqs[0].peak_bw; in icc_set_bw()
640 for (i = 0; i < path->num_nodes; i++) { in icc_set_bw()
641 node = path->reqs[i].node; in icc_set_bw()
643 /* update the consumer request for this path */ in icc_set_bw()
644 path->reqs[i].avg_bw = avg_bw; in icc_set_bw()
645 path->reqs[i].peak_bw = peak_bw; in icc_set_bw()
650 trace_icc_set_bw(path, node, i, avg_bw, peak_bw); in icc_set_bw()
653 ret = apply_constraints(path); in icc_set_bw()
658 for (i = 0; i < path->num_nodes; i++) { in icc_set_bw()
659 node = path->reqs[i].node; in icc_set_bw()
660 path->reqs[i].avg_bw = old_avg; in icc_set_bw()
661 path->reqs[i].peak_bw = old_peak; in icc_set_bw()
664 apply_constraints(path); in icc_set_bw()
669 trace_icc_set_bw_end(path, ret); in icc_set_bw()
675 static int __icc_enable(struct icc_path *path, bool enable) in __icc_enable() argument
679 if (!path) in __icc_enable()
682 if (WARN_ON(IS_ERR(path) || !path->num_nodes)) in __icc_enable()
687 for (i = 0; i < path->num_nodes; i++) in __icc_enable()
688 path->reqs[i].enabled = enable; in __icc_enable()
692 return icc_set_bw(path, path->reqs[0].avg_bw, in __icc_enable()
693 path->reqs[0].peak_bw); in __icc_enable()
696 int icc_enable(struct icc_path *path) in icc_enable() argument
698 return __icc_enable(path, true); in icc_enable()
702 int icc_disable(struct icc_path *path) in icc_disable() argument
704 return __icc_enable(path, false); in icc_disable()
709 * icc_get() - return a handle for path between two endpoints
710 * @dev: the device requesting the path
714 * This function will search for a path between two endpoints and return an
727 struct icc_path *path = ERR_PTR(-EPROBE_DEFER); in icc_get() local
739 path = path_find(dev, src, dst); in icc_get()
740 if (IS_ERR(path)) { in icc_get()
741 dev_err(dev, "%s: invalid path=%ld\n", __func__, PTR_ERR(path)); in icc_get()
745 path->name = kasprintf(GFP_KERNEL, "%s-%s", src->name, dst->name); in icc_get()
746 if (!path->name) { in icc_get()
747 kfree(path); in icc_get()
748 path = ERR_PTR(-ENOMEM); in icc_get()
752 return path; in icc_get()
758 * @path: interconnect path
760 * Use this function to release the constraints on a path when the path is
763 void icc_put(struct icc_path *path) in icc_put() argument
769 if (!path || WARN_ON(IS_ERR(path))) in icc_put()
772 ret = icc_set_bw(path, 0, 0); in icc_put()
777 for (i = 0; i < path->num_nodes; i++) { in icc_put()
778 node = path->reqs[i].node; in icc_put()
779 hlist_del(&path->reqs[i].req_node); in icc_put()
785 kfree_const(path->name); in icc_put()
786 kfree(path); in icc_put()