Commit 13bec8d4 authored by Ajay Kishore's avatar Ajay Kishore Committed by Linus Walleij

pinctrl: qcom: use scm_call to route GPIO irq to Apps

For IPQ806x targets, TZ protects the registers that are used to
configure the routing of interrupts to a target processor.
To resolve this, this patch uses scm call to route GPIO interrupts
to application processor. Also the scm call interface is changed.
Signed-off-by: default avatarAjay Kishore <akisho@codeaurora.org>
Signed-off-by: default avatarAnsuel Smith <ansuelsmth@gmail.com>
Link: https://lore.kernel.org/r/20200327223209.20409-1-ansuelsmth@gmail.comReviewed-by: default avatarBjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 1592c4b9
...@@ -22,6 +22,8 @@ ...@@ -22,6 +22,8 @@
#include <linux/reboot.h> #include <linux/reboot.h>
#include <linux/pm.h> #include <linux/pm.h>
#include <linux/log2.h> #include <linux/log2.h>
#include <linux/qcom_scm.h>
#include <linux/io.h>
#include <linux/soc/qcom/irq.h> #include <linux/soc/qcom/irq.h>
...@@ -60,6 +62,8 @@ struct msm_pinctrl { ...@@ -60,6 +62,8 @@ struct msm_pinctrl {
struct irq_chip irq_chip; struct irq_chip irq_chip;
int irq; int irq;
bool intr_target_use_scm;
raw_spinlock_t lock; raw_spinlock_t lock;
DECLARE_BITMAP(dual_edge_irqs, MAX_NR_GPIO); DECLARE_BITMAP(dual_edge_irqs, MAX_NR_GPIO);
...@@ -68,6 +72,7 @@ struct msm_pinctrl { ...@@ -68,6 +72,7 @@ struct msm_pinctrl {
const struct msm_pinctrl_soc_data *soc; const struct msm_pinctrl_soc_data *soc;
void __iomem *regs[MAX_NR_TILES]; void __iomem *regs[MAX_NR_TILES];
u32 phys_base[MAX_NR_TILES];
}; };
#define MSM_ACCESSOR(name) \ #define MSM_ACCESSOR(name) \
...@@ -882,11 +887,31 @@ static int msm_gpio_irq_set_type(struct irq_data *d, unsigned int type) ...@@ -882,11 +887,31 @@ static int msm_gpio_irq_set_type(struct irq_data *d, unsigned int type)
else else
clear_bit(d->hwirq, pctrl->dual_edge_irqs); clear_bit(d->hwirq, pctrl->dual_edge_irqs);
/* Route interrupts to application cpu */ /* Route interrupts to application cpu.
val = msm_readl_intr_target(pctrl, g); * With intr_target_use_scm interrupts are routed to
val &= ~(7 << g->intr_target_bit); * application cpu using scm calls.
val |= g->intr_target_kpss_val << g->intr_target_bit; */
msm_writel_intr_target(val, pctrl, g); if (pctrl->intr_target_use_scm) {
u32 addr = pctrl->phys_base[0] + g->intr_target_reg;
int ret;
qcom_scm_io_readl(addr, &val);
val &= ~(7 << g->intr_target_bit);
val |= g->intr_target_kpss_val << g->intr_target_bit;
ret = qcom_scm_io_writel(addr, val);
if (ret)
dev_err(pctrl->dev,
"Failed routing %lu interrupt to Apps proc",
d->hwirq);
}
} else {
val = msm_readl_intr_target(pctrl, g);
val &= ~(7 << g->intr_target_bit);
val |= g->intr_target_kpss_val << g->intr_target_bit;
msm_writel_intr_target(val, pctrl, g);
}
/* Update configuration for gpio. /* Update configuration for gpio.
* RAW_STATUS_EN is left on for all gpio irqs. Due to the * RAW_STATUS_EN is left on for all gpio irqs. Due to the
...@@ -1241,6 +1266,9 @@ int msm_pinctrl_probe(struct platform_device *pdev, ...@@ -1241,6 +1266,9 @@ int msm_pinctrl_probe(struct platform_device *pdev,
pctrl->dev = &pdev->dev; pctrl->dev = &pdev->dev;
pctrl->soc = soc_data; pctrl->soc = soc_data;
pctrl->chip = msm_gpio_template; pctrl->chip = msm_gpio_template;
pctrl->intr_target_use_scm = of_device_is_compatible(
pctrl->dev->of_node,
"qcom,ipq8064-pinctrl");
raw_spin_lock_init(&pctrl->lock); raw_spin_lock_init(&pctrl->lock);
...@@ -1253,9 +1281,12 @@ int msm_pinctrl_probe(struct platform_device *pdev, ...@@ -1253,9 +1281,12 @@ int msm_pinctrl_probe(struct platform_device *pdev,
return PTR_ERR(pctrl->regs[i]); return PTR_ERR(pctrl->regs[i]);
} }
} else { } else {
pctrl->regs[0] = devm_platform_ioremap_resource(pdev, 0); res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
pctrl->regs[0] = devm_ioremap_resource(&pdev->dev, res);
if (IS_ERR(pctrl->regs[0])) if (IS_ERR(pctrl->regs[0]))
return PTR_ERR(pctrl->regs[0]); return PTR_ERR(pctrl->regs[0]);
pctrl->phys_base[0] = res->start;
} }
msm_pinctrl_setup_pm_reset(pctrl); msm_pinctrl_setup_pm_reset(pctrl);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment