cff66ace51
The DT of_device.h and of_platform.h date back to the separate of_platform_bus_type before it as merged into the regular platform bus. As part of that merge prepping Arm DT support 13 years ago, they "temporarily" include each other. They also include platform_device.h and of.h. As a result, there's a pretty much random mix of those include files used throughout the tree. In order to detangle these headers and replace the implicit includes with struct declarations, users need to explicitly include the correct includes. Signed-off-by: Rob Herring <robh@kernel.org> Link: https://lore.kernel.org/r/20230714174638.4058268-1-robh@kernel.org Signed-off-by: Georgi Djakov <djakov@kernel.org>
97 lines
2.2 KiB
C
97 lines
2.2 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* RPM over SMD communication wrapper for interconnects
|
|
*
|
|
* Copyright (C) 2019 Linaro Ltd
|
|
* Author: Georgi Djakov <georgi.djakov@linaro.org>
|
|
*/
|
|
|
|
#include <linux/interconnect-provider.h>
|
|
#include <linux/module.h>
|
|
#include <linux/platform_device.h>
|
|
#include <linux/soc/qcom/smd-rpm.h>
|
|
|
|
#include "icc-rpm.h"
|
|
|
|
#define RPM_KEY_BW 0x00007762
|
|
#define QCOM_RPM_SMD_KEY_RATE 0x007a484b
|
|
|
|
static struct qcom_smd_rpm *icc_smd_rpm;
|
|
|
|
struct icc_rpm_smd_req {
|
|
__le32 key;
|
|
__le32 nbytes;
|
|
__le32 value;
|
|
};
|
|
|
|
bool qcom_icc_rpm_smd_available(void)
|
|
{
|
|
return !!icc_smd_rpm;
|
|
}
|
|
EXPORT_SYMBOL_GPL(qcom_icc_rpm_smd_available);
|
|
|
|
int qcom_icc_rpm_smd_send(int ctx, int rsc_type, int id, u32 val)
|
|
{
|
|
struct icc_rpm_smd_req req = {
|
|
.key = cpu_to_le32(RPM_KEY_BW),
|
|
.nbytes = cpu_to_le32(sizeof(u32)),
|
|
.value = cpu_to_le32(val),
|
|
};
|
|
|
|
return qcom_rpm_smd_write(icc_smd_rpm, ctx, rsc_type, id, &req,
|
|
sizeof(req));
|
|
}
|
|
EXPORT_SYMBOL_GPL(qcom_icc_rpm_smd_send);
|
|
|
|
int qcom_icc_rpm_set_bus_rate(const struct rpm_clk_resource *clk, int ctx, u32 rate)
|
|
{
|
|
struct clk_smd_rpm_req req = {
|
|
.key = cpu_to_le32(QCOM_RPM_SMD_KEY_RATE),
|
|
.nbytes = cpu_to_le32(sizeof(u32)),
|
|
};
|
|
|
|
/* Branch clocks are only on/off */
|
|
if (clk->branch)
|
|
rate = !!rate;
|
|
|
|
req.value = cpu_to_le32(rate);
|
|
return qcom_rpm_smd_write(icc_smd_rpm,
|
|
ctx,
|
|
clk->resource_type,
|
|
clk->clock_id,
|
|
&req, sizeof(req));
|
|
}
|
|
EXPORT_SYMBOL_GPL(qcom_icc_rpm_set_bus_rate);
|
|
|
|
static int qcom_icc_rpm_smd_remove(struct platform_device *pdev)
|
|
{
|
|
icc_smd_rpm = NULL;
|
|
|
|
return 0;
|
|
}
|
|
|
|
static int qcom_icc_rpm_smd_probe(struct platform_device *pdev)
|
|
{
|
|
icc_smd_rpm = dev_get_drvdata(pdev->dev.parent);
|
|
|
|
if (!icc_smd_rpm) {
|
|
dev_err(&pdev->dev, "unable to retrieve handle to RPM\n");
|
|
return -ENODEV;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static struct platform_driver qcom_interconnect_rpm_smd_driver = {
|
|
.driver = {
|
|
.name = "icc_smd_rpm",
|
|
},
|
|
.probe = qcom_icc_rpm_smd_probe,
|
|
.remove = qcom_icc_rpm_smd_remove,
|
|
};
|
|
module_platform_driver(qcom_interconnect_rpm_smd_driver);
|
|
MODULE_AUTHOR("Georgi Djakov <georgi.djakov@linaro.org>");
|
|
MODULE_DESCRIPTION("Qualcomm SMD RPM interconnect proxy driver");
|
|
MODULE_LICENSE("GPL v2");
|
|
MODULE_ALIAS("platform:icc_smd_rpm");
|