From: Sai Prakash Ranjan <saiprakash.ranjan@codeaurora.org>
To: Suzuki K Poulose <suzuki.poulose@arm.com>, mike.leach@linaro.org
Cc: linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org,
mathieu.poirier@linaro.org, swboyd@chromium.org
Subject: Re: [PATCH] coresight: dynamic-replicator: Fix handling of multiple connections
Date: Wed, 29 Apr 2020 17:17:41 +0530 [thread overview]
Message-ID: <5b0f5d77c4eec22d8048bb0ffa078345@codeaurora.org> (raw)
In-Reply-To: <668ea1283a6dd6b34e701972f6f71034@codeaurora.org>
On 2020-04-28 17:53, Sai Prakash Ranjan wrote:
> On 2020-04-27 19:23, Suzuki K Poulose wrote:
>> On 04/27/2020 10:45 AM, Mike Leach wrote:
> [...]
>>>>
>>>> This is not sufficient. You must prevent another session trying to
>>>> enable the other port of the replicator as this could silently fail
>>>> the "on-going" session. Not ideal. Fail the attempt to enable a port
>>>> if the other port is active. You could track this in software and
>>>> fail early.
>>>>
>>>> Suzuki
>>>
>>> While I have no issue in principle with not enabling a path to a sink
>>> that is not in use - indeed in some cases attaching to unused sinks
>>> can cause back-pressure that slows throughput (cf TPIU) - I am
>>> concerned that this modification is masking an underlying issue with
>>> the platform in question.
>>>
>>> Should we decide to enable the diversion of different IDs to
>>> different
>>> sinks or allow different sessions go to different sinks, then this
>>> has
>>> potential to fail on the SC7180 SoC - and it will be difficult in
>>> future to associate a problem with this discussion.
>>
>> Mike,
>>
>> I think thats a good point.
>> Sai, please could we narrow down this to the real problem and may be
>> work around it for the "device" ? Do we know which sink is causing the
>> back pressure ? We could then push the "work around" to the replicator
>> it is connected to.
>>
>> Suzuki
>
> Hi Suzuki, Mike,
>
> To add some more to the information provided earlier,
> swao_replicator(6b06000) and etf are
> in AOSS (Always-On-SubSystem) group. Also TPIU(connected to
> qdss_replicator) and EUD(connected
> to swao_replicator) sinks are unused.
>
> Please ignore the id filter values provided earlier.
> Here are ID filter values after boot and before enabling replicator. As
> per
> these idfilter values, we should not try to enable replicator if its
> already
> enabled (in this case for swao_replicator) right?
>
> localhost ~ # cat
> /sys/bus/amba/devices/6b06000.replicator/replicator1/mgmt/idfilter0
> 0x0
> localhost ~ # cat
> /sys/bus/amba/devices/6b06000.replicator/replicator1/mgmt/idfilter1
> 0x0
>
> localhost ~ # cat
> /sys/bus/amba/devices/6046000.replicator/replicator0/mgmt/idfilter0
> 0xff
> localhost ~ # cat
> /sys/bus/amba/devices/6046000.replicator/replicator0/mgmt/idfilter1
> 0xff
>
Looking more into replicator1(swao_replicator) values as 0x0 even after
replicator_reset()
in replicator probe, I added dynamic_replicator_reset in
dynamic_replicator_enable()
and am not seeing any hardlockup. Also I added some prints to check the
idfilter
values before and after reset and found that its not set to 0xff even
after replicator_reset()
in replicator probe, I don't see any other path setting it to 0x0.
After probe:
[ 8.477669] func replicator_probe before reset replicator replicator1
REPLICATOR_IDFILTER0=0x0 REPLICATOR_IDFILTER1=0x0
[ 8.489470] func replicator_probe after reset replicator replicator1
REPLICATOR_IDFILTER0=0xff REPLICATOR_IDFILTER1=0xff
[ 8.502738] func replicator_probe before reset replicator replicator0
REPLICATOR_IDFILTER0=0x0 REPLICATOR_IDFILTER1=0x0
[ 8.515214] func replicator_probe after reset replicator replicator0
REPLICATOR_IDFILTER0=0xff REPLICATOR_IDFILTER1=0xff
localhost ~ #
localhost ~ #
localhost ~ # echo 1 > /sys/bus/coresight/devices/tmc_etr0/enable_sink
localhost ~ #
localhost ~ # echo 1 > /sys/bus/coresight/devices/etm0/enable_source
[ 58.490485] func dynamic_replicator_enable before reset replicator
replicator0 REPLICATOR_IDFILTER0=0xff REPLICATOR_IDFILTER1=0xff
[ 58.503246] func dynamic_replicator_enable after reset replicator
replicator0 REPLICATOR_IDFILTER0=0xff REPLICATOR_IDFILTER1=0xff
[ 58.520902] func dynamic_replicator_enable before reset replicator
replicator1 REPLICATOR_IDFILTER0=0x0 REPLICATOR_IDFILTER1=0x0
[ 58.533500] func dynamic_replicator_enable after reset replicator
replicator1 REPLICATOR_IDFILTER0=0xff REPLICATOR_IDFILTER1=0xff
localhost ~ #
Can we have a replicator_reset in dynamic_replicator_enable?
diff --git a/drivers/hwtracing/coresight/coresight-replicator.c
b/drivers/hwtracing/coresight/coresight-replicator.c
index e7dc1c31d20d..794f8e4c049f 100644
--- a/drivers/hwtracing/coresight/coresight-replicator.c
+++ b/drivers/hwtracing/coresight/coresight-replicator.c
@@ -68,6 +68,8 @@ static int dynamic_replicator_enable(struct
replicator_drvdata *drvdata,
int rc = 0;
u32 reg;
+ dynamic_replicator_reset(drvdata);
+
switch (outport) {
case 0:
reg = REPLICATOR_IDFILTER0;
Thanks,
Sai
--
QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a
member
of Code Aurora Forum, hosted by The Linux Foundation
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
next prev parent reply other threads:[~2020-04-29 11:47 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-04-26 14:37 [PATCH] coresight: dynamic-replicator: Fix handling of multiple connections Sai Prakash Ranjan
2020-04-27 9:20 ` Suzuki K Poulose
2020-04-27 9:45 ` Mike Leach
2020-04-27 13:53 ` Suzuki K Poulose
2020-04-28 12:23 ` Sai Prakash Ranjan
2020-04-29 11:47 ` Sai Prakash Ranjan [this message]
2020-04-29 13:49 ` Suzuki K Poulose
2020-04-29 13:59 ` Sai Prakash Ranjan
2020-04-29 14:27 ` Mike Leach
2020-04-29 14:48 ` Sai Prakash Ranjan
2020-04-29 16:58 ` Mike Leach
2020-04-29 17:11 ` Sai Prakash Ranjan
2020-05-06 7:35 ` Sai Prakash Ranjan
2020-05-08 8:53 ` Sai Prakash Ranjan
2020-05-11 11:14 ` Mike Leach
2020-05-11 14:16 ` Sai Prakash Ranjan
2020-05-11 14:30 ` Suzuki K Poulose
2020-05-11 14:41 ` Sai Prakash Ranjan
2020-05-12 11:49 ` Mike Leach
2020-05-12 17:45 ` Mathieu Poirier
2020-05-12 17:46 ` Sai Prakash Ranjan
2020-05-12 21:52 ` Mike Leach
2020-05-13 1:49 ` Stephen Boyd
2020-05-13 15:45 ` Sai Prakash Ranjan
2020-05-13 15:33 ` Sai Prakash Ranjan
2020-05-16 10:04 ` Sai Prakash Ranjan
2020-05-19 9:04 ` Sai Prakash Ranjan
2020-05-11 14:34 ` Sai Prakash Ranjan
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=5b0f5d77c4eec22d8048bb0ffa078345@codeaurora.org \
--to=saiprakash.ranjan@codeaurora.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mathieu.poirier@linaro.org \
--cc=mike.leach@linaro.org \
--cc=suzuki.poulose@arm.com \
--cc=swboyd@chromium.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;
as well as URLs for NNTP newsgroup(s).