2019-01-16 18:10:56 +02:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2018-2019, Linaro Ltd.
|
|
|
|
* Author: Georgi Djakov <georgi.djakov@linaro.org>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __LINUX_INTERCONNECT_H
|
|
|
|
#define __LINUX_INTERCONNECT_H
|
|
|
|
|
|
|
|
#include <linux/mutex.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
|
|
|
/* macros for converting to icc units */
|
|
|
|
#define Bps_to_icc(x) ((x) / 1000)
|
|
|
|
#define kBps_to_icc(x) (x)
|
|
|
|
#define MBps_to_icc(x) ((x) * 1000)
|
|
|
|
#define GBps_to_icc(x) ((x) * 1000 * 1000)
|
|
|
|
#define bps_to_icc(x) (1)
|
|
|
|
#define kbps_to_icc(x) ((x) / 8 + ((x) % 8 ? 1 : 0))
|
|
|
|
#define Mbps_to_icc(x) ((x) * 1000 / 8)
|
|
|
|
#define Gbps_to_icc(x) ((x) * 1000 * 1000 / 8)
|
|
|
|
|
|
|
|
struct icc_path;
|
|
|
|
struct device;
|
|
|
|
|
|
|
|
#if IS_ENABLED(CONFIG_INTERCONNECT)
|
|
|
|
|
|
|
|
struct icc_path *icc_get(struct device *dev, const int src_id,
|
|
|
|
const int dst_id);
|
2019-01-16 18:10:58 +02:00
|
|
|
struct icc_path *of_icc_get(struct device *dev, const char *name);
|
2020-04-15 15:53:10 +05:30
|
|
|
struct icc_path *devm_of_icc_get(struct device *dev, const char *name);
|
2020-05-12 15:53:20 +03:00
|
|
|
struct icc_path *of_icc_get_by_index(struct device *dev, int idx);
|
2019-01-16 18:10:56 +02:00
|
|
|
void icc_put(struct icc_path *path);
|
2020-05-10 18:30:37 +03:00
|
|
|
int icc_enable(struct icc_path *path);
|
|
|
|
int icc_disable(struct icc_path *path);
|
2019-01-16 18:10:56 +02:00
|
|
|
int icc_set_bw(struct icc_path *path, u32 avg_bw, u32 peak_bw);
|
2019-08-09 15:13:23 +03:00
|
|
|
void icc_set_tag(struct icc_path *path, u32 tag);
|
2020-05-18 14:25:32 +03:00
|
|
|
const char *icc_get_name(struct icc_path *path);
|
2019-01-16 18:10:56 +02:00
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
static inline struct icc_path *icc_get(struct device *dev, const int src_id,
|
|
|
|
const int dst_id)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-01-16 18:10:58 +02:00
|
|
|
static inline struct icc_path *of_icc_get(struct device *dev,
|
|
|
|
const char *name)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2020-04-15 15:53:10 +05:30
|
|
|
static inline struct icc_path *devm_of_icc_get(struct device *dev,
|
|
|
|
const char *name)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2020-05-12 15:53:20 +03:00
|
|
|
static inline struct icc_path *of_icc_get_by_index(struct device *dev, int idx)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-01-16 18:10:56 +02:00
|
|
|
static inline void icc_put(struct icc_path *path)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2020-05-10 18:30:37 +03:00
|
|
|
static inline int icc_enable(struct icc_path *path)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int icc_disable(struct icc_path *path)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-01-16 18:10:56 +02:00
|
|
|
static inline int icc_set_bw(struct icc_path *path, u32 avg_bw, u32 peak_bw)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-08-09 15:13:23 +03:00
|
|
|
static inline void icc_set_tag(struct icc_path *path, u32 tag)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2020-05-18 14:25:32 +03:00
|
|
|
static inline const char *icc_get_name(struct icc_path *path)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-01-16 18:10:56 +02:00
|
|
|
#endif /* CONFIG_INTERCONNECT */
|
|
|
|
|
|
|
|
#endif /* __LINUX_INTERCONNECT_H */
|