[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <e7875f70-2b79-48e0-a63b-caf6f1fd287b@kernel.org>
Date: Fri, 22 Aug 2025 08:50:17 +0200
From: Krzysztof Kozlowski <krzk@...nel.org>
To: Andrea della Porta <andrea.porta@...e.com>
Cc: Jim Quinlan <jim2101024@...il.com>,
Florian Fainelli <florian.fainelli@...adcom.com>,
Broadcom internal kernel review list
<bcm-kernel-feedback-list@...adcom.com>, Bjorn Helgaas
<bhelgaas@...gle.com>, Lorenzo Pieralisi <lpieralisi@...nel.org>,
kwilczynski@...nel.org, Manivannan Sadhasivam <mani@...nel.org>,
Rob Herring <robh@...nel.org>, Krzysztof Kozlowski <krzk+dt@...nel.org>,
Conor Dooley <conor+dt@...nel.org>, linux-pci@...r.kernel.org,
linux-arm-kernel@...ts.infradead.org, linux-rpi-kernel@...ts.infradead.org,
devicetree@...r.kernel.org, linux-kernel@...r.kernel.org, iivanov@...e.de,
svarbanov@...e.de, mbrugger@...e.com,
Jonathan Bell <jonathan@...pberrypi.com>, Phil Elwell
<phil@...pberrypi.com>, kernel test robot <lkp@...el.com>
Subject: Re: [PATCH] dt-bindings: pci: brcmstb: Add rp1-nexus node to fix DTC
warning
On 21/08/2025 17:22, Andrea della Porta wrote:
> Hi Krzysztof,
>
> On 10:55 Tue 12 Aug , Krzysztof Kozlowski wrote:
>> On 12/08/2025 10:50, Andrea della Porta wrote:
>>> The devicetree compiler is complaining as follows:
>>>
>>> arch/arm64/boot/dts/broadcom/rp1-nexus.dtsi:3.11-14.3: Warning (unit_address_vs_reg): /axi/pcie@...0120000/rp1_nexus: node has a reg or ranges property, but no unit name
>>> /home/andrea/linux-torvalds/arch/arm64/boot/dts/broadcom/bcm2712-rpi-5-b.dtb: pcie@...0120000: Unevaluated properties are not allowed ('rp1_nexus' was unexpected)
>>
>> Please trim the paths.
>
> Ack.
>
>>
>>>
>>> Add the optional node that fix this to the DT binding.
>>>
>>> Reported-by: kernel test robot <lkp@...el.com>
>>> Closes: https://lore.kernel.org/oe-kbuild-all/202506041952.baJDYBT4-lkp@intel.com/
>>> Signed-off-by: Andrea della Porta <andrea.porta@...e.com>
>>> ---
>>> Documentation/devicetree/bindings/pci/brcm,stb-pcie.yaml | 9 +++++++++
>>> 1 file changed, 9 insertions(+)
>>>
>>> diff --git a/Documentation/devicetree/bindings/pci/brcm,stb-pcie.yaml b/Documentation/devicetree/bindings/pci/brcm,stb-pcie.yaml
>>> index 812ef5957cfc..7d8ba920b652 100644
>>> --- a/Documentation/devicetree/bindings/pci/brcm,stb-pcie.yaml
>>> +++ b/Documentation/devicetree/bindings/pci/brcm,stb-pcie.yaml
>>> @@ -126,6 +126,15 @@ required:
>>> allOf:
>>> - $ref: /schemas/pci/pci-host-bridge.yaml#
>>> - $ref: /schemas/interrupt-controller/msi-controller.yaml#
>>> + - if:
>>> + properties:
>>> + compatible:
>>> + contains:
>>> + const: brcm,bcm2712-pcie
>>> + then:
>>> + properties:
>>> + rp1_nexus:
>>
>> No, you cannot document post-factum... This does not follow DTS coding
>> style.
>
> I think I didn't catch what you mean here: would that mean that
> we cannot resolve that warning since we cannot add anything to the
> binding?
I meant, you cannot use a warning from the code you recently introduced
as a reason to use incorrect style.
Fixing warning is of course fine and correct, but for the code recently
introduced and which bypassed ABI review it is basically like new review
of new ABI.
This needs standard review practice, so you need to document WHY you
need such node. Warning is not the reason here why you are doing. If
this was part of original patchset, like it should have been, you would
not use some imaginary warning as reason, right?
So provide reason why you need here this dedicated child, what is that
child representing.
Otherwise I can suggest: drop the child and DTSO, this also solves the
warning...
>
> Regarding rp1_nexus, you're right I guess it should be
> rp1-nexus as per DTS coding style.
>
>>
>> Also:
>>
>> Node names should be generic. See also an explanation and list of
>> examples (not exhaustive) in DT specification:
>> https://devicetree-specification.readthedocs.io/en/latest/chapter2-devicetree-basics.html#generic-names-recommendation
>
> In this case it could be difficult: we need to search for a DT node
Search like in driver? That's wrong, you should be searching by compatible.
> starting from the DT root and using generic names like pci@0,0 or
> dev@0,0 could possibly led to conflicts with other peripherals.
> That's why I chose a specific name.
Dunno, depends what can be there, but you do not get a specific
(non-generic) device node name for a generic PCI device or endpoint.
Best regards,
Krzysztof
Powered by blists - more mailing lists