[PATCH v11 1/7] dt-bindings: soc: mediatek: add mtk svs dt-bindings
Rob Herring
robh at kernel.org
Tue Jan 12 09:47:27 EST 2021
On Thu, Jan 07, 2021 at 10:43:50AM +0800, Roger Lu wrote:
> Document the binding for enabling mtk svs on MediaTek SoC.
>
> Signed-off-by: Roger Lu <roger.lu at mediatek.com>
> ---
> .../bindings/soc/mediatek/mtk-svs.yaml | 80 +++++++++++++++++++
> 1 file changed, 80 insertions(+)
> create mode 100644 Documentation/devicetree/bindings/soc/mediatek/mtk-svs.yaml
>
> diff --git a/Documentation/devicetree/bindings/soc/mediatek/mtk-svs.yaml b/Documentation/devicetree/bindings/soc/mediatek/mtk-svs.yaml
> new file mode 100644
> index 000000000000..bb8c345a0c0a
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/soc/mediatek/mtk-svs.yaml
> @@ -0,0 +1,80 @@
> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
> +%YAML 1.2
> +---
> +$id: http://devicetree.org/schemas/soc/mediatek/mtk-svs.yaml#
> +$schema: http://devicetree.org/meta-schemas/core.yaml#
> +
> +title: Introduce MTK SVS engine
Introduce? That's what this commit does, not what this binding is.
> +
> +maintainers:
> + - Matthias Brugger <matthias.bgg at gmail.com>
> + - Kevin Hilman <khilman at kernel.org>
> + - Nishanth Menon <nm at ti.com>
This should be someone that knows the h/w. Not who applies patches.
Perhaps you.
> +
> +description: |+
> + The Smart Voltage Scaling(SVS) engine is a piece of hardware
> + which has several controllers(banks) for calculating suitable
> + voltage to different power domains(CPU/GPU/CCI) according to
> + chip process corner, temperatures and other factors. Then DVFS
> + driver could apply SVS bank voltage to PMIC/Buck.
> +
> +properties:
> + compatible:
> + enum:
> + - mediatek,mt8183-svs
> +
> + reg:
> + description: Address range of the MTK SVS controller.
> + maxItems: 1
> +
> + interrupts:
> + description: IRQ for the MTK SVS controller.
Drop. That's kind of obvious with only 1 interrupt.
> + maxItems: 1
> +
> + clocks:
> + description: Main clock for MTK SVS controller to work.
How many clocks (maxItems)?
> +
> + clock-names:
> + const: main
> +
> + nvmem-cells:
> + maxItems: 2
> + description:
> + Phandle to the calibration data provided by a nvmem device.
Need to define what each entry is.
items:
- description: ...
- description: ...
> +
> + nvmem-cell-names:
> + items:
> + - const: svs-calibration-data
> + - const: t-calibration-data
> +
> +required:
> + - compatible
> + - reg
> + - interrupts
> + - clocks
> + - clock-names
> + - nvmem-cells
> + - nvmem-cell-names
> +
> +additionalProperties: false
> +
> +examples:
> + - |
> + #include <dt-bindings/clock/mt8183-clk.h>
> + #include <dt-bindings/interrupt-controller/arm-gic.h>
> + #include <dt-bindings/interrupt-controller/irq.h>
> +
> + soc {
> + #address-cells = <2>;
> + #size-cells = <2>;
> +
> + svs at 1100b000 {
> + compatible = "mediatek,mt8183-svs";
> + reg = <0 0x1100b000 0 0x1000>;
> + interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_LOW>;
> + clocks = <&infracfg CLK_INFRA_THERM>;
> + clock-names = "main";
> + nvmem-cells = <&svs_calibration>, <&thermal_calibration>;
> + nvmem-cell-names = "svs-calibration-data", "t-calibration-data";
> + };
> + };
> --
> 2.18.0
>
More information about the linux-arm-kernel
mailing list