From: "Maulik Shah (mkshah)" <quic_mkshah@quicinc.com>
To: Volodymyr Babchuk <Volodymyr_Babchuk@epam.com>
Cc: Caleb Connolly <caleb.connolly@linaro.org>,
<Volodymyr_Babchuk@epam.com>,
"andersson@kernel.org >> Bjorn Andersson" <andersson@kernel.org>,
Konrad Dybcio <konrad.dybcio@linaro.org>,
linux-arm-msm <linux-arm-msm@vger.kernel.org>,
LKML <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH] soc: qcom: cmd-db: map shared memory as WT, not WB
Date: Thu, 28 Mar 2024 17:31:04 +0530 [thread overview]
Message-ID: <19bb6ff0-04ff-4e88-8c8a-499c054bdea4@quicinc.com> (raw)
In-Reply-To: <20240327200917.2576034-1-volodymyr_babchuk@epam.com>
On 3/28/2024 1:39 AM, Volodymyr Babchuk wrote:
> It appears that hardware does not like cacheable accesses to this
> region. Trying to access this shared memory region as Normal Memory
> leads to secure interrupt which causes an endless loop somewhere in
> Trust Zone.
Linux does not write into cmd-db region. This region is write protected
by XPU. Making this region uncached magically solves the XPU write fault
issue.
Can you please include above details?
>
> The only reason it is working right now is because Qualcomm Hypervisor
> maps the same region as Non-Cacheable memory in Stage 2 translation
> tables. The issue manifests if we want to use another hypervisor (like
> Xen or KVM), which does not know anything about those specific
> mappings. This patch fixes the issue by mapping the shared memory as
> Write-Through. This removes dependency on correct mappings in Stage 2
> tables.
Using MEMREMAP_WC also resolves for qcm6490, see below comment.
>
> I tested this on SA8155P with Xen.
>
> Signed-off-by: Volodymyr Babchuk <volodymyr_babchuk@epam.com>
> ---
> drivers/soc/qcom/cmd-db.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/soc/qcom/cmd-db.c b/drivers/soc/qcom/cmd-db.c
> index a5fd68411bed5..dd5ababdb476c 100644
> --- a/drivers/soc/qcom/cmd-db.c
> +++ b/drivers/soc/qcom/cmd-db.c
> @@ -324,7 +324,7 @@ static int cmd_db_dev_probe(struct platform_device *pdev)
> return -EINVAL;
> }
>
> - cmd_db_header = memremap(rmem->base, rmem->size, MEMREMAP_WB);
> + cmd_db_header = memremap(rmem->base, rmem->size, MEMREMAP_WT);
In downstream, we have below which resolved similar issue on qcm6490.
cmd_db_header = memremap(rmem->base, rmem->size, MEMREMAP_WC);
Downstream SA8155P also have MEMREMAP_WC. Can you please give it a try
on your device?
Thanks,
Maulik
next prev parent reply other threads:[~2024-03-28 12:01 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-03-27 20:09 [PATCH] soc: qcom: cmd-db: map shared memory as WT, not WB Volodymyr Babchuk
2024-03-27 20:45 ` Konrad Dybcio
2024-03-27 21:04 ` Volodymyr Babchuk
2024-03-27 21:06 ` Konrad Dybcio
2024-03-27 23:29 ` Caleb Connolly
2024-03-28 9:58 ` Stephan Gerhold
2024-03-29 0:40 ` Stephen Boyd
2024-04-11 3:54 ` Elliot Berman
2024-04-11 4:43 ` Stephen Boyd
2024-04-10 22:12 ` Volodymyr Babchuk
2024-04-11 8:02 ` Stephan Gerhold
2024-04-11 8:41 ` Stephen Boyd
2024-03-28 21:29 ` Volodymyr Babchuk
2024-03-28 11:12 ` Nikita Travkin
2024-03-28 14:06 ` Nikita Travkin
2024-03-28 12:01 ` Maulik Shah (mkshah) [this message]
2024-03-28 22:19 ` Volodymyr Babchuk
2024-03-29 4:52 ` Maulik Shah (mkshah)
2024-07-12 10:23 ` Pavan Kondeti
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=19bb6ff0-04ff-4e88-8c8a-499c054bdea4@quicinc.com \
--to=quic_mkshah@quicinc.com \
--cc=Volodymyr_Babchuk@epam.com \
--cc=andersson@kernel.org \
--cc=caleb.connolly@linaro.org \
--cc=konrad.dybcio@linaro.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox