linux-hardening.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Konrad Dybcio <konrad.dybcio@linaro.org>
To: Odelu Kukatla <quic_okukatla@quicinc.com>,
	Mike Tipton <quic_mdtipton@quicinc.com>
Cc: Bjorn Andersson <andersson@kernel.org>,
	Georgi Djakov <djakov@kernel.org>, Rob Herring <robh@kernel.org>,
	Krzysztof Kozlowski <krzysztof.kozlowski+dt@linaro.org>,
	Conor Dooley <conor+dt@kernel.org>,
	Kees Cook <keescook@chromium.org>,
	cros-qcom-dts-watchers@chromium.org,
	"Gustavo A . R . Silva" <gustavoars@kernel.org>,
	linux-arm-msm@vger.kernel.org, linux-pm@vger.kernel.org,
	devicetree@vger.kernel.org, linux-kernel@vger.kernel.org,
	linux-hardening@vger.kernel.org, quic_rlaggysh@quicinc.com
Subject: Re: [PATCH v4 1/4] interconnect: qcom: icc-rpmh: Add QoS configuration support
Date: Tue, 18 Jun 2024 16:26:41 +0200	[thread overview]
Message-ID: <08533ee4-ac72-4d36-84ef-c44e8865d16d@linaro.org> (raw)
In-Reply-To: <434c6cfa-cede-4e62-a785-35a81ae0d30d@quicinc.com>



On 5/28/24 16:52, Odelu Kukatla wrote:
> Hi Konrad,
> 
> On 5/8/2024 8:07 AM, Mike Tipton wrote:
>> On Sat, Apr 13, 2024 at 09:31:47PM +0200, Konrad Dybcio wrote:
>>> On 3.04.2024 10:45 AM, Odelu Kukatla wrote:
>>>>
>>>>
>>>> On 3/27/2024 2:26 AM, Konrad Dybcio wrote:
>>>>> On 25.03.2024 7:16 PM, Odelu Kukatla wrote:
>>>>>> It adds QoS support for QNOC device and includes support for
>>>>>> configuring priority, priority forward disable, urgency forwarding.
>>>>>> This helps in priortizing the traffic originating from different
>>>>>> interconnect masters at NoC(Network On Chip).
>>>>>>
>>>>>> Signed-off-by: Odelu Kukatla <quic_okukatla@quicinc.com>
>>>>>> ---
>>>
>>> [...]
>>>
>>>>>> @@ -70,6 +102,7 @@ struct qcom_icc_node {
>>>>>>   	u64 max_peak[QCOM_ICC_NUM_BUCKETS];
>>>>>>   	struct qcom_icc_bcm *bcms[MAX_BCM_PER_NODE];
>>>>>>   	size_t num_bcms;
>>>>>> +	const struct qcom_icc_qosbox *qosbox;
>>>>>
>>>>> I believe I came up with a better approach for storing this.. see [1]
>>>>>
>>>>> Konrad
>>>>>
>>>>> [1] https://lore.kernel.org/linux-arm-msm/20240326-topic-rpm_icc_qos_cleanup-v1-4-357e736792be@linaro.org/
>>
>> Note that I replied to this patch series as well. Similar comments here
>> for how that approach would apply to icc-rpmh.
>>
>>>>>
>>>>
>>>> I see in this series, QoS parameters are moved into struct qcom_icc_desc.
>>>> Even though we program QoS at Provider/Bus level, it is property of the node/master connected to a Bus/NoC.
>>>
>>> I don't see how it could be the case, we're obviously telling the controller which
>>> endpoints have priority over others, not telling nodes whether the data they
>>> transfer can omit the queue.
>>
>> The QoS settings tune the priority of data coming out of a specific port
>> on the NOC. The nodes are 1:1 with the ports. Yes, this does tell the
>> NOC which ports have priority over others. But that's done by
>> configuring each port's priority in their own port-specific QoS
>> registers.
>>
>>>
>>>> It will be easier later to know which master's QoS we are programming if we add in node data.
>>>> Readability point of view,  it might be good to keep QoS parameters in node data.
>>>
>>> I don't agree here either, with the current approach we've made countless mistakes
>>> when converting the downstream data (I have already submitted some fixes with more
>>> in flight), as there's tons of jumping around the code to find what goes where.
>>
>> I don't follow why keeping the port's own QoS settings in that port's
>> struct results in more jumping around. It should do the opposite, in
>> fact. If someone wants to know the QoS settings applied to the qhm_qup0
>> port, then they should be able to look directly in the qhm_qup0 struct.
>> Otherwise, if it's placed elsewhere then they'd have to jump elsewhere
>> to find what that logical qhm_qup0-related data is set to.
>>
>> If it *was* placed elsewhere, then we'd still need some logical way to
>> map between that separate location and the node it's associated with.
>> Which is a problem with your patch for cleaning up the icc-rpm QoS. In
>> its current form, it's impossible to identify which QoS settings apply
>> to which logical node (without detailed knowledge of the NOC register
>> layout).
>>
>> Keeping this data with the node struct reduces the need for extra layers
>> of mapping between the QoS settings and the node struct. It keeps all
>> the port-related information all together in one place.
>>
>> I did like your earlier suggestion of using a compound literal to
>> initialize the .qosbox pointers, such that we don't need a separate
>> top-level variable defined for them. They're only ever referenced by a
>> single node, so there's no need for them to be separate variables.
>>
>> But I don't see the logic in totally separating the QoS data from the
>> port it's associated with.
>>
>>>
> I will update the patch as per your suggestion of keeping .qosbox initialization inside *qcom_icc_node* structure.
> I will post next version with this update and addressing other comments from v4.

Sorry for the late answer, but ack, let's go forward with this

Konrad

  reply	other threads:[~2024-06-18 14:26 UTC|newest]

Thread overview: 16+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-03-25 18:16 [PATCH v4 0/4] Add support for QoS configuration Odelu Kukatla
2024-03-25 18:16 ` [PATCH v4 1/4] interconnect: qcom: icc-rpmh: Add QoS configuration support Odelu Kukatla
2024-03-26 20:56   ` Konrad Dybcio
2024-03-27  8:44     ` Krzysztof Kozlowski
2024-03-27 11:42       ` Odelu Kukatla
2024-04-03  8:45     ` Odelu Kukatla
2024-04-13 19:31       ` Konrad Dybcio
2024-05-08  2:37         ` Mike Tipton
2024-05-28 14:52           ` Odelu Kukatla
2024-06-18 14:26             ` Konrad Dybcio [this message]
2024-03-25 18:16 ` [PATCH v4 2/4] interconnect: qcom: sc7280: enable QoS programming Odelu Kukatla
2024-03-25 18:16 ` [PATCH v4 3/4] dt-bindings: interconnect: add clock property to enable QOS on SC7280 Odelu Kukatla
2024-03-26  7:30   ` Krzysztof Kozlowski
2024-03-27 11:35     ` Odelu Kukatla
2024-03-27 12:14       ` Krzysztof Kozlowski
2024-03-25 18:16 ` [PATCH v4 4/4] arm64: dts: qcom: sc7280: Add clocks for QOS configuration Odelu Kukatla

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=08533ee4-ac72-4d36-84ef-c44e8865d16d@linaro.org \
    --to=konrad.dybcio@linaro.org \
    --cc=andersson@kernel.org \
    --cc=conor+dt@kernel.org \
    --cc=cros-qcom-dts-watchers@chromium.org \
    --cc=devicetree@vger.kernel.org \
    --cc=djakov@kernel.org \
    --cc=gustavoars@kernel.org \
    --cc=keescook@chromium.org \
    --cc=krzysztof.kozlowski+dt@linaro.org \
    --cc=linux-arm-msm@vger.kernel.org \
    --cc=linux-hardening@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-pm@vger.kernel.org \
    --cc=quic_mdtipton@quicinc.com \
    --cc=quic_okukatla@quicinc.com \
    --cc=quic_rlaggysh@quicinc.com \
    --cc=robh@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;
as well as URLs for NNTP newsgroup(s).