162306a36Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/sound/nvidia,tegra210-dmic.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Tegra210 DMIC Controller
862306a36Sopenharmony_ci
962306a36Sopenharmony_cidescription: |
1062306a36Sopenharmony_ci  The Digital MIC (DMIC) Controller is used to interface with Pulse
1162306a36Sopenharmony_ci  Density Modulation (PDM) input devices. It converts PDM signals to
1262306a36Sopenharmony_ci  Pulse Coded Modulation (PCM) signals. DMIC can be viewed as a PDM
1362306a36Sopenharmony_ci  receiver.
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_cimaintainers:
1662306a36Sopenharmony_ci  - Jon Hunter <jonathanh@nvidia.com>
1762306a36Sopenharmony_ci  - Sameer Pujar <spujar@nvidia.com>
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ciallOf:
2062306a36Sopenharmony_ci  - $ref: dai-common.yaml#
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ciproperties:
2362306a36Sopenharmony_ci  $nodename:
2462306a36Sopenharmony_ci    pattern: "^dmic@[0-9a-f]*$"
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci  compatible:
2762306a36Sopenharmony_ci    oneOf:
2862306a36Sopenharmony_ci      - const: nvidia,tegra210-dmic
2962306a36Sopenharmony_ci      - items:
3062306a36Sopenharmony_ci          - enum:
3162306a36Sopenharmony_ci              - nvidia,tegra234-dmic
3262306a36Sopenharmony_ci              - nvidia,tegra194-dmic
3362306a36Sopenharmony_ci              - nvidia,tegra186-dmic
3462306a36Sopenharmony_ci          - const: nvidia,tegra210-dmic
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci  reg:
3762306a36Sopenharmony_ci    maxItems: 1
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci  clocks:
4062306a36Sopenharmony_ci    maxItems: 1
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci  clock-names:
4362306a36Sopenharmony_ci    const: dmic
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci  assigned-clocks:
4662306a36Sopenharmony_ci    maxItems: 1
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci  assigned-clock-parents:
4962306a36Sopenharmony_ci    maxItems: 1
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci  assigned-clock-rates:
5262306a36Sopenharmony_ci    maxItems: 1
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci  sound-name-prefix:
5562306a36Sopenharmony_ci    pattern: "^DMIC[1-9]$"
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci  ports:
5862306a36Sopenharmony_ci    $ref: /schemas/graph.yaml#/properties/ports
5962306a36Sopenharmony_ci    properties:
6062306a36Sopenharmony_ci      port@0:
6162306a36Sopenharmony_ci        $ref: audio-graph-port.yaml#
6262306a36Sopenharmony_ci        unevaluatedProperties: false
6362306a36Sopenharmony_ci        description: |
6462306a36Sopenharmony_ci          DMIC ACIF (Audio Client Interface) port connected to the
6562306a36Sopenharmony_ci          corresponding AHUB (Audio Hub) ACIF port.
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci      port@1:
6862306a36Sopenharmony_ci        $ref: audio-graph-port.yaml#
6962306a36Sopenharmony_ci        unevaluatedProperties: false
7062306a36Sopenharmony_ci        description: |
7162306a36Sopenharmony_ci          DMIC DAP (Digital Audio Port) interface which can be connected
7262306a36Sopenharmony_ci          to external audio codec for capture.
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_cirequired:
7562306a36Sopenharmony_ci  - compatible
7662306a36Sopenharmony_ci  - reg
7762306a36Sopenharmony_ci  - clocks
7862306a36Sopenharmony_ci  - clock-names
7962306a36Sopenharmony_ci  - assigned-clocks
8062306a36Sopenharmony_ci  - assigned-clock-parents
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_ciadditionalProperties: false
8362306a36Sopenharmony_ci
8462306a36Sopenharmony_ciexamples:
8562306a36Sopenharmony_ci  - |
8662306a36Sopenharmony_ci    #include<dt-bindings/clock/tegra210-car.h>
8762306a36Sopenharmony_ci
8862306a36Sopenharmony_ci    dmic@702d4000 {
8962306a36Sopenharmony_ci        compatible = "nvidia,tegra210-dmic";
9062306a36Sopenharmony_ci        reg = <0x702d4000 0x100>;
9162306a36Sopenharmony_ci        clocks = <&tegra_car TEGRA210_CLK_DMIC1>;
9262306a36Sopenharmony_ci        clock-names = "dmic";
9362306a36Sopenharmony_ci        assigned-clocks = <&tegra_car TEGRA210_CLK_DMIC1>;
9462306a36Sopenharmony_ci        assigned-clock-parents = <&tegra_car TEGRA210_CLK_PLL_A_OUT0>;
9562306a36Sopenharmony_ci        assigned-clock-rates = <3072000>;
9662306a36Sopenharmony_ci        sound-name-prefix = "DMIC1";
9762306a36Sopenharmony_ci    };
9862306a36Sopenharmony_ci
9962306a36Sopenharmony_ci...
100