lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <6ffdf6ca-51b5-a968-bb4e-c4d6d46f63aa@codeaurora.org>
Date:   Wed, 5 Dec 2018 17:24:18 -0800
From:   David Dai <daidavid1@...eaurora.org>
To:     Stephen Boyd <sboyd@...nel.org>, Alex Elder <elder@...aro.org>,
        linux-arm-msm@...r.kernel.org, linux-clk@...r.kernel.org,
        linux-kernel@...r.kernel.org
Cc:     georgi.djakov@...aro.org, bjorn.andersson@...aro.org,
        evgreen@...gle.com, tdas@...eaurora.org
Subject: Re: [RFC PATCH] clk: qcom: clk-rpmh: Add IPA clock support



On 12/4/2018 11:15 PM, Stephen Boyd wrote:
> Quoting David Dai (2018-12-04 17:14:10)
>> On 12/4/2018 2:34 PM, Stephen Boyd wrote:
>>> Quoting Alex Elder (2018-12-04 13:41:47)
>>>> On 12/4/18 1:24 PM, Stephen Boyd wrote:
>>>>> Quoting David Dai (2018-12-03 19:50:13)
>>>>>> Add IPA clock support by extending the current clk rpmh driver to support
>>>>>> clocks that are managed by a different type of RPMh resource known as
>>>>>> Bus Clock Manager(BCM).
>>>>> Yes, but why? Does the IPA driver need to set clk rates and that somehow
>>>>> doesn't work as a bandwidth request?
>>>> The IPA core clock is a *clock*, not a bus.  Representing it as if
>>>> it were a bus, abusing the interconnect interface--pretending a bandwidth
>>>> request is really a clock rate request--is kind of kludgy.  I think Bjorn
>>>> and David (and maybe Georgi? I don't know) decided a long time ago that
>>>> exposing this as a clock is the right way to do it.  I agree with that.
>>>>
>>> But then we translate that clock rate into a bandwidth request to the
>>> BCM hardware? Seems really weird because it's doing the opposite of what
>>> you say is abusive. What does the IPA driver plan to do with this clk?
>>> Calculate a frequency by knowing that it really boils down to some
>>> bandwidth that then gets converted back into some clock frequency? Do we
>>> have the user somewhere that can be pointed to?
>> The clock rate is translated into a unitless threshold value sent as
>> part of the rpmh msg
>> that BCM takes to select a performance. In this case, the unit
>> conversion is based on
>> the unit value read from the aux data which is in Khz. I understand that
>> this wasn't
>> explicitly mentioned anywhere and I'll improve on that next patch.
> How is this different from bus bandwidth requests? In those cases the
> bandwidth is calculated in bits per second or something like that, and
> written to the hardware so it can convert that bandwidth into kHz and
> set a bus clk frequency in the clock controller? So in the IPA case
> we've skipped the bps to kHz conversion step and gone straight to the
> clk frequency setting part? Is a BCM able to aggregate units of
> bandwidth or kHz depending on how it's configured and this BCM is
> configured for kHz?

The data written to the hardware is just a 14bit scalar value that it 
takes to select a performance/frequency from a preset table. It's not 
really doing any sort of conversion in hardware in this case, instead 
the value is computed by software based on the aux data given. Think of 
it as a generic aggregator as opposed to being strictly bandwidth and 
the aggregator itself does not care what type of value it is(be it Khz 
or BW/s).

>
>> Here's a link to
>> the IPA driver implementation: https://lkml.org/lkml/2018/11/7/220
> Thanks for the link. It looks like the IPA driver hard codes a rate of
> 75 MHz.
>

-- 
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
a Linux Foundation Collaborative Project

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ