blob: f5f82a5c939e2f5c531ab579ab029c396c9856d4 [file] [log] [blame]
Georgi Djakovdd018a92019-11-28 16:18:16 +02001/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Interconnect framework internal structs
4 *
5 * Copyright (c) 2019, Linaro Ltd.
6 * Author: Georgi Djakov <georgi.djakov@linaro.org>
7 */
8
9#ifndef __DRIVERS_INTERCONNECT_INTERNAL_H
10#define __DRIVERS_INTERCONNECT_INTERNAL_H
11
12/**
13 * struct icc_req - constraints that are attached to each node
14 * @req_node: entry in list of requests for the particular @node
15 * @node: the interconnect node to which this constraint applies
16 * @dev: reference to the device that sets the constraints
Georgi Djakov7d374b22020-05-10 18:30:37 +030017 * @enabled: indicates whether the path with this request is enabled
Georgi Djakovdd018a92019-11-28 16:18:16 +020018 * @tag: path tag (optional)
19 * @avg_bw: an integer describing the average bandwidth in kBps
20 * @peak_bw: an integer describing the peak bandwidth in kBps
21 */
22struct icc_req {
23 struct hlist_node req_node;
24 struct icc_node *node;
25 struct device *dev;
Georgi Djakov7d374b22020-05-10 18:30:37 +030026 bool enabled;
Georgi Djakovdd018a92019-11-28 16:18:16 +020027 u32 tag;
28 u32 avg_bw;
29 u32 peak_bw;
30};
31
32/**
33 * struct icc_path - interconnect path structure
Georgi Djakov05309832019-11-28 16:18:17 +020034 * @name: a string name of the path (useful for ftrace)
Georgi Djakovdd018a92019-11-28 16:18:16 +020035 * @num_nodes: number of hops (nodes)
36 * @reqs: array of the requests applicable to this path of nodes
37 */
38struct icc_path {
Georgi Djakov05309832019-11-28 16:18:17 +020039 const char *name;
Georgi Djakovdd018a92019-11-28 16:18:16 +020040 size_t num_nodes;
41 struct icc_req reqs[];
42};
43
44#endif