Message ID | 20230531234923.2307013-4-chris.packham@alliedtelesis.co.nz |
---|---|
State | New |
Headers |
Return-Path: <linux-kernel-owner@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:a05:6358:3046:b0:115:7a1d:dabb with SMTP id p6csp780861rwl; Wed, 31 May 2023 16:56:19 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7PSLAIRz2TdZtRSxCjEn4OWY6M52tET3bv6t2IK6TUsGcd6+k3EJKIk8oxwYJkZj4SCyMS X-Received: by 2002:a05:6214:27e4:b0:623:690c:3ce6 with SMTP id jt4-20020a05621427e400b00623690c3ce6mr8171954qvb.32.1685577379094; Wed, 31 May 2023 16:56:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1685577379; cv=none; d=google.com; s=arc-20160816; b=XhF+axzNTLGjzFhFTXZgojfvDlstFEPTXLz8VIJN/iNfPLDEdBvb3vWWHj7Dto5rz/ 2/dicQ6wTb1UTtz7QiDvfaNwBy86QdLMGoWn0OY3lHBRcxL5DqKMoHr3+tPLkZTYR2ql CSxYHhzxzgyUGaEbkqaFSiNeRYIsYdMQ12nMeOrjdFViBUmiDAba43pRqn2haTAy45ch 1GBqd90+PJOcGYuL9YIbwYQJlRNDhcNfyP3OQ4heqydYWye3YY9zjQzpYoIuSdJAy4a4 muXa9UB2Y8FxpQZ/l+wAHQVkUOxp5FZFzOjNgIC5s5CGvhmg4v9w6BKUJ5QXzEenAbU5 /uhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=v+XqUHAZAtRRYKVgrV2vYHaz+qmZQnkKqvNzsnRzqDU=; b=J6Nfw6QMHvzWOc6hjGCmLmw2koiUDTXF2xaPKCwEVme0lNsxXG4mqNe0m6d5FEbnp+ 3M4ZxWL2AUQfDwKsUJKOI9Wn17SWons8QshCPpPXQ2mkdU/WCCV5qnQosbcWMn12ESwv tFDfXNjhTbAj7HNmaqHMFmxRXTaohofr9SM4cylThdTnr4rSxL7kKGcn6Dvds8yIjn7E Hhm/QImgRAhPBafwq5MNwJOOARWsO5VJ9H4syQasXLXDm1wV16+RrvzOEmKGTS43iaIE KvTOhra/L9oHNNN55EayinrgXFFtF6EExw8CXjkLkOMMlyAZEZ36MUdT4tO9AlIefsDH q+Vg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@alliedtelesis.co.nz header.s=mail181024 header.b=PNIva49A; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=REJECT dis=NONE) header.from=alliedtelesis.co.nz Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id e12-20020a170902784c00b001ab03c66823si1660716pln.141.2023.05.31.16.56.04; Wed, 31 May 2023 16:56:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@alliedtelesis.co.nz header.s=mail181024 header.b=PNIva49A; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=REJECT dis=NONE) header.from=alliedtelesis.co.nz Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230361AbjEaXto (ORCPT <rfc822;andrewvogler123@gmail.com> + 99 others); Wed, 31 May 2023 19:49:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43974 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230000AbjEaXth (ORCPT <rfc822;linux-kernel@vger.kernel.org>); Wed, 31 May 2023 19:49:37 -0400 Received: from gate2.alliedtelesis.co.nz (gate2.alliedtelesis.co.nz [202.36.163.20]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 83D26138 for <linux-kernel@vger.kernel.org>; Wed, 31 May 2023 16:49:33 -0700 (PDT) Received: from svr-chch-seg1.atlnz.lc (mmarshal3.atlnz.lc [10.32.18.43]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by gate2.alliedtelesis.co.nz (Postfix) with ESMTPS id 699142C034B; Thu, 1 Jun 2023 11:49:30 +1200 (NZST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=alliedtelesis.co.nz; s=mail181024; t=1685576970; bh=v+XqUHAZAtRRYKVgrV2vYHaz+qmZQnkKqvNzsnRzqDU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=PNIva49AEQy020Y7CdrF8kSI2nNSrhrmH0QF4x80D1I/vST9ZVg/2LBavc+g+145h IU+OlP+UDDY9GBVQTCGb6bz31daXDmz4uydsmBR0ISDzVmr+2JPULBgWgEzLDHAHrH Thn1WJhwjU/ZwvckeWBq97qlJ0Jn/Gof4vaVcm+5iTRR4Fy/oFomC8I4/YPqeSa/aA 39rxJOFqQerGke80KZxwoBp/77t3WzUA9inDHrMpzJi5fy3hE/lmn68lkpyx/Rd6BS 8ZDCgnRoB2wqp3/aESPtyUnqQ6L/FJy5JwyDlHXnAkqcpxSOh+o1vBf24VC8WgcvNy BL+SLUwb1vCoA== Received: from pat.atlnz.lc (Not Verified[10.32.16.33]) by svr-chch-seg1.atlnz.lc with Trustwave SEG (v8,2,6,11305) id <B6477dd0a0000>; Thu, 01 Jun 2023 11:49:30 +1200 Received: from chrisp-dl.ws.atlnz.lc (chrisp-dl.ws.atlnz.lc [10.33.22.30]) by pat.atlnz.lc (Postfix) with ESMTP id 3A85613ED2D; Thu, 1 Jun 2023 11:49:30 +1200 (NZST) Received: by chrisp-dl.ws.atlnz.lc (Postfix, from userid 1030) id 3B4D4285285; Thu, 1 Jun 2023 11:49:30 +1200 (NZST) From: Chris Packham <chris.packham@alliedtelesis.co.nz> To: miquel.raynal@bootlin.com, richard@nod.at, vigneshr@ti.com, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, conor+dt@kernel.org, andrew@lunn.ch, gregory.clement@bootlin.com, sebastian.hesselbarth@gmail.com, conor@kernel.org Cc: linux-mtd@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, enachman@marvell.com, Vadym Kochan <vadym.kochan@plvision.eu>, Chris Packham <chris.packham@alliedtelesis.co.nz> Subject: [PATCH v8 3/3] dt-bindings: mtd: marvell-nand: Convert to YAML DT scheme Date: Thu, 1 Jun 2023 11:49:23 +1200 Message-Id: <20230531234923.2307013-4-chris.packham@alliedtelesis.co.nz> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20230531234923.2307013-1-chris.packham@alliedtelesis.co.nz> References: <20230531234923.2307013-1-chris.packham@alliedtelesis.co.nz> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-SEG-SpamProfiler-Score: -1 x-atlnz-ls: pat X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: <linux-kernel.vger.kernel.org> X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1767455985583259078?= X-GMAIL-MSGID: =?utf-8?q?1767455985583259078?= |
Series |
dt-bindings: mtd: marvell-nand: Add YAML scheme
|
|
Commit Message
Chris Packham
May 31, 2023, 11:49 p.m. UTC
From: Vadym Kochan <vadym.kochan@plvision.eu> Switch the DT binding to a YAML schema to enable the DT validation. The text binding didn't mention it as a requirement but existing usage has compatible = "marvell,armada-8k-nand-controller", "marvell,armada370-nand-controller"; so the YAML allows this in addition to the individual compatible values. There was also an incorrect reference to dma-names being "rxtx" where the driver and existing device trees actually use dma-names = "data" so this is corrected in the conversion. Signed-off-by: Vadym Kochan <vadym.kochan@plvision.eu> Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz> --- Notes: Changes in v8: - Mark deprecated compatible values as such - Allow "marvell,armada-8k-nand-controller" without "marvell,armada370-nand-controller" - Make dma-names usage reflect reality - Update commit message Changes in v7: - Restore "label" and "partitions" properties (should be picked up via nand-controller.yaml but aren't) - Add/restore nand-on-flash-bbt and nand-ecc-mode which aren't covered by nand-controller.yaml. - Use "unevalautedProperties: false" - Corrections for clock-names, dma-names, nand-rb and nand-ecc-strength - Add pxa3xx-nand-controller example Changes in v6: - remove properties covered by nand-controller.yaml - add example using armada-8k compatible earlier changes: v5: 1) Get back "label" and "partitions" properties but without ref to the "partition.yaml" which was wrongly used. 2) Add "additionalProperties: false" for nand@ because all possible properties are described. v4: 1) Remove "label" and "partitions" properties 2) Use 2 clocks for A7K/8K platform which is a requirement v3: 1) Remove txt version from the MAINTAINERS list 2) Use enum for some of compatible strings 3) Drop: #address-cells #size-cells: as they are inherited from the nand-controller.yaml 4) Add restriction to use 2 clocks for A8K SoC 5) Dropped description for clock-names and extend it with minItems: 1 6) Drop description for "dmas" 7) Use "unevalautedProperties: false" 8) Drop quites from yaml refs. 9) Use 4-space indentation for the example section v2: 1) Fixed warning by yamllint with incorrect indentation for compatible list .../bindings/mtd/marvell,nand-controller.yaml | 223 ++++++++++++++++++ .../devicetree/bindings/mtd/marvell-nand.txt | 126 ---------- MAINTAINERS | 1 - 3 files changed, 223 insertions(+), 127 deletions(-) create mode 100644 Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml delete mode 100644 Documentation/devicetree/bindings/mtd/marvell-nand.txt
Comments
On 01/06/2023 01:49, Chris Packham wrote: > From: Vadym Kochan <vadym.kochan@plvision.eu> > > Switch the DT binding to a YAML schema to enable the DT validation. > > The text binding didn't mention it as a requirement but existing usage > has > > compatible = "marvell,armada-8k-nand-controller", > "marvell,armada370-nand-controller"; > > so the YAML allows this in addition to the individual compatible values. > > There was also an incorrect reference to dma-names being "rxtx" where > the driver and existing device trees actually use dma-names = "data" so > this is corrected in the conversion. > > Signed-off-by: Vadym Kochan <vadym.kochan@plvision.eu> > Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz> > --- > > Notes: > Changes in v8: > - Mark deprecated compatible values as such > - Allow "marvell,armada-8k-nand-controller" without > "marvell,armada370-nand-controller" > - Make dma-names usage reflect reality > - Update commit message > > Changes in v7: > - Restore "label" and "partitions" properties (should be picked up via > nand-controller.yaml but aren't) What do you mean by "aren't"? They are not needed. > - Add/restore nand-on-flash-bbt and nand-ecc-mode which aren't covered > by nand-controller.yaml. > - Use "unevalautedProperties: false" > - Corrections for clock-names, dma-names, nand-rb and nand-ecc-strength > - Add pxa3xx-nand-controller example > > Changes in v6: > - remove properties covered by nand-controller.yaml > - add example using armada-8k compatible > > earlier changes: > > v5: > 1) Get back "label" and "partitions" properties but without > ref to the "partition.yaml" which was wrongly used. > > 2) Add "additionalProperties: false" for nand@ because all possible > properties are described. > > v4: > 1) Remove "label" and "partitions" properties > > 2) Use 2 clocks for A7K/8K platform which is a requirement > > v3: > 1) Remove txt version from the MAINTAINERS list > > 2) Use enum for some of compatible strings > > 3) Drop: > #address-cells > #size-cells: > > as they are inherited from the nand-controller.yaml > > 4) Add restriction to use 2 clocks for A8K SoC > > 5) Dropped description for clock-names and extend it with > minItems: 1 > > 6) Drop description for "dmas" > > 7) Use "unevalautedProperties: false" > > 8) Drop quites from yaml refs. > > 9) Use 4-space indentation for the example section > > v2: > 1) Fixed warning by yamllint with incorrect indentation for compatible list > > .../bindings/mtd/marvell,nand-controller.yaml | 223 ++++++++++++++++++ > .../devicetree/bindings/mtd/marvell-nand.txt | 126 ---------- > MAINTAINERS | 1 - > 3 files changed, 223 insertions(+), 127 deletions(-) > create mode 100644 Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml > delete mode 100644 Documentation/devicetree/bindings/mtd/marvell-nand.txt > > diff --git a/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml > new file mode 100644 > index 000000000000..433feb430555 > --- /dev/null > +++ b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml > @@ -0,0 +1,223 @@ > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > +%YAML 1.2 > +--- > +$id: http://devicetree.org/schemas/mtd/marvell,nand-controller.yaml# > +$schema: http://devicetree.org/meta-schemas/core.yaml# > + > +title: Marvell NAND Flash Controller (NFC) > + > +maintainers: > + - Miquel Raynal <miquel.raynal@bootlin.com> > + > +properties: > + compatible: > + oneOf: > + - items: > + - const: marvell,armada-8k-nand-controller > + - const: marvell,armada370-nand-controller > + - enum: > + - marvell,armada-8k-nand-controller > + - marvell,armada370-nand-controller > + - marvell,pxa3xx-nand-controller > + - description: legacy bindings > + deprecated: true > + enum: > + - marvell,armada-8k-nand > + - marvell,armada370-nand > + - marvell,pxa3xx-nand > + > + reg: > + maxItems: 1 > + > + interrupts: > + maxItems: 1 > + > + clocks: > + description: > + Shall reference the NAND controller clocks, the second one is > + is only needed for the Armada 7K/8K SoCs > + minItems: 1 > + maxItems: 2 > + > + clock-names: > + minItems: 1 > + items: > + - const: core > + - const: reg > + > + dmas: > + maxItems: 1 > + > + dma-names: > + items: > + - const: data > + > + marvell,system-controller: > + $ref: /schemas/types.yaml#/definitions/phandle > + description: Syscon node that handles NAND controller related registers > + > +patternProperties: > + "^nand@[0-3]$": > + type: object > + unevaluatedProperties: false > + properties: > + reg: > + minimum: 0 > + maximum: 3 > + > + nand-rb: > + minItems: 1 Drop minItems. > + maxItems: 1 Didn't you have here minimum and maximum? I think I did not ask to remove them. > + > + nand-ecc-step-size: > + const: 512 > + > + nand-ecc-strength: > + enum: [1, 4, 8, 12, 16] > + > + nand-on-flash-bbt: > + $ref: /schemas/types.yaml#/definitions/flag > + > + nand-ecc-mode: > + const: hw > + > + label: > + $ref: /schemas/types.yaml#/definitions/string Drop label > + > + partitions: > + type: object Drop partitions. > + > + marvell,nand-keep-config: > + description: | > + Orders the driver not to take the timings from the core and > + leaving them completely untouched. Bootloader timings will then > + be used. > + $ref: /schemas/types.yaml#/definitions/flag > + > + marvell,nand-enable-arbiter: > + description: | > + To enable the arbiter, all boards blindly used it, > + this bit was set by the bootloader for many boards and even if > + it is marked reserved in several datasheets, it might be needed to set > + it (otherwise it is harmless). > + $ref: /schemas/types.yaml#/definitions/flag > + deprecated: true > + > + additionalProperties: false unevaluatedProperties: false > + > + required: > + - reg > + - nand-rb > + required: block goes here > +allOf: > + - $ref: nand-controller.yaml > + > + - if: > + properties: > + compatible: > + contains: > + const: marvell,pxa3xx-nand-controller > + then: > + required: > + - dmas > + - dma-names > + > + - if: > + properties: > + compatible: > + contains: > + const: marvell,armada-8k-nand-controller > + then: > + properties: > + clocks: > + minItems: 2 > + > + clock-names: > + minItems: 2 > + > + required: > + - marvell,system-controller > + Best regards, Krzysztof
On 1/06/23 19:05, Krzysztof Kozlowski wrote: > On 01/06/2023 01:49, Chris Packham wrote: >> From: Vadym Kochan <vadym.kochan@plvision.eu> >> >> Switch the DT binding to a YAML schema to enable the DT validation. >> >> The text binding didn't mention it as a requirement but existing usage >> has >> >> compatible = "marvell,armada-8k-nand-controller", >> "marvell,armada370-nand-controller"; >> >> so the YAML allows this in addition to the individual compatible values. >> >> There was also an incorrect reference to dma-names being "rxtx" where >> the driver and existing device trees actually use dma-names = "data" so >> this is corrected in the conversion. >> >> Signed-off-by: Vadym Kochan <vadym.kochan@plvision.eu> >> Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz> >> --- >> >> Notes: >> Changes in v8: >> - Mark deprecated compatible values as such >> - Allow "marvell,armada-8k-nand-controller" without >> "marvell,armada370-nand-controller" >> - Make dma-names usage reflect reality >> - Update commit message >> >> Changes in v7: >> - Restore "label" and "partitions" properties (should be picked up via >> nand-controller.yaml but aren't) > What do you mean by "aren't"? They are not needed. I mean I simply cannot make it work and I'm out of ideas (I'm also in an awkward timezone so it takes 24hrs for me to ask a question and get a response which leads to me making guesses instead of waiting). nand-controller.yaml references nand-chip.yaml which references mtd.yaml which defines the "label" and "partitions" property. I thought marvell,nand-controller.yaml could just say `$ref: nand-controller.yaml` and it would mean I'd get all the definitions down the chain but this doesn't seem to work the way I expect (or more likely I'm not doing it right). I thought it might have something to do with the different patternProperties pattern but even when I make that match what is used in nand-controller.yaml it doesn't seem to pick up those properties. >> - Add/restore nand-on-flash-bbt and nand-ecc-mode which aren't covered >> by nand-controller.yaml. >> - Use "unevalautedProperties: false" >> - Corrections for clock-names, dma-names, nand-rb and nand-ecc-strength >> - Add pxa3xx-nand-controller example >> >> Changes in v6: >> - remove properties covered by nand-controller.yaml >> - add example using armada-8k compatible >> >> earlier changes: >> >> v5: >> 1) Get back "label" and "partitions" properties but without >> ref to the "partition.yaml" which was wrongly used. >> >> 2) Add "additionalProperties: false" for nand@ because all possible >> properties are described. >> >> v4: >> 1) Remove "label" and "partitions" properties >> >> 2) Use 2 clocks for A7K/8K platform which is a requirement >> >> v3: >> 1) Remove txt version from the MAINTAINERS list >> >> 2) Use enum for some of compatible strings >> >> 3) Drop: >> #address-cells >> #size-cells: >> >> as they are inherited from the nand-controller.yaml >> >> 4) Add restriction to use 2 clocks for A8K SoC >> >> 5) Dropped description for clock-names and extend it with >> minItems: 1 >> >> 6) Drop description for "dmas" >> >> 7) Use "unevalautedProperties: false" >> >> 8) Drop quites from yaml refs. >> >> 9) Use 4-space indentation for the example section >> >> v2: >> 1) Fixed warning by yamllint with incorrect indentation for compatible list >> >> .../bindings/mtd/marvell,nand-controller.yaml | 223 ++++++++++++++++++ >> .../devicetree/bindings/mtd/marvell-nand.txt | 126 ---------- >> MAINTAINERS | 1 - >> 3 files changed, 223 insertions(+), 127 deletions(-) >> create mode 100644 Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >> delete mode 100644 Documentation/devicetree/bindings/mtd/marvell-nand.txt >> >> diff --git a/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >> new file mode 100644 >> index 000000000000..433feb430555 >> --- /dev/null >> +++ b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >> @@ -0,0 +1,223 @@ >> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >> +%YAML 1.2 >> +--- >> +$id: http://scanmail.trustwave.com/?c=20988&d=18P45NWaR4V6pXt_kuivNCiVAXCm3C7MEF-_8xrP2A&u=http%3a%2f%2fdevicetree%2eorg%2fschemas%2fmtd%2fmarvell%2cnand-controller%2eyaml%23 >> +$schema: http://scanmail.trustwave.com/?c=20988&d=18P45NWaR4V6pXt_kuivNCiVAXCm3C7MEFvq8B-ZjQ&u=http%3a%2f%2fdevicetree%2eorg%2fmeta-schemas%2fcore%2eyaml%23 >> + >> +title: Marvell NAND Flash Controller (NFC) >> + >> +maintainers: >> + - Miquel Raynal <miquel.raynal@bootlin.com> >> + >> +properties: >> + compatible: >> + oneOf: >> + - items: >> + - const: marvell,armada-8k-nand-controller >> + - const: marvell,armada370-nand-controller >> + - enum: >> + - marvell,armada-8k-nand-controller >> + - marvell,armada370-nand-controller >> + - marvell,pxa3xx-nand-controller >> + - description: legacy bindings >> + deprecated: true >> + enum: >> + - marvell,armada-8k-nand >> + - marvell,armada370-nand >> + - marvell,pxa3xx-nand >> + >> + reg: >> + maxItems: 1 >> + >> + interrupts: >> + maxItems: 1 >> + >> + clocks: >> + description: >> + Shall reference the NAND controller clocks, the second one is >> + is only needed for the Armada 7K/8K SoCs >> + minItems: 1 >> + maxItems: 2 >> + >> + clock-names: >> + minItems: 1 >> + items: >> + - const: core >> + - const: reg >> + >> + dmas: >> + maxItems: 1 >> + >> + dma-names: >> + items: >> + - const: data >> + >> + marvell,system-controller: >> + $ref: /schemas/types.yaml#/definitions/phandle >> + description: Syscon node that handles NAND controller related registers >> + >> +patternProperties: >> + "^nand@[0-3]$": >> + type: object >> + unevaluatedProperties: false >> + properties: >> + reg: >> + minimum: 0 >> + maximum: 3 >> + >> + nand-rb: >> + minItems: 1 > Drop minItems. > >> + maxItems: 1 > Didn't you have here minimum and maximum? I think I did not ask to > remove them. > >> + >> + nand-ecc-step-size: >> + const: 512 >> + >> + nand-ecc-strength: >> + enum: [1, 4, 8, 12, 16] >> + >> + nand-on-flash-bbt: >> + $ref: /schemas/types.yaml#/definitions/flag >> + >> + nand-ecc-mode: >> + const: hw >> + >> + label: >> + $ref: /schemas/types.yaml#/definitions/string > Drop label > >> + >> + partitions: >> + type: object > Drop partitions. > >> + >> + marvell,nand-keep-config: >> + description: | >> + Orders the driver not to take the timings from the core and >> + leaving them completely untouched. Bootloader timings will then >> + be used. >> + $ref: /schemas/types.yaml#/definitions/flag >> + >> + marvell,nand-enable-arbiter: >> + description: | >> + To enable the arbiter, all boards blindly used it, >> + this bit was set by the bootloader for many boards and even if >> + it is marked reserved in several datasheets, it might be needed to set >> + it (otherwise it is harmless). >> + $ref: /schemas/types.yaml#/definitions/flag >> + deprecated: true >> + >> + additionalProperties: false > unevaluatedProperties: false > >> + >> + required: >> + - reg >> + - nand-rb >> + > required: block goes here > >> +allOf: >> + - $ref: nand-controller.yaml >> + >> + - if: >> + properties: >> + compatible: >> + contains: >> + const: marvell,pxa3xx-nand-controller >> + then: >> + required: >> + - dmas >> + - dma-names >> + >> + - if: >> + properties: >> + compatible: >> + contains: >> + const: marvell,armada-8k-nand-controller >> + then: >> + properties: >> + clocks: >> + minItems: 2 >> + >> + clock-names: >> + minItems: 2 >> + >> + required: >> + - marvell,system-controller >> + > > Best regards, > Krzysztof >
Hi Krzystof, On 1/06/23 19:05, Krzysztof Kozlowski wrote: > On 01/06/2023 01:49, Chris Packham wrote: >> From: Vadym Kochan <vadym.kochan@plvision.eu> >> >> Switch the DT binding to a YAML schema to enable the DT validation. >> >> The text binding didn't mention it as a requirement but existing usage >> has >> >> compatible = "marvell,armada-8k-nand-controller", >> "marvell,armada370-nand-controller"; >> >> so the YAML allows this in addition to the individual compatible values. >> >> There was also an incorrect reference to dma-names being "rxtx" where >> the driver and existing device trees actually use dma-names = "data" so >> this is corrected in the conversion. >> >> Signed-off-by: Vadym Kochan <vadym.kochan@plvision.eu> >> Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz> >> --- >> >> Notes: >> Changes in v8: >> - Mark deprecated compatible values as such >> - Allow "marvell,armada-8k-nand-controller" without >> "marvell,armada370-nand-controller" >> - Make dma-names usage reflect reality >> - Update commit message >> >> Changes in v7: >> - Restore "label" and "partitions" properties (should be picked up via >> nand-controller.yaml but aren't) > What do you mean by "aren't"? They are not needed. (sorry I keep responding to snippets rather than putting all the replies in one place. For posterity here's the same response I provided in a separate message). I mean I simply cannot make it work and I'm out of ideas (I'm also in an awkward timezone so it takes 24hrs for me to ask a question and get a response which leads to me making guesses instead of waiting). nand-controller.yaml references nand-chip.yaml which references mtd.yaml which defines the "label" and "partitions" property. I thought marvell,nand-controller.yaml could just say `$ref: nand-controller.yaml` and it would mean I'd get all the definitions down the chain but this doesn't seem to work the way I expect (or more likely I'm not doing it right). I thought it might have something to do with the different patternProperties pattern but even when I make that match what is used in nand-controller.yaml it doesn't seem to pick up those properties. >> - Add/restore nand-on-flash-bbt and nand-ecc-mode which aren't covered >> by nand-controller.yaml. >> - Use "unevalautedProperties: false" >> - Corrections for clock-names, dma-names, nand-rb and nand-ecc-strength >> - Add pxa3xx-nand-controller example >> >> Changes in v6: >> - remove properties covered by nand-controller.yaml >> - add example using armada-8k compatible >> >> earlier changes: >> >> v5: >> 1) Get back "label" and "partitions" properties but without >> ref to the "partition.yaml" which was wrongly used. >> >> 2) Add "additionalProperties: false" for nand@ because all possible >> properties are described. >> >> v4: >> 1) Remove "label" and "partitions" properties >> >> 2) Use 2 clocks for A7K/8K platform which is a requirement >> >> v3: >> 1) Remove txt version from the MAINTAINERS list >> >> 2) Use enum for some of compatible strings >> >> 3) Drop: >> #address-cells >> #size-cells: >> >> as they are inherited from the nand-controller.yaml >> >> 4) Add restriction to use 2 clocks for A8K SoC >> >> 5) Dropped description for clock-names and extend it with >> minItems: 1 >> >> 6) Drop description for "dmas" >> >> 7) Use "unevalautedProperties: false" >> >> 8) Drop quites from yaml refs. >> >> 9) Use 4-space indentation for the example section >> >> v2: >> 1) Fixed warning by yamllint with incorrect indentation for compatible list >> >> .../bindings/mtd/marvell,nand-controller.yaml | 223 ++++++++++++++++++ >> .../devicetree/bindings/mtd/marvell-nand.txt | 126 ---------- >> MAINTAINERS | 1 - >> 3 files changed, 223 insertions(+), 127 deletions(-) >> create mode 100644 Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >> delete mode 100644 Documentation/devicetree/bindings/mtd/marvell-nand.txt >> >> diff --git a/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >> new file mode 100644 >> index 000000000000..433feb430555 >> --- /dev/null >> +++ b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >> @@ -0,0 +1,223 @@ >> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >> +%YAML 1.2 >> +--- >> +$id: http://scanmail.trustwave.com/?c=20988&d=18P45NWaR4V6pXt_kuivNCiVAXCm3C7MEF-_8xrP2A&u=http%3a%2f%2fdevicetree%2eorg%2fschemas%2fmtd%2fmarvell%2cnand-controller%2eyaml%23 >> +$schema: http://scanmail.trustwave.com/?c=20988&d=18P45NWaR4V6pXt_kuivNCiVAXCm3C7MEFvq8B-ZjQ&u=http%3a%2f%2fdevicetree%2eorg%2fmeta-schemas%2fcore%2eyaml%23 >> + >> +title: Marvell NAND Flash Controller (NFC) >> + >> +maintainers: >> + - Miquel Raynal <miquel.raynal@bootlin.com> >> + >> +properties: >> + compatible: >> + oneOf: >> + - items: >> + - const: marvell,armada-8k-nand-controller >> + - const: marvell,armada370-nand-controller >> + - enum: >> + - marvell,armada-8k-nand-controller >> + - marvell,armada370-nand-controller >> + - marvell,pxa3xx-nand-controller >> + - description: legacy bindings >> + deprecated: true >> + enum: >> + - marvell,armada-8k-nand >> + - marvell,armada370-nand >> + - marvell,pxa3xx-nand >> + >> + reg: >> + maxItems: 1 >> + >> + interrupts: >> + maxItems: 1 >> + >> + clocks: >> + description: >> + Shall reference the NAND controller clocks, the second one is >> + is only needed for the Armada 7K/8K SoCs >> + minItems: 1 >> + maxItems: 2 >> + >> + clock-names: >> + minItems: 1 >> + items: >> + - const: core >> + - const: reg >> + >> + dmas: >> + maxItems: 1 >> + >> + dma-names: >> + items: >> + - const: data >> + >> + marvell,system-controller: >> + $ref: /schemas/types.yaml#/definitions/phandle >> + description: Syscon node that handles NAND controller related registers >> + >> +patternProperties: >> + "^nand@[0-3]$": >> + type: object >> + unevaluatedProperties: false >> + properties: >> + reg: >> + minimum: 0 >> + maximum: 3 >> + >> + nand-rb: >> + minItems: 1 > Drop minItems. > >> + maxItems: 1 > Didn't you have here minimum and maximum? I think I did not ask to > remove them. I did but I couldn't figure out how to do minimum and maximum with an array would the following be correct (note removing both minItems and maxItems as dtb_check complains if I have maxItems and items). nand-rb: items: - minimum: 0 maximum: 1 > >> + >> + nand-ecc-step-size: >> + const: 512 >> + >> + nand-ecc-strength: >> + enum: [1, 4, 8, 12, 16] >> + >> + nand-on-flash-bbt: >> + $ref: /schemas/types.yaml#/definitions/flag >> + >> + nand-ecc-mode: >> + const: hw >> + >> + label: >> + $ref: /schemas/types.yaml#/definitions/string > Drop label > >> + >> + partitions: >> + type: object > Drop partitions. This is the part I can't get to work. It should pick it up via nand-controller.yaml but nothing I do seems to work. >> + >> + marvell,nand-keep-config: >> + description: | >> + Orders the driver not to take the timings from the core and >> + leaving them completely untouched. Bootloader timings will then >> + be used. >> + $ref: /schemas/types.yaml#/definitions/flag >> + >> + marvell,nand-enable-arbiter: >> + description: | >> + To enable the arbiter, all boards blindly used it, >> + this bit was set by the bootloader for many boards and even if >> + it is marked reserved in several datasheets, it might be needed to set >> + it (otherwise it is harmless). >> + $ref: /schemas/types.yaml#/definitions/flag >> + deprecated: true >> + >> + additionalProperties: false > unevaluatedProperties: false It was hiding by '"^nand@[0-3]$":'. Should I move it here? > >> + >> + required: >> + - reg >> + - nand-rb >> + > required: block goes here Will move > >> +allOf: >> + - $ref: nand-controller.yaml >> + >> + - if: >> + properties: >> + compatible: >> + contains: >> + const: marvell,pxa3xx-nand-controller >> + then: >> + required: >> + - dmas >> + - dma-names >> + >> + - if: >> + properties: >> + compatible: >> + contains: >> + const: marvell,armada-8k-nand-controller >> + then: >> + properties: >> + clocks: >> + minItems: 2 >> + >> + clock-names: >> + minItems: 2 >> + >> + required: >> + - marvell,system-controller >> + > > Best regards, > Krzysztof >
On 02/06/2023 01:06, Chris Packham wrote: > Hi Krzystof, > > On 1/06/23 19:05, Krzysztof Kozlowski wrote: >> On 01/06/2023 01:49, Chris Packham wrote: >>> From: Vadym Kochan <vadym.kochan@plvision.eu> >>> >>> Switch the DT binding to a YAML schema to enable the DT validation. >>> >>> The text binding didn't mention it as a requirement but existing usage >>> has >>> >>> compatible = "marvell,armada-8k-nand-controller", >>> "marvell,armada370-nand-controller"; >>> >>> so the YAML allows this in addition to the individual compatible values. >>> >>> There was also an incorrect reference to dma-names being "rxtx" where >>> the driver and existing device trees actually use dma-names = "data" so >>> this is corrected in the conversion. >>> >>> Signed-off-by: Vadym Kochan <vadym.kochan@plvision.eu> >>> Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz> >>> --- >>> >>> Notes: >>> Changes in v8: >>> - Mark deprecated compatible values as such >>> - Allow "marvell,armada-8k-nand-controller" without >>> "marvell,armada370-nand-controller" >>> - Make dma-names usage reflect reality >>> - Update commit message >>> >>> Changes in v7: >>> - Restore "label" and "partitions" properties (should be picked up via >>> nand-controller.yaml but aren't) >> What do you mean by "aren't"? They are not needed. > > (sorry I keep responding to snippets rather than putting all the replies > in one place. For posterity here's the same response I provided in a > separate message). > > I mean I simply cannot make it work and I'm out of ideas (I'm also in an > awkward timezone so it takes 24hrs for me to ask a question and get a > response which leads to me making guesses instead of waiting). > > nand-controller.yaml references nand-chip.yaml which references mtd.yaml > which defines the "label" and "partitions" property. > > I thought marvell,nand-controller.yaml could just say `$ref: > nand-controller.yaml` and it would mean I'd get all the definitions down > the chain but this doesn't seem to work the way I expect (or more likely > I'm not doing it right). I thought it might have something to do with > the different patternProperties pattern but even when I make that match > what is used in nand-controller.yaml it doesn't seem to pick up those > properties. Then you are doing something different than all other bindings. >>> - Add/restore nand-on-flash-bbt and nand-ecc-mode which aren't covered >>> by nand-controller.yaml. >>> - Use "unevalautedProperties: false" >>> - Corrections for clock-names, dma-names, nand-rb and nand-ecc-strength >>> - Add pxa3xx-nand-controller example >>> >>> Changes in v6: >>> - remove properties covered by nand-controller.yaml >>> - add example using armada-8k compatible >>> >>> earlier changes: >>> >>> v5: >>> 1) Get back "label" and "partitions" properties but without >>> ref to the "partition.yaml" which was wrongly used. >>> >>> 2) Add "additionalProperties: false" for nand@ because all possible >>> properties are described. >>> >>> v4: >>> 1) Remove "label" and "partitions" properties >>> >>> 2) Use 2 clocks for A7K/8K platform which is a requirement >>> >>> v3: >>> 1) Remove txt version from the MAINTAINERS list >>> >>> 2) Use enum for some of compatible strings >>> >>> 3) Drop: >>> #address-cells >>> #size-cells: >>> >>> as they are inherited from the nand-controller.yaml >>> >>> 4) Add restriction to use 2 clocks for A8K SoC >>> >>> 5) Dropped description for clock-names and extend it with >>> minItems: 1 >>> >>> 6) Drop description for "dmas" >>> >>> 7) Use "unevalautedProperties: false" >>> >>> 8) Drop quites from yaml refs. >>> >>> 9) Use 4-space indentation for the example section >>> >>> v2: >>> 1) Fixed warning by yamllint with incorrect indentation for compatible list >>> >>> .../bindings/mtd/marvell,nand-controller.yaml | 223 ++++++++++++++++++ >>> .../devicetree/bindings/mtd/marvell-nand.txt | 126 ---------- >>> MAINTAINERS | 1 - >>> 3 files changed, 223 insertions(+), 127 deletions(-) >>> create mode 100644 Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>> delete mode 100644 Documentation/devicetree/bindings/mtd/marvell-nand.txt >>> >>> diff --git a/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>> new file mode 100644 >>> index 000000000000..433feb430555 >>> --- /dev/null >>> +++ b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>> @@ -0,0 +1,223 @@ >>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >>> +%YAML 1.2 >>> +--- >>> +$id: http://scanmail.trustwave.com/?c=20988&d=18P45NWaR4V6pXt_kuivNCiVAXCm3C7MEF-_8xrP2A&u=http%3a%2f%2fdevicetree%2eorg%2fschemas%2fmtd%2fmarvell%2cnand-controller%2eyaml%23 >>> +$schema: http://scanmail.trustwave.com/?c=20988&d=18P45NWaR4V6pXt_kuivNCiVAXCm3C7MEFvq8B-ZjQ&u=http%3a%2f%2fdevicetree%2eorg%2fmeta-schemas%2fcore%2eyaml%23 >>> + >>> +title: Marvell NAND Flash Controller (NFC) >>> + >>> +maintainers: >>> + - Miquel Raynal <miquel.raynal@bootlin.com> >>> + >>> +properties: >>> + compatible: >>> + oneOf: >>> + - items: >>> + - const: marvell,armada-8k-nand-controller >>> + - const: marvell,armada370-nand-controller >>> + - enum: >>> + - marvell,armada-8k-nand-controller >>> + - marvell,armada370-nand-controller >>> + - marvell,pxa3xx-nand-controller >>> + - description: legacy bindings >>> + deprecated: true >>> + enum: >>> + - marvell,armada-8k-nand >>> + - marvell,armada370-nand >>> + - marvell,pxa3xx-nand >>> + >>> + reg: >>> + maxItems: 1 >>> + >>> + interrupts: >>> + maxItems: 1 >>> + >>> + clocks: >>> + description: >>> + Shall reference the NAND controller clocks, the second one is >>> + is only needed for the Armada 7K/8K SoCs >>> + minItems: 1 >>> + maxItems: 2 >>> + >>> + clock-names: >>> + minItems: 1 >>> + items: >>> + - const: core >>> + - const: reg >>> + >>> + dmas: >>> + maxItems: 1 >>> + >>> + dma-names: >>> + items: >>> + - const: data >>> + >>> + marvell,system-controller: >>> + $ref: /schemas/types.yaml#/definitions/phandle >>> + description: Syscon node that handles NAND controller related registers >>> + >>> +patternProperties: >>> + "^nand@[0-3]$": >>> + type: object >>> + unevaluatedProperties: false >>> + properties: >>> + reg: >>> + minimum: 0 >>> + maximum: 3 >>> + >>> + nand-rb: >>> + minItems: 1 >> Drop minItems. >> >>> + maxItems: 1 >> Didn't you have here minimum and maximum? I think I did not ask to >> remove them. > > I did but I couldn't figure out how to do minimum and maximum with an > array would the following be correct (note removing both minItems and > maxItems as dtb_check complains if I have maxItems and items). items: minimum: n maximum: n maxItems: n or items: - minimum: n maximum: n See for example Documentation/devicetree/bindings/arm/l2c2x0.yaml > > nand-rb: > items: > - minimum: 0 > maximum: 1 > >> >>> + >>> + nand-ecc-step-size: >>> + const: 512 >>> + >>> + nand-ecc-strength: >>> + enum: [1, 4, 8, 12, 16] >>> + >>> + nand-on-flash-bbt: >>> + $ref: /schemas/types.yaml#/definitions/flag >>> + >>> + nand-ecc-mode: >>> + const: hw >>> + >>> + label: >>> + $ref: /schemas/types.yaml#/definitions/string >> Drop label >> >>> + >>> + partitions: >>> + type: object >> Drop partitions. > > This is the part I can't get to work. It should pick it up via > nand-controller.yaml but nothing I do seems to work. > >>> + >>> + marvell,nand-keep-config: >>> + description: | >>> + Orders the driver not to take the timings from the core and >>> + leaving them completely untouched. Bootloader timings will then >>> + be used. >>> + $ref: /schemas/types.yaml#/definitions/flag >>> + >>> + marvell,nand-enable-arbiter: >>> + description: | >>> + To enable the arbiter, all boards blindly used it, >>> + this bit was set by the bootloader for many boards and even if >>> + it is marked reserved in several datasheets, it might be needed to set >>> + it (otherwise it is harmless). >>> + $ref: /schemas/types.yaml#/definitions/flag >>> + deprecated: true >>> + >>> + additionalProperties: false >> unevaluatedProperties: false > It was hiding by '"^nand@[0-3]$":'. Should I move it here? You cannot have both additionalProps and unevaluatedProps at the same time, so we do not talk about same thing or this was never working? Best regards, Krzysztof
On 4/06/23 21:26, Krzysztof Kozlowski wrote: > On 02/06/2023 01:06, Chris Packham wrote: >> Hi Krzystof, >> >> On 1/06/23 19:05, Krzysztof Kozlowski wrote: >>> On 01/06/2023 01:49, Chris Packham wrote: >>>> From: Vadym Kochan <vadym.kochan@plvision.eu> >>>> >>>> Switch the DT binding to a YAML schema to enable the DT validation. >>>> >>>> The text binding didn't mention it as a requirement but existing usage >>>> has >>>> >>>> compatible = "marvell,armada-8k-nand-controller", >>>> "marvell,armada370-nand-controller"; >>>> >>>> so the YAML allows this in addition to the individual compatible values. >>>> >>>> There was also an incorrect reference to dma-names being "rxtx" where >>>> the driver and existing device trees actually use dma-names = "data" so >>>> this is corrected in the conversion. >>>> >>>> Signed-off-by: Vadym Kochan <vadym.kochan@plvision.eu> >>>> Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz> >>>> --- >>>> >>>> Notes: >>>> Changes in v8: >>>> - Mark deprecated compatible values as such >>>> - Allow "marvell,armada-8k-nand-controller" without >>>> "marvell,armada370-nand-controller" >>>> - Make dma-names usage reflect reality >>>> - Update commit message >>>> >>>> Changes in v7: >>>> - Restore "label" and "partitions" properties (should be picked up via >>>> nand-controller.yaml but aren't) >>> What do you mean by "aren't"? They are not needed. >> (sorry I keep responding to snippets rather than putting all the replies >> in one place. For posterity here's the same response I provided in a >> separate message). >> >> I mean I simply cannot make it work and I'm out of ideas (I'm also in an >> awkward timezone so it takes 24hrs for me to ask a question and get a >> response which leads to me making guesses instead of waiting). >> >> nand-controller.yaml references nand-chip.yaml which references mtd.yaml >> which defines the "label" and "partitions" property. >> >> I thought marvell,nand-controller.yaml could just say `$ref: >> nand-controller.yaml` and it would mean I'd get all the definitions down >> the chain but this doesn't seem to work the way I expect (or more likely >> I'm not doing it right). I thought it might have something to do with >> the different patternProperties pattern but even when I make that match >> what is used in nand-controller.yaml it doesn't seem to pick up those >> properties. > Then you are doing something different than all other bindings. Not intentionally. I should probably check that the existing bindings actually work as expected. One thing that this has that the others don't is including "label" and "partitions" in the examples. >>>> - Add/restore nand-on-flash-bbt and nand-ecc-mode which aren't covered >>>> by nand-controller.yaml. >>>> - Use "unevalautedProperties: false" >>>> - Corrections for clock-names, dma-names, nand-rb and nand-ecc-strength >>>> - Add pxa3xx-nand-controller example >>>> >>>> Changes in v6: >>>> - remove properties covered by nand-controller.yaml >>>> - add example using armada-8k compatible >>>> >>>> earlier changes: >>>> >>>> v5: >>>> 1) Get back "label" and "partitions" properties but without >>>> ref to the "partition.yaml" which was wrongly used. >>>> >>>> 2) Add "additionalProperties: false" for nand@ because all possible >>>> properties are described. >>>> >>>> v4: >>>> 1) Remove "label" and "partitions" properties >>>> >>>> 2) Use 2 clocks for A7K/8K platform which is a requirement >>>> >>>> v3: >>>> 1) Remove txt version from the MAINTAINERS list >>>> >>>> 2) Use enum for some of compatible strings >>>> >>>> 3) Drop: >>>> #address-cells >>>> #size-cells: >>>> >>>> as they are inherited from the nand-controller.yaml >>>> >>>> 4) Add restriction to use 2 clocks for A8K SoC >>>> >>>> 5) Dropped description for clock-names and extend it with >>>> minItems: 1 >>>> >>>> 6) Drop description for "dmas" >>>> >>>> 7) Use "unevalautedProperties: false" >>>> >>>> 8) Drop quites from yaml refs. >>>> >>>> 9) Use 4-space indentation for the example section >>>> >>>> v2: >>>> 1) Fixed warning by yamllint with incorrect indentation for compatible list >>>> >>>> .../bindings/mtd/marvell,nand-controller.yaml | 223 ++++++++++++++++++ >>>> .../devicetree/bindings/mtd/marvell-nand.txt | 126 ---------- >>>> MAINTAINERS | 1 - >>>> 3 files changed, 223 insertions(+), 127 deletions(-) >>>> create mode 100644 Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>>> delete mode 100644 Documentation/devicetree/bindings/mtd/marvell-nand.txt >>>> >>>> diff --git a/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>>> new file mode 100644 >>>> index 000000000000..433feb430555 >>>> --- /dev/null >>>> +++ b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>>> @@ -0,0 +1,223 @@ >>>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >>>> +%YAML 1.2 >>>> +--- >>>> +$id: http://scanmail.trustwave.com/?c=20988&d=yNj85IkMld8k0XBdA9CH4pQjE5peaXAdz-exk_Hdww&u=http%3a%2f%2fdevicetree%2eorg%2fschemas%2fmtd%2fmarvell%2cnand-controller%2eyaml%23 >>>> +$schema: http://scanmail.trustwave.com/?c=20988&d=yNj85IkMld8k0XBdA9CH4pQjE5peaXAdz-PkkPSLlg&u=http%3a%2f%2fdevicetree%2eorg%2fmeta-schemas%2fcore%2eyaml%23 >>>> + >>>> +title: Marvell NAND Flash Controller (NFC) >>>> + >>>> +maintainers: >>>> + - Miquel Raynal <miquel.raynal@bootlin.com> >>>> + >>>> +properties: >>>> + compatible: >>>> + oneOf: >>>> + - items: >>>> + - const: marvell,armada-8k-nand-controller >>>> + - const: marvell,armada370-nand-controller >>>> + - enum: >>>> + - marvell,armada-8k-nand-controller >>>> + - marvell,armada370-nand-controller >>>> + - marvell,pxa3xx-nand-controller >>>> + - description: legacy bindings >>>> + deprecated: true >>>> + enum: >>>> + - marvell,armada-8k-nand >>>> + - marvell,armada370-nand >>>> + - marvell,pxa3xx-nand >>>> + >>>> + reg: >>>> + maxItems: 1 >>>> + >>>> + interrupts: >>>> + maxItems: 1 >>>> + >>>> + clocks: >>>> + description: >>>> + Shall reference the NAND controller clocks, the second one is >>>> + is only needed for the Armada 7K/8K SoCs >>>> + minItems: 1 >>>> + maxItems: 2 >>>> + >>>> + clock-names: >>>> + minItems: 1 >>>> + items: >>>> + - const: core >>>> + - const: reg >>>> + >>>> + dmas: >>>> + maxItems: 1 >>>> + >>>> + dma-names: >>>> + items: >>>> + - const: data >>>> + >>>> + marvell,system-controller: >>>> + $ref: /schemas/types.yaml#/definitions/phandle >>>> + description: Syscon node that handles NAND controller related registers >>>> + >>>> +patternProperties: >>>> + "^nand@[0-3]$": >>>> + type: object >>>> + unevaluatedProperties: false >>>> + properties: >>>> + reg: >>>> + minimum: 0 >>>> + maximum: 3 >>>> + >>>> + nand-rb: >>>> + minItems: 1 >>> Drop minItems. >>> >>>> + maxItems: 1 >>> Didn't you have here minimum and maximum? I think I did not ask to >>> remove them. >> I did but I couldn't figure out how to do minimum and maximum with an >> array would the following be correct (note removing both minItems and >> maxItems as dtb_check complains if I have maxItems and items). > items: > minimum: n > maximum: n > maxItems: n > > or > > items: > - minimum: n > maximum: n > > See for example Documentation/devicetree/bindings/arm/l2c2x0.yaml Thanks, so my suggestion below should be OK then. >> nand-rb: >> items: >> - minimum: 0 >> maximum: 1 >> >>>> + >>>> + nand-ecc-step-size: >>>> + const: 512 >>>> + >>>> + nand-ecc-strength: >>>> + enum: [1, 4, 8, 12, 16] >>>> + >>>> + nand-on-flash-bbt: >>>> + $ref: /schemas/types.yaml#/definitions/flag >>>> + >>>> + nand-ecc-mode: >>>> + const: hw >>>> + >>>> + label: >>>> + $ref: /schemas/types.yaml#/definitions/string >>> Drop label >>> >>>> + >>>> + partitions: >>>> + type: object >>> Drop partitions. >> This is the part I can't get to work. It should pick it up via >> nand-controller.yaml but nothing I do seems to work. >> >>>> + >>>> + marvell,nand-keep-config: >>>> + description: | >>>> + Orders the driver not to take the timings from the core and >>>> + leaving them completely untouched. Bootloader timings will then >>>> + be used. >>>> + $ref: /schemas/types.yaml#/definitions/flag >>>> + >>>> + marvell,nand-enable-arbiter: >>>> + description: | >>>> + To enable the arbiter, all boards blindly used it, >>>> + this bit was set by the bootloader for many boards and even if >>>> + it is marked reserved in several datasheets, it might be needed to set >>>> + it (otherwise it is harmless). >>>> + $ref: /schemas/types.yaml#/definitions/flag >>>> + deprecated: true >>>> + >>>> + additionalProperties: false >>> unevaluatedProperties: false >> It was hiding by '"^nand@[0-3]$":'. Should I move it here? > You cannot have both additionalProps and unevaluatedProps at the same > time, so we do not talk about same thing or this was never working? Hmm, I'm a little confused then. At various times I've been told to put 'additionalProperties: false' or 'unevaluatedProperties: false' (although never at the same time). I'm not sure when to use one or the other. From what I've been able to glean 'additionalProperties: true' indicates that the node is expected to have child nodes defined in a different schema so I would have thought 'additionalProperties: false' would be appropriate for a schema covering a leaf node. 'unevaluatedProperties: false' seems to enable stricter checking which makes sense when all the properties are described in the schema. > > Best regards, > Krzysztof
> > Then you are doing something different than all other bindings. > > Not intentionally. I should probably check that the existing bindings > actually work as expected. This binding supports marvell,pxa3xx-nand. That is really really old. So it could well be it works in the kernel, but the YAML does not fully implement what the kernel actually supports. Best practices could of pushed modern day DT to a subset, and YAML only supports that subset of reality. And once you get outside of this subset, you run into trouble. I don't actually know this is the case, but you should keep it in mind. Andrew
On 6/06/23 08:44, Chris Packham wrote: > > On 4/06/23 21:26, Krzysztof Kozlowski wrote: >> On 02/06/2023 01:06, Chris Packham wrote: >>> Hi Krzystof, >>> >>> On 1/06/23 19:05, Krzysztof Kozlowski wrote: >>>> On 01/06/2023 01:49, Chris Packham wrote: >>>>> From: Vadym Kochan <vadym.kochan@plvision.eu> >>>>> >>>>> Switch the DT binding to a YAML schema to enable the DT validation. >>>>> >>>>> The text binding didn't mention it as a requirement but existing >>>>> usage >>>>> has >>>>> >>>>> compatible = "marvell,armada-8k-nand-controller", >>>>> "marvell,armada370-nand-controller"; >>>>> >>>>> so the YAML allows this in addition to the individual compatible >>>>> values. >>>>> >>>>> There was also an incorrect reference to dma-names being "rxtx" where >>>>> the driver and existing device trees actually use dma-names = >>>>> "data" so >>>>> this is corrected in the conversion. >>>>> >>>>> Signed-off-by: Vadym Kochan <vadym.kochan@plvision.eu> >>>>> Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz> >>>>> --- >>>>> >>>>> Notes: >>>>> Changes in v8: >>>>> - Mark deprecated compatible values as such >>>>> - Allow "marvell,armada-8k-nand-controller" without >>>>> "marvell,armada370-nand-controller" >>>>> - Make dma-names usage reflect reality >>>>> - Update commit message >>>>> Changes in v7: >>>>> - Restore "label" and "partitions" properties (should be >>>>> picked up via >>>>> nand-controller.yaml but aren't) >>>> What do you mean by "aren't"? They are not needed. >>> (sorry I keep responding to snippets rather than putting all the >>> replies >>> in one place. For posterity here's the same response I provided in a >>> separate message). >>> >>> I mean I simply cannot make it work and I'm out of ideas (I'm also >>> in an >>> awkward timezone so it takes 24hrs for me to ask a question and get a >>> response which leads to me making guesses instead of waiting). >>> >>> nand-controller.yaml references nand-chip.yaml which references >>> mtd.yaml >>> which defines the "label" and "partitions" property. >>> >>> I thought marvell,nand-controller.yaml could just say `$ref: >>> nand-controller.yaml` and it would mean I'd get all the definitions >>> down >>> the chain but this doesn't seem to work the way I expect (or more >>> likely >>> I'm not doing it right). I thought it might have something to do with >>> the different patternProperties pattern but even when I make that match >>> what is used in nand-controller.yaml it doesn't seem to pick up those >>> properties. >> Then you are doing something different than all other bindings. > > Not intentionally. I should probably check that the existing bindings > actually work as expected. > > One thing that this has that the others don't is including "label" and > "partitions" in the examples. > >>>>> - Add/restore nand-on-flash-bbt and nand-ecc-mode which >>>>> aren't covered >>>>> by nand-controller.yaml. >>>>> - Use "unevalautedProperties: false" >>>>> - Corrections for clock-names, dma-names, nand-rb and >>>>> nand-ecc-strength >>>>> - Add pxa3xx-nand-controller example >>>>> Changes in v6: >>>>> - remove properties covered by nand-controller.yaml >>>>> - add example using armada-8k compatible >>>>> earlier changes: >>>>> v5: >>>>> 1) Get back "label" and "partitions" properties but without >>>>> ref to the "partition.yaml" which was wrongly used. >>>>> 2) Add "additionalProperties: false" for nand@ >>>>> because all possible >>>>> properties are described. >>>>> v4: >>>>> 1) Remove "label" and "partitions" properties >>>>> 2) Use 2 clocks for A7K/8K platform which is a >>>>> requirement >>>>> v3: >>>>> 1) Remove txt version from the MAINTAINERS list >>>>> 2) Use enum for some of compatible strings >>>>> 3) Drop: >>>>> #address-cells >>>>> #size-cells: >>>>> as they are inherited from the nand-controller.yaml >>>>> 4) Add restriction to use 2 clocks for A8K SoC >>>>> 5) Dropped description for clock-names and extend it >>>>> with >>>>> minItems: 1 >>>>> 6) Drop description for "dmas" >>>>> 7) Use "unevalautedProperties: false" >>>>> 8) Drop quites from yaml refs. >>>>> 9) Use 4-space indentation for the example section >>>>> v2: >>>>> 1) Fixed warning by yamllint with incorrect indentation >>>>> for compatible list >>>>> >>>>> .../bindings/mtd/marvell,nand-controller.yaml | 223 >>>>> ++++++++++++++++++ >>>>> .../devicetree/bindings/mtd/marvell-nand.txt | 126 ---------- >>>>> MAINTAINERS | 1 - >>>>> 3 files changed, 223 insertions(+), 127 deletions(-) >>>>> create mode 100644 >>>>> Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>>>> delete mode 100644 >>>>> Documentation/devicetree/bindings/mtd/marvell-nand.txt >>>>> >>>>> diff --git >>>>> a/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>>>> b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>>>> new file mode 100644 >>>>> index 000000000000..433feb430555 >>>>> --- /dev/null >>>>> +++ >>>>> b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml >>>>> @@ -0,0 +1,223 @@ >>>>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >>>>> +%YAML 1.2 >>>>> +--- >>>>> +$id: >>>>> http://scanmail.trustwave.com/?c=20988&d=yNj85IkMld8k0XBdA9CH4pQjE5peaXAdz-exk_Hdww&u=http%3a%2f%2fdevicetree%2eorg%2fschemas%2fmtd%2fmarvell%2cnand-controller%2eyaml%23 >>>>> +$schema: >>>>> http://scanmail.trustwave.com/?c=20988&d=yNj85IkMld8k0XBdA9CH4pQjE5peaXAdz-PkkPSLlg&u=http%3a%2f%2fdevicetree%2eorg%2fmeta-schemas%2fcore%2eyaml%23 >>>>> + >>>>> +title: Marvell NAND Flash Controller (NFC) >>>>> + >>>>> +maintainers: >>>>> + - Miquel Raynal <miquel.raynal@bootlin.com> >>>>> + >>>>> +properties: >>>>> + compatible: >>>>> + oneOf: >>>>> + - items: >>>>> + - const: marvell,armada-8k-nand-controller >>>>> + - const: marvell,armada370-nand-controller >>>>> + - enum: >>>>> + - marvell,armada-8k-nand-controller >>>>> + - marvell,armada370-nand-controller >>>>> + - marvell,pxa3xx-nand-controller >>>>> + - description: legacy bindings >>>>> + deprecated: true >>>>> + enum: >>>>> + - marvell,armada-8k-nand >>>>> + - marvell,armada370-nand >>>>> + - marvell,pxa3xx-nand >>>>> + >>>>> + reg: >>>>> + maxItems: 1 >>>>> + >>>>> + interrupts: >>>>> + maxItems: 1 >>>>> + >>>>> + clocks: >>>>> + description: >>>>> + Shall reference the NAND controller clocks, the second one is >>>>> + is only needed for the Armada 7K/8K SoCs >>>>> + minItems: 1 >>>>> + maxItems: 2 >>>>> + >>>>> + clock-names: >>>>> + minItems: 1 >>>>> + items: >>>>> + - const: core >>>>> + - const: reg >>>>> + >>>>> + dmas: >>>>> + maxItems: 1 >>>>> + >>>>> + dma-names: >>>>> + items: >>>>> + - const: data >>>>> + >>>>> + marvell,system-controller: >>>>> + $ref: /schemas/types.yaml#/definitions/phandle >>>>> + description: Syscon node that handles NAND controller related >>>>> registers >>>>> + >>>>> +patternProperties: >>>>> + "^nand@[0-3]$": >>>>> + type: object >>>>> + unevaluatedProperties: false >>>>> + properties: >>>>> + reg: >>>>> + minimum: 0 >>>>> + maximum: 3 >>>>> + >>>>> + nand-rb: >>>>> + minItems: 1 >>>> Drop minItems. >>>> >>>>> + maxItems: 1 >>>> Didn't you have here minimum and maximum? I think I did not ask to >>>> remove them. >>> I did but I couldn't figure out how to do minimum and maximum with an >>> array would the following be correct (note removing both minItems and >>> maxItems as dtb_check complains if I have maxItems and items). >> items: >> minimum: n >> maximum: n >> maxItems: n >> >> or >> >> items: >> - minimum: n >> maximum: n >> >> See for example Documentation/devicetree/bindings/arm/l2c2x0.yaml > Thanks, so my suggestion below should be OK then. >>> nand-rb: >>> items: >>> - minimum: 0 >>> maximum: 1 >>> >>>>> + >>>>> + nand-ecc-step-size: >>>>> + const: 512 >>>>> + >>>>> + nand-ecc-strength: >>>>> + enum: [1, 4, 8, 12, 16] >>>>> + >>>>> + nand-on-flash-bbt: >>>>> + $ref: /schemas/types.yaml#/definitions/flag >>>>> + >>>>> + nand-ecc-mode: >>>>> + const: hw >>>>> + >>>>> + label: >>>>> + $ref: /schemas/types.yaml#/definitions/string >>>> Drop label >>>> >>>>> + >>>>> + partitions: >>>>> + type: object >>>> Drop partitions. >>> This is the part I can't get to work. It should pick it up via >>> nand-controller.yaml but nothing I do seems to work. >>> >>>>> + >>>>> + marvell,nand-keep-config: >>>>> + description: | >>>>> + Orders the driver not to take the timings from the core >>>>> and >>>>> + leaving them completely untouched. Bootloader timings >>>>> will then >>>>> + be used. >>>>> + $ref: /schemas/types.yaml#/definitions/flag >>>>> + >>>>> + marvell,nand-enable-arbiter: >>>>> + description: | >>>>> + To enable the arbiter, all boards blindly used it, >>>>> + this bit was set by the bootloader for many boards and >>>>> even if >>>>> + it is marked reserved in several datasheets, it might >>>>> be needed to set >>>>> + it (otherwise it is harmless). >>>>> + $ref: /schemas/types.yaml#/definitions/flag >>>>> + deprecated: true >>>>> + >>>>> + additionalProperties: false >>>> unevaluatedProperties: false >>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? >> You cannot have both additionalProps and unevaluatedProps at the same >> time, so we do not talk about same thing or this was never working? > > Hmm, I'm a little confused then. At various times I've been told to > put 'additionalProperties: false' or 'unevaluatedProperties: false' > (although never at the same time). I'm not sure when to use one or the > other. > > From what I've been able to glean 'additionalProperties: true' > indicates that the node is expected to have child nodes defined in a > different schema so I would have thought 'additionalProperties: false' > would be appropriate for a schema covering a leaf node. > 'unevaluatedProperties: false' seems to enable stricter checking which > makes sense when all the properties are described in the schema. So I think this might be the problem. If I look at qcom,nandc.yaml or ingenic,nand.yaml which both have a partitions property in their example. Neither have 'unevaluatedProperties: false' on the nand@... subnode. If I add it sure enough I start getting complaints about the 'partitions' node being unexpected. > >> >> Best regards, >> Krzysztof
Hi Chris, Chris.Packham@alliedtelesis.co.nz wrote on Tue, 6 Jun 2023 04:38:01 +0000: > On 6/06/23 08:44, Chris Packham wrote: > > > > On 4/06/23 21:26, Krzysztof Kozlowski wrote: > >> On 02/06/2023 01:06, Chris Packham wrote: > >>> Hi Krzystof, > >>> > >>> On 1/06/23 19:05, Krzysztof Kozlowski wrote: > >>>> On 01/06/2023 01:49, Chris Packham wrote: > >>>>> From: Vadym Kochan <vadym.kochan@plvision.eu> > >>>>> > >>>>> Switch the DT binding to a YAML schema to enable the DT validation. > >>>>> > >>>>> The text binding didn't mention it as a requirement but existing > >>>>> usage > >>>>> has > >>>>> > >>>>> compatible = "marvell,armada-8k-nand-controller", > >>>>> "marvell,armada370-nand-controller"; > >>>>> > >>>>> so the YAML allows this in addition to the individual compatible > >>>>> values. > >>>>> > >>>>> There was also an incorrect reference to dma-names being "rxtx" where > >>>>> the driver and existing device trees actually use dma-names = > >>>>> "data" so > >>>>> this is corrected in the conversion. > >>>>> > >>>>> Signed-off-by: Vadym Kochan <vadym.kochan@plvision.eu> > >>>>> Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz> > >>>>> --- > >>>>> > >>>>> Notes: > >>>>> Changes in v8: > >>>>> - Mark deprecated compatible values as such > >>>>> - Allow "marvell,armada-8k-nand-controller" without > >>>>> "marvell,armada370-nand-controller" > >>>>> - Make dma-names usage reflect reality > >>>>> - Update commit message > >>>>> Changes in v7: > >>>>> - Restore "label" and "partitions" properties (should be > >>>>> picked up via > >>>>> nand-controller.yaml but aren't) > >>>> What do you mean by "aren't"? They are not needed. > >>> (sorry I keep responding to snippets rather than putting all the > >>> replies > >>> in one place. For posterity here's the same response I provided in a > >>> separate message). > >>> > >>> I mean I simply cannot make it work and I'm out of ideas (I'm also > >>> in an > >>> awkward timezone so it takes 24hrs for me to ask a question and get a > >>> response which leads to me making guesses instead of waiting). > >>> > >>> nand-controller.yaml references nand-chip.yaml which references > >>> mtd.yaml > >>> which defines the "label" and "partitions" property. > >>> > >>> I thought marvell,nand-controller.yaml could just say `$ref: > >>> nand-controller.yaml` and it would mean I'd get all the definitions > >>> down > >>> the chain but this doesn't seem to work the way I expect (or more > >>> likely > >>> I'm not doing it right). I thought it might have something to do with > >>> the different patternProperties pattern but even when I make that match > >>> what is used in nand-controller.yaml it doesn't seem to pick up those > >>> properties. > >> Then you are doing something different than all other bindings. > > > > Not intentionally. I should probably check that the existing bindings > > actually work as expected. > > > > One thing that this has that the others don't is including "label" and > > "partitions" in the examples. > > > >>>>> - Add/restore nand-on-flash-bbt and nand-ecc-mode which > >>>>> aren't covered > >>>>> by nand-controller.yaml. > >>>>> - Use "unevalautedProperties: false" > >>>>> - Corrections for clock-names, dma-names, nand-rb and > >>>>> nand-ecc-strength > >>>>> - Add pxa3xx-nand-controller example > >>>>> Changes in v6: > >>>>> - remove properties covered by nand-controller.yaml > >>>>> - add example using armada-8k compatible > >>>>> earlier changes: > >>>>> v5: > >>>>> 1) Get back "label" and "partitions" properties but without > >>>>> ref to the "partition.yaml" which was wrongly used. > >>>>> 2) Add "additionalProperties: false" for nand@ > >>>>> because all possible > >>>>> properties are described. > >>>>> v4: > >>>>> 1) Remove "label" and "partitions" properties > >>>>> 2) Use 2 clocks for A7K/8K platform which is a > >>>>> requirement > >>>>> v3: > >>>>> 1) Remove txt version from the MAINTAINERS list > >>>>> 2) Use enum for some of compatible strings > >>>>> 3) Drop: > >>>>> #address-cells > >>>>> #size-cells: > >>>>> as they are inherited from the nand-controller.yaml > >>>>> 4) Add restriction to use 2 clocks for A8K SoC > >>>>> 5) Dropped description for clock-names and extend it > >>>>> with > >>>>> minItems: 1 > >>>>> 6) Drop description for "dmas" > >>>>> 7) Use "unevalautedProperties: false" > >>>>> 8) Drop quites from yaml refs. > >>>>> 9) Use 4-space indentation for the example section > >>>>> v2: > >>>>> 1) Fixed warning by yamllint with incorrect indentation > >>>>> for compatible list > >>>>> > >>>>> .../bindings/mtd/marvell,nand-controller.yaml | 223 > >>>>> ++++++++++++++++++ > >>>>> .../devicetree/bindings/mtd/marvell-nand.txt | 126 ---------- > >>>>> MAINTAINERS | 1 - > >>>>> 3 files changed, 223 insertions(+), 127 deletions(-) > >>>>> create mode 100644 > >>>>> Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml > >>>>> delete mode 100644 > >>>>> Documentation/devicetree/bindings/mtd/marvell-nand.txt > >>>>> > >>>>> diff --git > >>>>> a/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml > >>>>> b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml > >>>>> new file mode 100644 > >>>>> index 000000000000..433feb430555 > >>>>> --- /dev/null > >>>>> +++ > >>>>> b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml > >>>>> @@ -0,0 +1,223 @@ > >>>>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > >>>>> +%YAML 1.2 > >>>>> +--- > >>>>> +$id: > >>>>> http://scanmail.trustwave.com/?c=20988&d=yNj85IkMld8k0XBdA9CH4pQjE5peaXAdz-exk_Hdww&u=http%3a%2f%2fdevicetree%2eorg%2fschemas%2fmtd%2fmarvell%2cnand-controller%2eyaml%23 > >>>>> +$schema: > >>>>> http://scanmail.trustwave.com/?c=20988&d=yNj85IkMld8k0XBdA9CH4pQjE5peaXAdz-PkkPSLlg&u=http%3a%2f%2fdevicetree%2eorg%2fmeta-schemas%2fcore%2eyaml%23 > >>>>> + > >>>>> +title: Marvell NAND Flash Controller (NFC) > >>>>> + > >>>>> +maintainers: > >>>>> + - Miquel Raynal <miquel.raynal@bootlin.com> > >>>>> + > >>>>> +properties: > >>>>> + compatible: > >>>>> + oneOf: > >>>>> + - items: > >>>>> + - const: marvell,armada-8k-nand-controller > >>>>> + - const: marvell,armada370-nand-controller > >>>>> + - enum: > >>>>> + - marvell,armada-8k-nand-controller > >>>>> + - marvell,armada370-nand-controller > >>>>> + - marvell,pxa3xx-nand-controller > >>>>> + - description: legacy bindings > >>>>> + deprecated: true > >>>>> + enum: > >>>>> + - marvell,armada-8k-nand > >>>>> + - marvell,armada370-nand > >>>>> + - marvell,pxa3xx-nand > >>>>> + > >>>>> + reg: > >>>>> + maxItems: 1 > >>>>> + > >>>>> + interrupts: > >>>>> + maxItems: 1 > >>>>> + > >>>>> + clocks: > >>>>> + description: > >>>>> + Shall reference the NAND controller clocks, the second one is > >>>>> + is only needed for the Armada 7K/8K SoCs > >>>>> + minItems: 1 > >>>>> + maxItems: 2 > >>>>> + > >>>>> + clock-names: > >>>>> + minItems: 1 > >>>>> + items: > >>>>> + - const: core > >>>>> + - const: reg > >>>>> + > >>>>> + dmas: > >>>>> + maxItems: 1 > >>>>> + > >>>>> + dma-names: > >>>>> + items: > >>>>> + - const: data > >>>>> + > >>>>> + marvell,system-controller: > >>>>> + $ref: /schemas/types.yaml#/definitions/phandle > >>>>> + description: Syscon node that handles NAND controller related > >>>>> registers > >>>>> + > >>>>> +patternProperties: > >>>>> + "^nand@[0-3]$": > >>>>> + type: object > >>>>> + unevaluatedProperties: false > >>>>> + properties: > >>>>> + reg: > >>>>> + minimum: 0 > >>>>> + maximum: 3 > >>>>> + > >>>>> + nand-rb: > >>>>> + minItems: 1 > >>>> Drop minItems. > >>>> > >>>>> + maxItems: 1 > >>>> Didn't you have here minimum and maximum? I think I did not ask to > >>>> remove them. > >>> I did but I couldn't figure out how to do minimum and maximum with an > >>> array would the following be correct (note removing both minItems and > >>> maxItems as dtb_check complains if I have maxItems and items). > >> items: > >> minimum: n > >> maximum: n > >> maxItems: n > >> > >> or > >> > >> items: > >> - minimum: n > >> maximum: n > >> > >> See for example Documentation/devicetree/bindings/arm/l2c2x0.yaml > > Thanks, so my suggestion below should be OK then. > >>> nand-rb: > >>> items: > >>> - minimum: 0 > >>> maximum: 1 > >>> > >>>>> + > >>>>> + nand-ecc-step-size: > >>>>> + const: 512 > >>>>> + > >>>>> + nand-ecc-strength: > >>>>> + enum: [1, 4, 8, 12, 16] > >>>>> + > >>>>> + nand-on-flash-bbt: > >>>>> + $ref: /schemas/types.yaml#/definitions/flag > >>>>> + > >>>>> + nand-ecc-mode: > >>>>> + const: hw > >>>>> + > >>>>> + label: > >>>>> + $ref: /schemas/types.yaml#/definitions/string > >>>> Drop label > >>>> > >>>>> + > >>>>> + partitions: > >>>>> + type: object > >>>> Drop partitions. > >>> This is the part I can't get to work. It should pick it up via > >>> nand-controller.yaml but nothing I do seems to work. > >>> > >>>>> + > >>>>> + marvell,nand-keep-config: > >>>>> + description: | > >>>>> + Orders the driver not to take the timings from the core > >>>>> and > >>>>> + leaving them completely untouched. Bootloader timings > >>>>> will then > >>>>> + be used. > >>>>> + $ref: /schemas/types.yaml#/definitions/flag > >>>>> + > >>>>> + marvell,nand-enable-arbiter: > >>>>> + description: | > >>>>> + To enable the arbiter, all boards blindly used it, > >>>>> + this bit was set by the bootloader for many boards and > >>>>> even if > >>>>> + it is marked reserved in several datasheets, it might > >>>>> be needed to set > >>>>> + it (otherwise it is harmless). > >>>>> + $ref: /schemas/types.yaml#/definitions/flag > >>>>> + deprecated: true > >>>>> + > >>>>> + additionalProperties: false > >>>> unevaluatedProperties: false > >>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? > >> You cannot have both additionalProps and unevaluatedProps at the same > >> time, so we do not talk about same thing or this was never working? > > > > Hmm, I'm a little confused then. At various times I've been told to > > put 'additionalProperties: false' or 'unevaluatedProperties: false' > > (although never at the same time). I'm not sure when to use one or the > > other. > > > > From what I've been able to glean 'additionalProperties: true' > > indicates that the node is expected to have child nodes defined in a > > different schema so I would have thought 'additionalProperties: false' > > would be appropriate for a schema covering a leaf node. > > 'unevaluatedProperties: false' seems to enable stricter checking which > > makes sense when all the properties are described in the schema. > > So I think this might be the problem. If I look at qcom,nandc.yaml or > ingenic,nand.yaml which both have a partitions property in their > example. Neither have 'unevaluatedProperties: false' on the nand@... > subnode. If I add it sure enough I start getting complaints about the > 'partitions' node being unexpected. Sorry if that was unclear, I think the whole logic around the yaml files is to progressively constrain the descriptions, schema after schema. IOW, in the marvell binding you should set unevaluatedProperties: false for the NAND controller. What is inside (NAND chips, partition container, partition parsers, "mtd" properties, etc) will be handled by other files. Of course you can constrain a bit what can/cannot be used inside these subnodes, but I think you don't need to set unevaluatedProperties in these subnodes (the NAND chip in this case, or even the partitions) because you already reference nand-controller.yaml which references nand-chip.yaml, mtd.yaml, partitions.yaml, etc. *they* will make the generic checks and hopefully apply stricter checks, when deemed relevant. Thanks, Miquèl
On 06/06/2023 09:48, Miquel Raynal wrote: >>>>>>> + it (otherwise it is harmless). >>>>>>> + $ref: /schemas/types.yaml#/definitions/flag >>>>>>> + deprecated: true >>>>>>> + >>>>>>> + additionalProperties: false >>>>>> unevaluatedProperties: false >>>>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? >>>> You cannot have both additionalProps and unevaluatedProps at the same >>>> time, so we do not talk about same thing or this was never working? >>> >>> Hmm, I'm a little confused then. At various times I've been told to >>> put 'additionalProperties: false' or 'unevaluatedProperties: false' >>> (although never at the same time). I'm not sure when to use one or the >>> other. >>> >>> From what I've been able to glean 'additionalProperties: true' >>> indicates that the node is expected to have child nodes defined in a >>> different schema so I would have thought 'additionalProperties: false' >>> would be appropriate for a schema covering a leaf node. >>> 'unevaluatedProperties: false' seems to enable stricter checking which >>> makes sense when all the properties are described in the schema. >> >> So I think this might be the problem. If I look at qcom,nandc.yaml or >> ingenic,nand.yaml which both have a partitions property in their >> example. Neither have 'unevaluatedProperties: false' on the nand@... >> subnode. If I add it sure enough I start getting complaints about the >> 'partitions' node being unexpected. > > Sorry if that was unclear, I think the whole logic around the yaml > files is to progressively constrain the descriptions, schema after > schema. IOW, in the marvell binding you should set > unevaluatedProperties: false for the NAND controller. What is inside > (NAND chips, partition container, partition parsers, "mtd" properties, > etc) will be handled by other files. Of course you can constrain a bit > what can/cannot be used inside these subnodes, but I think you don't > need to set unevaluatedProperties in these subnodes (the NAND chip in > this case, or even the partitions) because you already reference > nand-controller.yaml which references nand-chip.yaml, mtd.yaml, > partitions.yaml, etc. *they* will make the generic checks and hopefully > apply stricter checks, when deemed relevant. No, neither nand-controller.yaml nor nand-chip.yaml limit the properties in this context, so each device schema must have unevaluatedProperties: false, for which I asked few emails ago. Best regards, Krzysztof
Hi Krzysztof, krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 10:44:34 +0200: > On 06/06/2023 09:48, Miquel Raynal wrote: > >>>>>>> + it (otherwise it is harmless). > >>>>>>> + $ref: /schemas/types.yaml#/definitions/flag > >>>>>>> + deprecated: true > >>>>>>> + > >>>>>>> + additionalProperties: false > >>>>>> unevaluatedProperties: false > >>>>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? > >>>> You cannot have both additionalProps and unevaluatedProps at the same > >>>> time, so we do not talk about same thing or this was never working? > >>> > >>> Hmm, I'm a little confused then. At various times I've been told to > >>> put 'additionalProperties: false' or 'unevaluatedProperties: false' > >>> (although never at the same time). I'm not sure when to use one or the > >>> other. > >>> > >>> From what I've been able to glean 'additionalProperties: true' > >>> indicates that the node is expected to have child nodes defined in a > >>> different schema so I would have thought 'additionalProperties: false' > >>> would be appropriate for a schema covering a leaf node. > >>> 'unevaluatedProperties: false' seems to enable stricter checking which > >>> makes sense when all the properties are described in the schema. > >> > >> So I think this might be the problem. If I look at qcom,nandc.yaml or > >> ingenic,nand.yaml which both have a partitions property in their > >> example. Neither have 'unevaluatedProperties: false' on the nand@... > >> subnode. If I add it sure enough I start getting complaints about the > >> 'partitions' node being unexpected. > > > > Sorry if that was unclear, I think the whole logic around the yaml > > files is to progressively constrain the descriptions, schema after > > schema. IOW, in the marvell binding you should set > > unevaluatedProperties: false for the NAND controller. What is inside > > (NAND chips, partition container, partition parsers, "mtd" properties, > > etc) will be handled by other files. Of course you can constrain a bit > > what can/cannot be used inside these subnodes, but I think you don't > > need to set unevaluatedProperties in these subnodes (the NAND chip in > > this case, or even the partitions) because you already reference > > nand-controller.yaml which references nand-chip.yaml, mtd.yaml, > > partitions.yaml, etc. *they* will make the generic checks and hopefully > > apply stricter checks, when deemed relevant. > > No, neither nand-controller.yaml nor nand-chip.yaml limit the properties > in this context, so each device schema must have unevaluatedProperties: > false, for which I asked few emails ago. The controller description shall be guarded by unevaluatedProperties: false, we agree. Do you mean the nand chip description in each nand controller binding should also include it at its own level? Because that is not what we enforced so far IIRC. I am totally fine doing so starting from now on if this is a new requirement (which makes sense). If yes, then it means we would need to list *all* the nand chip properties in each schema, which clearly involves a lot of duplication as you would need to define all types of partitions, partition parsers, generic properties, etc in order for the examples to pass all the checks. Only the properties like pinctrl-* would not need to be listed I guess. As Chris was having issues comparing his work with the ingenic and qcom yaml files, I gave your input a try and hopefully "fixed" these bindings. I'll Cc Chris on the submission so that he has an example of working -but maybe not fully valid, let's see- binding to take as example. Thanks, Miquèl
On 06/06/2023 12:28, Miquel Raynal wrote: > Hi Krzysztof, > > krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 10:44:34 +0200: > >> On 06/06/2023 09:48, Miquel Raynal wrote: >>>>>>>>> + it (otherwise it is harmless). >>>>>>>>> + $ref: /schemas/types.yaml#/definitions/flag >>>>>>>>> + deprecated: true >>>>>>>>> + >>>>>>>>> + additionalProperties: false >>>>>>>> unevaluatedProperties: false >>>>>>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? >>>>>> You cannot have both additionalProps and unevaluatedProps at the same >>>>>> time, so we do not talk about same thing or this was never working? >>>>> >>>>> Hmm, I'm a little confused then. At various times I've been told to >>>>> put 'additionalProperties: false' or 'unevaluatedProperties: false' >>>>> (although never at the same time). I'm not sure when to use one or the >>>>> other. >>>>> >>>>> From what I've been able to glean 'additionalProperties: true' >>>>> indicates that the node is expected to have child nodes defined in a >>>>> different schema so I would have thought 'additionalProperties: false' >>>>> would be appropriate for a schema covering a leaf node. >>>>> 'unevaluatedProperties: false' seems to enable stricter checking which >>>>> makes sense when all the properties are described in the schema. >>>> >>>> So I think this might be the problem. If I look at qcom,nandc.yaml or >>>> ingenic,nand.yaml which both have a partitions property in their >>>> example. Neither have 'unevaluatedProperties: false' on the nand@... >>>> subnode. If I add it sure enough I start getting complaints about the >>>> 'partitions' node being unexpected. >>> >>> Sorry if that was unclear, I think the whole logic around the yaml >>> files is to progressively constrain the descriptions, schema after >>> schema. IOW, in the marvell binding you should set >>> unevaluatedProperties: false for the NAND controller. What is inside >>> (NAND chips, partition container, partition parsers, "mtd" properties, >>> etc) will be handled by other files. Of course you can constrain a bit >>> what can/cannot be used inside these subnodes, but I think you don't >>> need to set unevaluatedProperties in these subnodes (the NAND chip in >>> this case, or even the partitions) because you already reference >>> nand-controller.yaml which references nand-chip.yaml, mtd.yaml, >>> partitions.yaml, etc. *they* will make the generic checks and hopefully >>> apply stricter checks, when deemed relevant. >> >> No, neither nand-controller.yaml nor nand-chip.yaml limit the properties >> in this context, so each device schema must have unevaluatedProperties: >> false, for which I asked few emails ago. > > The controller description shall be guarded by unevaluatedProperties: > false, we agree. Do you mean the nand chip description in each nand > controller binding should also include it at its own level? Because > that is not what we enforced so far IIRC. I am totally fine doing so > starting from now on if this is a new requirement (which makes sense). > > If yes, then it means we would need to list *all* the nand > chip properties in each schema, which clearly involves a lot of > duplication as you would need to define all types of partitions, > partition parsers, generic properties, etc in order for the examples to > pass all the checks. Only the properties like pinctrl-* would not need > to be listed I guess. Yes, this is what should be done. Each node should have either additional or unevaluatedProperties: false. It might come from referenced schema or from final (device) schema), but it looks here it is missing. It's exactly the same in all bindings. You will find plenty of examples, e.g. individual leds children and common.yaml. > > As Chris was having issues comparing his work with the ingenic and qcom > yaml files, I gave your input a try and hopefully "fixed" these > bindings. Both are wrong in this matter. You can easily test it. Patch like: diff --git a/Documentation/devicetree/bindings/mtd/ingenic,nand.yaml b/Documentation/devicetree/bindings/mtd/ingenic,nand.yaml index a7bdb5d3675c..968c42f6b5a2 100644 --- a/Documentation/devicetree/bindings/mtd/ingenic,nand.yaml +++ b/Documentation/devicetree/bindings/mtd/ingenic,nand.yaml @@ -97,6 +97,8 @@ examples: nand-ecc-mode = "hw"; nand-on-flash-bbt; + fake-stuff; + pinctrl-names = "default"; pinctrl-0 = <&pins_nemc_cs1>; should trigger warning as this is clearly fake-stuff. No warning though... Best regards, Krzysztof
On 06/06/2023 12:37, Krzysztof Kozlowski wrote: > On 06/06/2023 12:28, Miquel Raynal wrote: >> Hi Krzysztof, >> >> krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 10:44:34 +0200: >> >>> On 06/06/2023 09:48, Miquel Raynal wrote: >>>>>>>>>> + it (otherwise it is harmless). >>>>>>>>>> + $ref: /schemas/types.yaml#/definitions/flag >>>>>>>>>> + deprecated: true >>>>>>>>>> + >>>>>>>>>> + additionalProperties: false >>>>>>>>> unevaluatedProperties: false >>>>>>>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? >>>>>>> You cannot have both additionalProps and unevaluatedProps at the same >>>>>>> time, so we do not talk about same thing or this was never working? >>>>>> >>>>>> Hmm, I'm a little confused then. At various times I've been told to >>>>>> put 'additionalProperties: false' or 'unevaluatedProperties: false' >>>>>> (although never at the same time). I'm not sure when to use one or the >>>>>> other. >>>>>> >>>>>> From what I've been able to glean 'additionalProperties: true' >>>>>> indicates that the node is expected to have child nodes defined in a >>>>>> different schema so I would have thought 'additionalProperties: false' >>>>>> would be appropriate for a schema covering a leaf node. >>>>>> 'unevaluatedProperties: false' seems to enable stricter checking which >>>>>> makes sense when all the properties are described in the schema. >>>>> >>>>> So I think this might be the problem. If I look at qcom,nandc.yaml or >>>>> ingenic,nand.yaml which both have a partitions property in their >>>>> example. Neither have 'unevaluatedProperties: false' on the nand@... >>>>> subnode. If I add it sure enough I start getting complaints about the >>>>> 'partitions' node being unexpected. >>>> >>>> Sorry if that was unclear, I think the whole logic around the yaml >>>> files is to progressively constrain the descriptions, schema after >>>> schema. IOW, in the marvell binding you should set >>>> unevaluatedProperties: false for the NAND controller. What is inside >>>> (NAND chips, partition container, partition parsers, "mtd" properties, >>>> etc) will be handled by other files. Of course you can constrain a bit >>>> what can/cannot be used inside these subnodes, but I think you don't >>>> need to set unevaluatedProperties in these subnodes (the NAND chip in >>>> this case, or even the partitions) because you already reference >>>> nand-controller.yaml which references nand-chip.yaml, mtd.yaml, >>>> partitions.yaml, etc. *they* will make the generic checks and hopefully >>>> apply stricter checks, when deemed relevant. >>> >>> No, neither nand-controller.yaml nor nand-chip.yaml limit the properties >>> in this context, so each device schema must have unevaluatedProperties: >>> false, for which I asked few emails ago. >> >> The controller description shall be guarded by unevaluatedProperties: >> false, we agree. Do you mean the nand chip description in each nand >> controller binding should also include it at its own level? Because >> that is not what we enforced so far IIRC. I am totally fine doing so >> starting from now on if this is a new requirement (which makes sense). >> >> If yes, then it means we would need to list *all* the nand >> chip properties in each schema, which clearly involves a lot of >> duplication as you would need to define all types of partitions, >> partition parsers, generic properties, etc in order for the examples to >> pass all the checks. Only the properties like pinctrl-* would not need >> to be listed I guess. > > Yes, this is what should be done. Each node should have either Eh, no, I responded in wrong part of message. My yes was for: " Do you mean the nand chip description in each nand controller binding should also include it at its own level?" Now for actual paragraph: "If yes, then it means we would need to list *all* the nand chip properties in each schema," No, why? I don't understand. Use the same pattern as all other bindings, this is not special. Absolutely all have the same behavior, e.g. mentioned leds. You finish with unevaluatedProps and you're done, which is what I wrote here long, long time ago. Best regards, Krzysztof
Hi Krzysztof, krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 12:40:45 +0200: > On 06/06/2023 12:37, Krzysztof Kozlowski wrote: > > On 06/06/2023 12:28, Miquel Raynal wrote: > >> Hi Krzysztof, > >> > >> krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 10:44:34 +0200: > >> > >>> On 06/06/2023 09:48, Miquel Raynal wrote: > >>>>>>>>>> + it (otherwise it is harmless). > >>>>>>>>>> + $ref: /schemas/types.yaml#/definitions/flag > >>>>>>>>>> + deprecated: true > >>>>>>>>>> + > >>>>>>>>>> + additionalProperties: false > >>>>>>>>> unevaluatedProperties: false > >>>>>>>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? > >>>>>>> You cannot have both additionalProps and unevaluatedProps at the same > >>>>>>> time, so we do not talk about same thing or this was never working? > >>>>>> > >>>>>> Hmm, I'm a little confused then. At various times I've been told to > >>>>>> put 'additionalProperties: false' or 'unevaluatedProperties: false' > >>>>>> (although never at the same time). I'm not sure when to use one or the > >>>>>> other. > >>>>>> > >>>>>> From what I've been able to glean 'additionalProperties: true' > >>>>>> indicates that the node is expected to have child nodes defined in a > >>>>>> different schema so I would have thought 'additionalProperties: false' > >>>>>> would be appropriate for a schema covering a leaf node. > >>>>>> 'unevaluatedProperties: false' seems to enable stricter checking which > >>>>>> makes sense when all the properties are described in the schema. > >>>>> > >>>>> So I think this might be the problem. If I look at qcom,nandc.yaml or > >>>>> ingenic,nand.yaml which both have a partitions property in their > >>>>> example. Neither have 'unevaluatedProperties: false' on the nand@... > >>>>> subnode. If I add it sure enough I start getting complaints about the > >>>>> 'partitions' node being unexpected. > >>>> > >>>> Sorry if that was unclear, I think the whole logic around the yaml > >>>> files is to progressively constrain the descriptions, schema after > >>>> schema. IOW, in the marvell binding you should set > >>>> unevaluatedProperties: false for the NAND controller. What is inside > >>>> (NAND chips, partition container, partition parsers, "mtd" properties, > >>>> etc) will be handled by other files. Of course you can constrain a bit > >>>> what can/cannot be used inside these subnodes, but I think you don't > >>>> need to set unevaluatedProperties in these subnodes (the NAND chip in > >>>> this case, or even the partitions) because you already reference > >>>> nand-controller.yaml which references nand-chip.yaml, mtd.yaml, > >>>> partitions.yaml, etc. *they* will make the generic checks and hopefully > >>>> apply stricter checks, when deemed relevant. > >>> > >>> No, neither nand-controller.yaml nor nand-chip.yaml limit the properties > >>> in this context, so each device schema must have unevaluatedProperties: > >>> false, for which I asked few emails ago. > >> > >> The controller description shall be guarded by unevaluatedProperties: > >> false, we agree. Do you mean the nand chip description in each nand > >> controller binding should also include it at its own level? Because > >> that is not what we enforced so far IIRC. I am totally fine doing so > >> starting from now on if this is a new requirement (which makes sense). > >> > >> If yes, then it means we would need to list *all* the nand > >> chip properties in each schema, which clearly involves a lot of > >> duplication as you would need to define all types of partitions, > >> partition parsers, generic properties, etc in order for the examples to > >> pass all the checks. Only the properties like pinctrl-* would not need > >> to be listed I guess. > > > > Yes, this is what should be done. Each node should have either > > Eh, no, I responded in wrong part of message. My yes was for: > > " Do you mean the nand chip description in each nand > controller binding should also include it at its own level?" Clear. > > Now for actual paragraph: > > "If yes, then it means we would need to list *all* the nand chip > properties in each schema," > > No, why? I don't understand. Use the same pattern as all other bindings, > this is not special. Absolutely all have the same behavior, e.g. > mentioned leds. You finish with unevaluatedProps and you're done, which > is what I wrote here long, long time ago. Maybe because so far we did not bother referencing another schema in the NAND chip nodes? For your hint to work I guess we should have, in each controller binding, something along: patternProperties: "^nand@[a-f0-9]$": type: object + $ref: nand-chip.yaml# properties: If yes, please ignore the series sent aside, I will work on it again and send a v2. Thanks, Miquèl
Hi Krzysztof, miquel.raynal@bootlin.com wrote on Tue, 6 Jun 2023 12:57:24 +0200: > Hi Krzysztof, > > krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 12:40:45 +0200: > > > On 06/06/2023 12:37, Krzysztof Kozlowski wrote: > > > On 06/06/2023 12:28, Miquel Raynal wrote: > > >> Hi Krzysztof, > > >> > > >> krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 10:44:34 +0200: > > >> > > >>> On 06/06/2023 09:48, Miquel Raynal wrote: > > >>>>>>>>>> + it (otherwise it is harmless). > > >>>>>>>>>> + $ref: /schemas/types.yaml#/definitions/flag > > >>>>>>>>>> + deprecated: true > > >>>>>>>>>> + > > >>>>>>>>>> + additionalProperties: false > > >>>>>>>>> unevaluatedProperties: false > > >>>>>>>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? > > >>>>>>> You cannot have both additionalProps and unevaluatedProps at the same > > >>>>>>> time, so we do not talk about same thing or this was never working? > > >>>>>> > > >>>>>> Hmm, I'm a little confused then. At various times I've been told to > > >>>>>> put 'additionalProperties: false' or 'unevaluatedProperties: false' > > >>>>>> (although never at the same time). I'm not sure when to use one or the > > >>>>>> other. > > >>>>>> > > >>>>>> From what I've been able to glean 'additionalProperties: true' > > >>>>>> indicates that the node is expected to have child nodes defined in a > > >>>>>> different schema so I would have thought 'additionalProperties: false' > > >>>>>> would be appropriate for a schema covering a leaf node. > > >>>>>> 'unevaluatedProperties: false' seems to enable stricter checking which > > >>>>>> makes sense when all the properties are described in the schema. > > >>>>> > > >>>>> So I think this might be the problem. If I look at qcom,nandc.yaml or > > >>>>> ingenic,nand.yaml which both have a partitions property in their > > >>>>> example. Neither have 'unevaluatedProperties: false' on the nand@... > > >>>>> subnode. If I add it sure enough I start getting complaints about the > > >>>>> 'partitions' node being unexpected. > > >>>> > > >>>> Sorry if that was unclear, I think the whole logic around the yaml > > >>>> files is to progressively constrain the descriptions, schema after > > >>>> schema. IOW, in the marvell binding you should set > > >>>> unevaluatedProperties: false for the NAND controller. What is inside > > >>>> (NAND chips, partition container, partition parsers, "mtd" properties, > > >>>> etc) will be handled by other files. Of course you can constrain a bit > > >>>> what can/cannot be used inside these subnodes, but I think you don't > > >>>> need to set unevaluatedProperties in these subnodes (the NAND chip in > > >>>> this case, or even the partitions) because you already reference > > >>>> nand-controller.yaml which references nand-chip.yaml, mtd.yaml, > > >>>> partitions.yaml, etc. *they* will make the generic checks and hopefully > > >>>> apply stricter checks, when deemed relevant. > > >>> > > >>> No, neither nand-controller.yaml nor nand-chip.yaml limit the properties > > >>> in this context, so each device schema must have unevaluatedProperties: > > >>> false, for which I asked few emails ago. > > >> > > >> The controller description shall be guarded by unevaluatedProperties: > > >> false, we agree. Do you mean the nand chip description in each nand > > >> controller binding should also include it at its own level? Because > > >> that is not what we enforced so far IIRC. I am totally fine doing so > > >> starting from now on if this is a new requirement (which makes sense). > > >> > > >> If yes, then it means we would need to list *all* the nand > > >> chip properties in each schema, which clearly involves a lot of > > >> duplication as you would need to define all types of partitions, > > >> partition parsers, generic properties, etc in order for the examples to > > >> pass all the checks. Only the properties like pinctrl-* would not need > > >> to be listed I guess. > > > > > > Yes, this is what should be done. Each node should have either > > > > Eh, no, I responded in wrong part of message. My yes was for: > > > > " Do you mean the nand chip description in each nand > > controller binding should also include it at its own level?" > > Clear. > > > > > Now for actual paragraph: > > > > "If yes, then it means we would need to list *all* the nand chip > > properties in each schema," > > > > No, why? I don't understand. Use the same pattern as all other bindings, > > this is not special. Absolutely all have the same behavior, e.g. > > mentioned leds. You finish with unevaluatedProps and you're done, which > > is what I wrote here long, long time ago. > > Maybe because so far we did not bother referencing another schema in > the NAND chip nodes? For your hint to work I guess we should have, in > each controller binding, something along: > > patternProperties: > "^nand@[a-f0-9]$": > type: object > + $ref: nand-chip.yaml# > properties: > > If yes, please ignore the series sent aside, I will work on it again > and send a v2. Actually I already see a problem, let's the ingenic,nand.yaml example. The goal, IIUC, is to do: patternProperties: "^nand@[a-f0-9]$": type: object + $ref: nand-chip.yaml properties: ... + unevaluatedProperties: false The example in this file uses a property, nand-on-flash-bbt, which is described inside nand-controller.yaml instead of nand-chip.yaml. Indeed, the former actually describes many properties which are a bit more controller related than chip related. With the above description, the example fails because nand-on-flash-bbt is not allowed (it is not listed in nand-chip.yaml). How would you proceed in this case? Maybe I could move all the NAND chip properties which are somehow related to NAND controllers (and defined in nand-controller.yaml) in a dedicated file and reference it from nand-chip.yaml? Any other idea is welcome. Thanks, Miquèl
On 06/06/2023 12:57, Miquel Raynal wrote: > >> >> Now for actual paragraph: >> >> "If yes, then it means we would need to list *all* the nand chip >> properties in each schema," >> >> No, why? I don't understand. Use the same pattern as all other bindings, >> this is not special. Absolutely all have the same behavior, e.g. >> mentioned leds. You finish with unevaluatedProps and you're done, which >> is what I wrote here long, long time ago. > > Maybe because so far we did not bother referencing another schema in > the NAND chip nodes? For your hint to work I guess we should have, in > each controller binding, something along: > > patternProperties: > "^nand@[a-f0-9]$": > type: object > + $ref: nand-chip.yaml# > properties: > > If yes, please ignore the series sent aside, I will work on it again > and send a v2. nand-controller.yaml has it, so ideally each device binding should not need it, because it already references nand-controller.yaml. However if it doesn't work, then you need nand-chip in each device binding. Best regards, Krzysztof
On 06/06/2023 13:07, Miquel Raynal wrote: > Hi Krzysztof, > > miquel.raynal@bootlin.com wrote on Tue, 6 Jun 2023 12:57:24 +0200: > >> Hi Krzysztof, >> >> krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 12:40:45 +0200: >> >>> On 06/06/2023 12:37, Krzysztof Kozlowski wrote: >>>> On 06/06/2023 12:28, Miquel Raynal wrote: >>>>> Hi Krzysztof, >>>>> >>>>> krzysztof.kozlowski@linaro.org wrote on Tue, 6 Jun 2023 10:44:34 +0200: >>>>> >>>>>> On 06/06/2023 09:48, Miquel Raynal wrote: >>>>>>>>>>>>> + it (otherwise it is harmless). >>>>>>>>>>>>> + $ref: /schemas/types.yaml#/definitions/flag >>>>>>>>>>>>> + deprecated: true >>>>>>>>>>>>> + >>>>>>>>>>>>> + additionalProperties: false >>>>>>>>>>>> unevaluatedProperties: false >>>>>>>>>>> It was hiding by '"^nand@[0-3]$":'. Should I move it here? >>>>>>>>>> You cannot have both additionalProps and unevaluatedProps at the same >>>>>>>>>> time, so we do not talk about same thing or this was never working? >>>>>>>>> >>>>>>>>> Hmm, I'm a little confused then. At various times I've been told to >>>>>>>>> put 'additionalProperties: false' or 'unevaluatedProperties: false' >>>>>>>>> (although never at the same time). I'm not sure when to use one or the >>>>>>>>> other. >>>>>>>>> >>>>>>>>> From what I've been able to glean 'additionalProperties: true' >>>>>>>>> indicates that the node is expected to have child nodes defined in a >>>>>>>>> different schema so I would have thought 'additionalProperties: false' >>>>>>>>> would be appropriate for a schema covering a leaf node. >>>>>>>>> 'unevaluatedProperties: false' seems to enable stricter checking which >>>>>>>>> makes sense when all the properties are described in the schema. >>>>>>>> >>>>>>>> So I think this might be the problem. If I look at qcom,nandc.yaml or >>>>>>>> ingenic,nand.yaml which both have a partitions property in their >>>>>>>> example. Neither have 'unevaluatedProperties: false' on the nand@... >>>>>>>> subnode. If I add it sure enough I start getting complaints about the >>>>>>>> 'partitions' node being unexpected. >>>>>>> >>>>>>> Sorry if that was unclear, I think the whole logic around the yaml >>>>>>> files is to progressively constrain the descriptions, schema after >>>>>>> schema. IOW, in the marvell binding you should set >>>>>>> unevaluatedProperties: false for the NAND controller. What is inside >>>>>>> (NAND chips, partition container, partition parsers, "mtd" properties, >>>>>>> etc) will be handled by other files. Of course you can constrain a bit >>>>>>> what can/cannot be used inside these subnodes, but I think you don't >>>>>>> need to set unevaluatedProperties in these subnodes (the NAND chip in >>>>>>> this case, or even the partitions) because you already reference >>>>>>> nand-controller.yaml which references nand-chip.yaml, mtd.yaml, >>>>>>> partitions.yaml, etc. *they* will make the generic checks and hopefully >>>>>>> apply stricter checks, when deemed relevant. >>>>>> >>>>>> No, neither nand-controller.yaml nor nand-chip.yaml limit the properties >>>>>> in this context, so each device schema must have unevaluatedProperties: >>>>>> false, for which I asked few emails ago. >>>>> >>>>> The controller description shall be guarded by unevaluatedProperties: >>>>> false, we agree. Do you mean the nand chip description in each nand >>>>> controller binding should also include it at its own level? Because >>>>> that is not what we enforced so far IIRC. I am totally fine doing so >>>>> starting from now on if this is a new requirement (which makes sense). >>>>> >>>>> If yes, then it means we would need to list *all* the nand >>>>> chip properties in each schema, which clearly involves a lot of >>>>> duplication as you would need to define all types of partitions, >>>>> partition parsers, generic properties, etc in order for the examples to >>>>> pass all the checks. Only the properties like pinctrl-* would not need >>>>> to be listed I guess. >>>> >>>> Yes, this is what should be done. Each node should have either >>> >>> Eh, no, I responded in wrong part of message. My yes was for: >>> >>> " Do you mean the nand chip description in each nand >>> controller binding should also include it at its own level?" >> >> Clear. >> >>> >>> Now for actual paragraph: >>> >>> "If yes, then it means we would need to list *all* the nand chip >>> properties in each schema," >>> >>> No, why? I don't understand. Use the same pattern as all other bindings, >>> this is not special. Absolutely all have the same behavior, e.g. >>> mentioned leds. You finish with unevaluatedProps and you're done, which >>> is what I wrote here long, long time ago. >> >> Maybe because so far we did not bother referencing another schema in >> the NAND chip nodes? For your hint to work I guess we should have, in >> each controller binding, something along: >> >> patternProperties: >> "^nand@[a-f0-9]$": >> type: object >> + $ref: nand-chip.yaml# >> properties: >> >> If yes, please ignore the series sent aside, I will work on it again >> and send a v2. > > Actually I already see a problem, let's the ingenic,nand.yaml example. > The goal, IIUC, is to do: > > patternProperties: > "^nand@[a-f0-9]$": > type: object > + $ref: nand-chip.yaml > properties: > > ... > > + unevaluatedProperties: false > > The example in this file uses a property, nand-on-flash-bbt, which is > described inside nand-controller.yaml instead of nand-chip.yaml. > Indeed, the former actually describes many properties which are a bit > more controller related than chip related. With the above description, > the example fails because nand-on-flash-bbt is not allowed (it is not > listed in nand-chip.yaml). > > How would you proceed in this case? > > Maybe I could move all the NAND chip properties which are somehow > related to NAND controllers (and defined in nand-controller.yaml) in a > dedicated file and reference it from nand-chip.yaml? Any other idea is > welcome. Yes, this would work and seems reasonable. Other way could be to add unevaluatedProperties:false on this level (so after ref:nand-chip.yaml) in nand-controller.yaml. This however would not allow any new properties to be defined in device bindings. Best regards, Krzysztof
On 06/06/2023 13:11, Krzysztof Kozlowski wrote: >>> If yes, please ignore the series sent aside, I will work on it again >>> and send a v2. >> >> Actually I already see a problem, let's the ingenic,nand.yaml example. >> The goal, IIUC, is to do: >> >> patternProperties: >> "^nand@[a-f0-9]$": >> type: object >> + $ref: nand-chip.yaml >> properties: >> >> ... >> >> + unevaluatedProperties: false >> >> The example in this file uses a property, nand-on-flash-bbt, which is >> described inside nand-controller.yaml instead of nand-chip.yaml. >> Indeed, the former actually describes many properties which are a bit >> more controller related than chip related. With the above description, >> the example fails because nand-on-flash-bbt is not allowed (it is not >> listed in nand-chip.yaml). >> >> How would you proceed in this case? >> >> Maybe I could move all the NAND chip properties which are somehow >> related to NAND controllers (and defined in nand-controller.yaml) in a >> dedicated file and reference it from nand-chip.yaml? Any other idea is >> welcome. > > Yes, this would work and seems reasonable. Actually, since nand-chip is used by both SPI and NAND, then I think better would be to create separate file - nand-only-chip.yaml (name to be discussed): nand-controller.yaml: "^nand@[a-f0-9]$": $ref: nand-only-chip.yaml nand-only-chip.yaml: $ref: nand-chip.yaml all nand-controller-chip properties follow > Other way could be to add > unevaluatedProperties:false on this level (so after ref:nand-chip.yaml) > in nand-controller.yaml. This however would not allow any new properties > to be defined in device bindings. Best regards, Krzysztof
diff --git a/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml new file mode 100644 index 000000000000..433feb430555 --- /dev/null +++ b/Documentation/devicetree/bindings/mtd/marvell,nand-controller.yaml @@ -0,0 +1,223 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/mtd/marvell,nand-controller.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Marvell NAND Flash Controller (NFC) + +maintainers: + - Miquel Raynal <miquel.raynal@bootlin.com> + +properties: + compatible: + oneOf: + - items: + - const: marvell,armada-8k-nand-controller + - const: marvell,armada370-nand-controller + - enum: + - marvell,armada-8k-nand-controller + - marvell,armada370-nand-controller + - marvell,pxa3xx-nand-controller + - description: legacy bindings + deprecated: true + enum: + - marvell,armada-8k-nand + - marvell,armada370-nand + - marvell,pxa3xx-nand + + reg: + maxItems: 1 + + interrupts: + maxItems: 1 + + clocks: + description: + Shall reference the NAND controller clocks, the second one is + is only needed for the Armada 7K/8K SoCs + minItems: 1 + maxItems: 2 + + clock-names: + minItems: 1 + items: + - const: core + - const: reg + + dmas: + maxItems: 1 + + dma-names: + items: + - const: data + + marvell,system-controller: + $ref: /schemas/types.yaml#/definitions/phandle + description: Syscon node that handles NAND controller related registers + +patternProperties: + "^nand@[0-3]$": + type: object + unevaluatedProperties: false + properties: + reg: + minimum: 0 + maximum: 3 + + nand-rb: + minItems: 1 + maxItems: 1 + + nand-ecc-step-size: + const: 512 + + nand-ecc-strength: + enum: [1, 4, 8, 12, 16] + + nand-on-flash-bbt: + $ref: /schemas/types.yaml#/definitions/flag + + nand-ecc-mode: + const: hw + + label: + $ref: /schemas/types.yaml#/definitions/string + + partitions: + type: object + + marvell,nand-keep-config: + description: | + Orders the driver not to take the timings from the core and + leaving them completely untouched. Bootloader timings will then + be used. + $ref: /schemas/types.yaml#/definitions/flag + + marvell,nand-enable-arbiter: + description: | + To enable the arbiter, all boards blindly used it, + this bit was set by the bootloader for many boards and even if + it is marked reserved in several datasheets, it might be needed to set + it (otherwise it is harmless). + $ref: /schemas/types.yaml#/definitions/flag + deprecated: true + + additionalProperties: false + + required: + - reg + - nand-rb + +allOf: + - $ref: nand-controller.yaml + + - if: + properties: + compatible: + contains: + const: marvell,pxa3xx-nand-controller + then: + required: + - dmas + - dma-names + + - if: + properties: + compatible: + contains: + const: marvell,armada-8k-nand-controller + then: + properties: + clocks: + minItems: 2 + + clock-names: + minItems: 2 + + required: + - marvell,system-controller + +unevaluatedProperties: false + +required: + - compatible + - reg + - interrupts + - clocks + +examples: + - | + #include <dt-bindings/interrupt-controller/arm-gic.h> + nand_controller: nand-controller@d0000 { + compatible = "marvell,armada370-nand-controller"; + reg = <0xd0000 0x54>; + #address-cells = <1>; + #size-cells = <0>; + interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>; + clocks = <&coredivclk 0>; + + nand@0 { + reg = <0>; + label = "main-storage"; + nand-rb = <0>; + nand-ecc-mode = "hw"; + marvell,nand-keep-config; + nand-on-flash-bbt; + nand-ecc-strength = <4>; + nand-ecc-step-size = <512>; + + partitions { + compatible = "fixed-partitions"; + #address-cells = <1>; + #size-cells = <1>; + + partition@0 { + label = "Rootfs"; + reg = <0x00000000 0x40000000>; + }; + }; + }; + }; + + - | + cp0_nand_controller: nand-controller@720000 { + compatible = "marvell,armada-8k-nand-controller", + "marvell,armada370-nand-controller"; + reg = <0x720000 0x54>; + #address-cells = <1>; + #size-cells = <0>; + interrupts = <115 IRQ_TYPE_LEVEL_HIGH>; + clock-names = "core", "reg"; + clocks = <&cp0_clk 1 2>, + <&cp0_clk 1 17>; + marvell,system-controller = <&cp0_syscon0>; + + nand@0 { + reg = <0>; + label = "main-storage"; + nand-rb = <0>; + nand-ecc-mode = "hw"; + nand-ecc-strength = <8>; + nand-ecc-step-size = <512>; + }; + }; + + - | + nand-controller@43100000 { + compatible = "marvell,pxa3xx-nand-controller"; + reg = <0x43100000 90>; + interrupts = <45>; + clocks = <&clks 1>; + clock-names = "core"; + dmas = <&pdma 97 3>; + dma-names = "data"; + #address-cells = <1>; + #size-cells = <0>; + nand@0 { + reg = <0>; + nand-rb = <0>; + nand-ecc-mode = "hw"; + marvell,nand-keep-config; + }; + }; diff --git a/Documentation/devicetree/bindings/mtd/marvell-nand.txt b/Documentation/devicetree/bindings/mtd/marvell-nand.txt deleted file mode 100644 index a2d9a0f2b683..000000000000 --- a/Documentation/devicetree/bindings/mtd/marvell-nand.txt +++ /dev/null @@ -1,126 +0,0 @@ -Marvell NAND Flash Controller (NFC) - -Required properties: -- compatible: can be one of the following: - * "marvell,armada-8k-nand-controller" - * "marvell,armada370-nand-controller" - * "marvell,pxa3xx-nand-controller" - * "marvell,armada-8k-nand" (deprecated) - * "marvell,armada370-nand" (deprecated) - * "marvell,pxa3xx-nand" (deprecated) - Compatibles marked deprecated support only the old bindings described - at the bottom. -- reg: NAND flash controller memory area. -- #address-cells: shall be set to 1. Encode the NAND CS. -- #size-cells: shall be set to 0. -- interrupts: shall define the NAND controller interrupt. -- clocks: shall reference the NAND controller clocks, the second one is - is only needed for the Armada 7K/8K SoCs -- clock-names: mandatory if there is a second clock, in this case there - should be one clock named "core" and another one named "reg" -- marvell,system-controller: Set to retrieve the syscon node that handles - NAND controller related registers (only required with the - "marvell,armada-8k-nand[-controller]" compatibles). - -Optional properties: -- label: see partition.txt. New platforms shall omit this property. -- dmas: shall reference DMA channel associated to the NAND controller. - This property is only used with "marvell,pxa3xx-nand[-controller]" - compatible strings. -- dma-names: shall be "rxtx". - This property is only used with "marvell,pxa3xx-nand[-controller]" - compatible strings. - -Optional children nodes: -Children nodes represent the available NAND chips. - -Required properties: -- reg: shall contain the native Chip Select ids (0-3). -- nand-rb: see nand-controller.yaml (0-1). - -Optional properties: -- marvell,nand-keep-config: orders the driver not to take the timings - from the core and leaving them completely untouched. Bootloader - timings will then be used. -- label: MTD name. -- nand-on-flash-bbt: see nand-controller.yaml. -- nand-ecc-mode: see nand-controller.yaml. Will use hardware ECC if not specified. -- nand-ecc-algo: see nand-controller.yaml. This property is essentially useful when - not using hardware ECC. Howerver, it may be added when using hardware - ECC for clarification but will be ignored by the driver because ECC - mode is chosen depending on the page size and the strength required by - the NAND chip. This value may be overwritten with nand-ecc-strength - property. -- nand-ecc-strength: see nand-controller.yaml. -- nand-ecc-step-size: see nand-controller.yaml. Marvell's NAND flash controller does - use fixed strength (1-bit for Hamming, 16-bit for BCH), so the actual - step size will shrink or grow in order to fit the required strength. - Step sizes are not completely random for all and follow certain - patterns described in AN-379, "Marvell SoC NFC ECC". - -See Documentation/devicetree/bindings/mtd/nand-controller.yaml for more details on -generic bindings. - - -Example: -nand_controller: nand-controller@d0000 { - compatible = "marvell,armada370-nand-controller"; - reg = <0xd0000 0x54>; - #address-cells = <1>; - #size-cells = <0>; - interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>; - clocks = <&coredivclk 0>; - - nand@0 { - reg = <0>; - label = "main-storage"; - nand-rb = <0>; - nand-ecc-mode = "hw"; - marvell,nand-keep-config; - nand-on-flash-bbt; - nand-ecc-strength = <4>; - nand-ecc-step-size = <512>; - - partitions { - compatible = "fixed-partitions"; - #address-cells = <1>; - #size-cells = <1>; - - partition@0 { - label = "Rootfs"; - reg = <0x00000000 0x40000000>; - }; - }; - }; -}; - - -Note on legacy bindings: One can find, in not-updated device trees, -bindings slightly different than described above with other properties -described below as well as the partitions node at the root of a so -called "nand" node (without clear controller/chip separation). - -Legacy properties: -- marvell,nand-enable-arbiter: To enable the arbiter, all boards blindly - used it, this bit was set by the bootloader for many boards and even if - it is marked reserved in several datasheets, it might be needed to set - it (otherwise it is harmless) so whether or not this property is set, - the bit is selected by the driver. -- num-cs: Number of chip-select lines to use, all boards blindly set 1 - to this and for a reason, other values would have failed. The value of - this property is ignored. - -Example: - - nand0: nand@43100000 { - compatible = "marvell,pxa3xx-nand"; - reg = <0x43100000 90>; - interrupts = <45>; - dmas = <&pdma 97 0>; - dma-names = "rxtx"; - #address-cells = <1>; - marvell,nand-keep-config; - marvell,nand-enable-arbiter; - num-cs = <1>; - /* Partitions (optional) */ - }; diff --git a/MAINTAINERS b/MAINTAINERS index 2a42a75c304c..fdd2027529ea 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -12535,7 +12535,6 @@ MARVELL NAND CONTROLLER DRIVER M: Miquel Raynal <miquel.raynal@bootlin.com> L: linux-mtd@lists.infradead.org S: Maintained -F: Documentation/devicetree/bindings/mtd/marvell-nand.txt F: drivers/mtd/nand/raw/marvell_nand.c MARVELL OCTEON ENDPOINT DRIVER