DT properties which can have multiple entries need to specify what the entries are and define how many entries there can be. In the case of only a single entry, just 'maxItems: 1' is sufficient. Add the missing entry constraints. These were found with a modified meta-schema. Unfortunately, there are a few cases where the size constraints are not defined such as common bindings, so the meta-schema can't be part of the normal checks. Cc: Jens Axboe <axboe@kernel.dk> Cc: Stephen Boyd <sboyd@kernel.org> Cc: Thierry Reding <thierry.reding@gmail.com> Cc: MyungJoo Ham <myungjoo.ham@samsung.com> Cc: Chanwoo Choi <cw00.choi@samsung.com> Cc: Linus Walleij <linus.walleij@linaro.org> Cc: Bartosz Golaszewski <bgolaszewski@baylibre.com> Cc: Jonathan Cameron <jic23@kernel.org> Cc: Dmitry Torokhov <dmitry.torokhov@gmail.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Marc Zyngier <maz@kernel.org> Cc: Mauro Carvalho Chehab <mchehab@kernel.org> Cc: Chen-Yu Tsai <wens@csie.org> Cc: Ulf Hansson <ulf.hansson@linaro.org> Cc: "David S. Miller" <davem@davemloft.net> Cc: Jakub Kicinski <kuba@kernel.org> Cc: Sebastian Reichel <sre@kernel.org> Cc: Ohad Ben-Cohen <ohad@wizery.com> Cc: Bjorn Andersson <bjorn.andersson@linaro.org> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Acked-by: Sebastian Reichel <sre@kernel.org> Acked-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> #for-iio Acked-by: Chanwoo Choi <cw00.choi@samsung.com> Reviewed-by: Suman Anna <s-anna@ti.com> Acked-by: Paul Cercueil <paul@crapouillou.net> Acked-by: Dmitry Torokhov <dmitry.torokhov@gmail.com> Acked-by: Bartosz Golaszewski <bgolaszewski@baylibre.com> Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Link: https://lore.kernel.org/r/20210104230253.2805217-1-robh@kernel.org Signed-off-by: Rob Herring <robh@kernel.org>
133 lines
2.6 KiB
YAML
133 lines
2.6 KiB
YAML
# SPDX-License-Identifier: GPL-2.0
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/phy/allwinner,sun9i-a80-usb-phy.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: Allwinner A80 USB PHY Device Tree Bindings
|
|
|
|
maintainers:
|
|
- Chen-Yu Tsai <wens@csie.org>
|
|
- Maxime Ripard <mripard@kernel.org>
|
|
|
|
properties:
|
|
"#phy-cells":
|
|
const: 0
|
|
|
|
compatible:
|
|
const: allwinner,sun9i-a80-usb-phy
|
|
|
|
reg:
|
|
maxItems: 1
|
|
|
|
clocks:
|
|
anyOf:
|
|
- maxItems: 1
|
|
description: Main PHY Clock
|
|
|
|
- items:
|
|
- description: Main PHY clock
|
|
- description: HSIC 12MHz clock
|
|
- description: HSIC 480MHz clock
|
|
|
|
clock-names:
|
|
oneOf:
|
|
- const: phy
|
|
|
|
- items:
|
|
- const: phy
|
|
- const: hsic_12M
|
|
- const: hsic_480M
|
|
|
|
resets:
|
|
minItems: 1
|
|
items:
|
|
- description: Normal USB PHY reset
|
|
- description: HSIC Reset
|
|
|
|
reset-names:
|
|
minItems: 1
|
|
items:
|
|
- const: phy
|
|
- const: hsic
|
|
|
|
phy_type:
|
|
const: hsic
|
|
description:
|
|
When absent, the PHY type will be assumed to be normal USB.
|
|
|
|
phy-supply:
|
|
description:
|
|
Regulator that powers VBUS
|
|
|
|
required:
|
|
- "#phy-cells"
|
|
- compatible
|
|
- reg
|
|
- clocks
|
|
- clock-names
|
|
- resets
|
|
- reset-names
|
|
|
|
additionalProperties: false
|
|
|
|
if:
|
|
properties:
|
|
phy_type:
|
|
const: hsic
|
|
|
|
required:
|
|
- phy_type
|
|
|
|
then:
|
|
properties:
|
|
clocks:
|
|
maxItems: 3
|
|
|
|
clock-names:
|
|
maxItems: 3
|
|
|
|
resets:
|
|
maxItems: 2
|
|
|
|
reset-names:
|
|
maxItems: 2
|
|
|
|
examples:
|
|
- |
|
|
#include <dt-bindings/clock/sun9i-a80-usb.h>
|
|
#include <dt-bindings/reset/sun9i-a80-usb.h>
|
|
|
|
usbphy1: phy@a00800 {
|
|
compatible = "allwinner,sun9i-a80-usb-phy";
|
|
reg = <0x00a00800 0x4>;
|
|
clocks = <&usb_clocks CLK_USB0_PHY>;
|
|
clock-names = "phy";
|
|
resets = <&usb_clocks RST_USB0_PHY>;
|
|
reset-names = "phy";
|
|
phy-supply = <®_usb1_vbus>;
|
|
#phy-cells = <0>;
|
|
};
|
|
|
|
- |
|
|
#include <dt-bindings/clock/sun9i-a80-usb.h>
|
|
#include <dt-bindings/reset/sun9i-a80-usb.h>
|
|
|
|
usbphy3: phy@a02800 {
|
|
compatible = "allwinner,sun9i-a80-usb-phy";
|
|
reg = <0x00a02800 0x4>;
|
|
clocks = <&usb_clocks CLK_USB2_PHY>,
|
|
<&usb_clocks CLK_USB_HSIC>,
|
|
<&usb_clocks CLK_USB2_HSIC>;
|
|
clock-names = "phy",
|
|
"hsic_12M",
|
|
"hsic_480M";
|
|
resets = <&usb_clocks RST_USB2_PHY>,
|
|
<&usb_clocks RST_USB2_HSIC>;
|
|
reset-names = "phy",
|
|
"hsic";
|
|
phy_type = "hsic";
|
|
phy-supply = <®_usb3_vbus>;
|
|
#phy-cells = <0>;
|
|
};
|