提交 c6a8b171 编写于 作者: G Georgi Djakov 提交者: Jassi Brar

mailbox: qcom: Convert APCS IPC driver to use regmap

This hardware block provides more functionalities that just IPC. Convert
it to regmap to allow other child platform devices to use the same regmap.
Signed-off-by: NGeorgi Djakov <georgi.djakov@linaro.org>
Acked-by: NBjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: NJassi Brar <jaswinder.singh@linaro.org>
上级 ca64af43
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_platform.h> #include <linux/of_platform.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/regmap.h>
#include <linux/mailbox_controller.h> #include <linux/mailbox_controller.h>
#define QCOM_APCS_IPC_BITS 32 #define QCOM_APCS_IPC_BITS 32
...@@ -26,19 +27,25 @@ struct qcom_apcs_ipc { ...@@ -26,19 +27,25 @@ struct qcom_apcs_ipc {
struct mbox_controller mbox; struct mbox_controller mbox;
struct mbox_chan mbox_chans[QCOM_APCS_IPC_BITS]; struct mbox_chan mbox_chans[QCOM_APCS_IPC_BITS];
void __iomem *reg; struct regmap *regmap;
unsigned long offset; unsigned long offset;
}; };
static const struct regmap_config apcs_regmap_config = {
.reg_bits = 32,
.reg_stride = 4,
.val_bits = 32,
.max_register = 0x1000,
.fast_io = true,
};
static int qcom_apcs_ipc_send_data(struct mbox_chan *chan, void *data) static int qcom_apcs_ipc_send_data(struct mbox_chan *chan, void *data)
{ {
struct qcom_apcs_ipc *apcs = container_of(chan->mbox, struct qcom_apcs_ipc *apcs = container_of(chan->mbox,
struct qcom_apcs_ipc, mbox); struct qcom_apcs_ipc, mbox);
unsigned long idx = (unsigned long)chan->con_priv; unsigned long idx = (unsigned long)chan->con_priv;
writel(BIT(idx), apcs->reg); return regmap_write(apcs->regmap, apcs->offset, BIT(idx));
return 0;
} }
static const struct mbox_chan_ops qcom_apcs_ipc_ops = { static const struct mbox_chan_ops qcom_apcs_ipc_ops = {
...@@ -47,7 +54,9 @@ static const struct mbox_chan_ops qcom_apcs_ipc_ops = { ...@@ -47,7 +54,9 @@ static const struct mbox_chan_ops qcom_apcs_ipc_ops = {
static int qcom_apcs_ipc_probe(struct platform_device *pdev) static int qcom_apcs_ipc_probe(struct platform_device *pdev)
{ {
struct device_node *np = pdev->dev.of_node;
struct qcom_apcs_ipc *apcs; struct qcom_apcs_ipc *apcs;
struct regmap *regmap;
struct resource *res; struct resource *res;
unsigned long offset; unsigned long offset;
void __iomem *base; void __iomem *base;
...@@ -63,9 +72,14 @@ static int qcom_apcs_ipc_probe(struct platform_device *pdev) ...@@ -63,9 +72,14 @@ static int qcom_apcs_ipc_probe(struct platform_device *pdev)
if (IS_ERR(base)) if (IS_ERR(base))
return PTR_ERR(base); return PTR_ERR(base);
regmap = devm_regmap_init_mmio(&pdev->dev, base, &apcs_regmap_config);
if (IS_ERR(regmap))
return PTR_ERR(regmap);
offset = (unsigned long)of_device_get_match_data(&pdev->dev); offset = (unsigned long)of_device_get_match_data(&pdev->dev);
apcs->reg = base + offset; apcs->regmap = regmap;
apcs->offset = offset;
/* Initialize channel identifiers */ /* Initialize channel identifiers */
for (i = 0; i < ARRAY_SIZE(apcs->mbox_chans); i++) for (i = 0; i < ARRAY_SIZE(apcs->mbox_chans); i++)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册