linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Paul Cercueil <paul@crapouillou.net>
To: Daniel Lezcano <daniel.lezcano@linaro.org>
Cc: Thomas Gleixner <tglx@linutronix.de>,
	Maarten ter Huurne <maarten@treewalker.org>,
	od@zcrc.me, linux-kernel@vger.kernel.org,
	Mathieu Malaterre <malat@debian.org>,
	Artur Rojek <contact@artur-rojek.eu>
Subject: Re: [PATCH v3] clocksource: Add driver for the Ingenic JZ47xx OST
Date: Sat, 08 Feb 2020 10:23:44 -0300	[thread overview]
Message-ID: <1581168224.3.0@crapouillou.net> (raw)
In-Reply-To: <eef21d5f-334c-81b4-19b1-6498df4fca30@linaro.org>

Hi Daniel,

Le sam., févr. 8, 2020 at 08:09, Daniel Lezcano 
<daniel.lezcano@linaro.org> a écrit :
> Hi Paul,
> 
> On 15/01/2020 21:58, Paul Cercueil wrote:
>> 
>> 
>>  Le mer., janv. 15, 2020 at 20:54, Thomas Gleixner 
>> <tglx@linutronix.de> a
>>  écrit :
>>>  Paul Cercueil <paul@crapouillou.net> writes:
>>>>   Le mer., janv. 15, 2020 at 18:48, Maarten ter Huurne
>>>>   <maarten@treewalker.org> a écrit :
>>>>>   On Wednesday, 15 January 2020 14:57:01 CET Paul Cercueil wrote:
>>>>>>    Le mer., janv. 15, 2020 at 14:44, Daniel Lezcano
>>>>>>    <daniel.lezcano@linaro.org> a écrit :
>>>>>>    > Is the JZ47xx OST really a mfd needing a regmap? (Note 
>>>>>> regmap_read
>>>>>>    > will take a lock).
>>>>>> 
>>>>>>    Yes, the TCU_REG_OST_TCSR register is shared with the clocks 
>>>>>> driver.
>>>>> 
>>>>>   The TCU_REG_OST_TCSR register is only used in the probe though.
>>>>> 
>>>>>   To get the counter value from TCU_REG_OST_CNTL/TCU_REG_OST_CNTH 
>>>>> you
>>>>>   could technically do it by reading the register directly, if
>>>>>   performance
>>>>>   concerns make it necessary to bypass the usual kernel 
>>>>> infrastructure
>>>>>   for
>>>>>   dealing with shared registers.
>>>> 
>>>>   In theory yes, in practice there's no easy way to do that (the
>>>>   underlying mmio pointer is not obtainable from the regmap), and
>>>>   besides, the lock is just a spinlock and not a mutex.
>>> 
>>>  That lock still a massive contention point as clock readouts can be
>>>  pretty
>>>  frequent depending on workloads. Just think about tracing ...
>>> 
>>>  So I really would avoid both the lock and that ugly 64bit readout 
>>> thing.
>> 
>>  The 64bit readout thing is gone in V3.
>> 
>>  The lock cannot go away unless we have a way to retrieve the 
>> underlying
>>  mmio pointer from the regmap, which the regmap maintainers will 
>> never
>>  accept. So I can't really change that now. Besides,
>>  drivers/clocksource/ingenic-timer.c also registers a clocksource 
>> that's
>>  read with the regmap, and nobody complained.
> 
> Is there any progress on this? Having a lock in this code path is very
> impacting.

I have a v4 ready, I'm just waiting for 5.6-rc1 to start to rebase on 
top and send it.

-Paul



      reply	other threads:[~2020-02-08 13:24 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-01-14 15:06 [PATCH v3] clocksource: Add driver for the Ingenic JZ47xx OST Paul Cercueil
2020-01-15 13:44 ` Daniel Lezcano
2020-01-15 13:57   ` Paul Cercueil
2020-01-15 17:48     ` Maarten ter Huurne
2020-01-15 17:54       ` Paul Cercueil
2020-01-15 19:54         ` Thomas Gleixner
2020-01-15 20:58           ` Paul Cercueil
2020-01-15 21:50             ` Thomas Gleixner
2020-02-08  7:09             ` Daniel Lezcano
2020-02-08 13:23               ` Paul Cercueil [this message]

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=1581168224.3.0@crapouillou.net \
    --to=paul@crapouillou.net \
    --cc=contact@artur-rojek.eu \
    --cc=daniel.lezcano@linaro.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=maarten@treewalker.org \
    --cc=malat@debian.org \
    --cc=od@zcrc.me \
    --cc=tglx@linutronix.de \
    /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).