18c2ecf20Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
28c2ecf20Sopenharmony_ci%YAML 1.2
38c2ecf20Sopenharmony_ci---
48c2ecf20Sopenharmony_ci$id: http://devicetree.org/schemas/sound/fsl,easrc.yaml#
58c2ecf20Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
68c2ecf20Sopenharmony_ci
78c2ecf20Sopenharmony_cititle: NXP Asynchronous Sample Rate Converter (ASRC) Controller
88c2ecf20Sopenharmony_ci
98c2ecf20Sopenharmony_cimaintainers:
108c2ecf20Sopenharmony_ci  - Shengjiu Wang <shengjiu.wang@nxp.com>
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_ciproperties:
138c2ecf20Sopenharmony_ci  $nodename:
148c2ecf20Sopenharmony_ci    pattern: "^easrc@.*"
158c2ecf20Sopenharmony_ci
168c2ecf20Sopenharmony_ci  compatible:
178c2ecf20Sopenharmony_ci    const: fsl,imx8mn-easrc
188c2ecf20Sopenharmony_ci
198c2ecf20Sopenharmony_ci  reg:
208c2ecf20Sopenharmony_ci    maxItems: 1
218c2ecf20Sopenharmony_ci
228c2ecf20Sopenharmony_ci  interrupts:
238c2ecf20Sopenharmony_ci    maxItems: 1
248c2ecf20Sopenharmony_ci
258c2ecf20Sopenharmony_ci  clocks:
268c2ecf20Sopenharmony_ci    items:
278c2ecf20Sopenharmony_ci      - description: Peripheral clock
288c2ecf20Sopenharmony_ci
298c2ecf20Sopenharmony_ci  clock-names:
308c2ecf20Sopenharmony_ci    items:
318c2ecf20Sopenharmony_ci      - const: mem
328c2ecf20Sopenharmony_ci
338c2ecf20Sopenharmony_ci  dmas:
348c2ecf20Sopenharmony_ci    maxItems: 8
358c2ecf20Sopenharmony_ci
368c2ecf20Sopenharmony_ci  dma-names:
378c2ecf20Sopenharmony_ci    items:
388c2ecf20Sopenharmony_ci      - const: ctx0_rx
398c2ecf20Sopenharmony_ci      - const: ctx0_tx
408c2ecf20Sopenharmony_ci      - const: ctx1_rx
418c2ecf20Sopenharmony_ci      - const: ctx1_tx
428c2ecf20Sopenharmony_ci      - const: ctx2_rx
438c2ecf20Sopenharmony_ci      - const: ctx2_tx
448c2ecf20Sopenharmony_ci      - const: ctx3_rx
458c2ecf20Sopenharmony_ci      - const: ctx3_tx
468c2ecf20Sopenharmony_ci
478c2ecf20Sopenharmony_ci  firmware-name:
488c2ecf20Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/string
498c2ecf20Sopenharmony_ci    const: imx/easrc/easrc-imx8mn.bin
508c2ecf20Sopenharmony_ci    description: The coefficient table for the filters
518c2ecf20Sopenharmony_ci
528c2ecf20Sopenharmony_ci  fsl,asrc-rate:
538c2ecf20Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
548c2ecf20Sopenharmony_ci    minimum: 8000
558c2ecf20Sopenharmony_ci    maximum: 192000
568c2ecf20Sopenharmony_ci    description: Defines a mutual sample rate used by DPCM Back Ends
578c2ecf20Sopenharmony_ci
588c2ecf20Sopenharmony_ci  fsl,asrc-format:
598c2ecf20Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
608c2ecf20Sopenharmony_ci    enum: [2, 6, 10, 32, 36]
618c2ecf20Sopenharmony_ci    default: 2
628c2ecf20Sopenharmony_ci    description:
638c2ecf20Sopenharmony_ci      Defines a mutual sample format used by DPCM Back Ends
648c2ecf20Sopenharmony_ci
658c2ecf20Sopenharmony_cirequired:
668c2ecf20Sopenharmony_ci  - compatible
678c2ecf20Sopenharmony_ci  - reg
688c2ecf20Sopenharmony_ci  - interrupts
698c2ecf20Sopenharmony_ci  - clocks
708c2ecf20Sopenharmony_ci  - clock-names
718c2ecf20Sopenharmony_ci  - dmas
728c2ecf20Sopenharmony_ci  - dma-names
738c2ecf20Sopenharmony_ci  - firmware-name
748c2ecf20Sopenharmony_ci  - fsl,asrc-rate
758c2ecf20Sopenharmony_ci  - fsl,asrc-format
768c2ecf20Sopenharmony_ci
778c2ecf20Sopenharmony_ciadditionalProperties: false
788c2ecf20Sopenharmony_ci
798c2ecf20Sopenharmony_ciexamples:
808c2ecf20Sopenharmony_ci  - |
818c2ecf20Sopenharmony_ci    #include <dt-bindings/clock/imx8mn-clock.h>
828c2ecf20Sopenharmony_ci
838c2ecf20Sopenharmony_ci    easrc: easrc@300c0000 {
848c2ecf20Sopenharmony_ci           compatible = "fsl,imx8mn-easrc";
858c2ecf20Sopenharmony_ci           reg = <0x300c0000 0x10000>;
868c2ecf20Sopenharmony_ci           interrupts = <0x0 122 0x4>;
878c2ecf20Sopenharmony_ci           clocks = <&clk IMX8MN_CLK_ASRC_ROOT>;
888c2ecf20Sopenharmony_ci           clock-names = "mem";
898c2ecf20Sopenharmony_ci           dmas = <&sdma2 16 23 0> , <&sdma2 17 23 0>,
908c2ecf20Sopenharmony_ci                  <&sdma2 18 23 0> , <&sdma2 19 23 0>,
918c2ecf20Sopenharmony_ci                  <&sdma2 20 23 0> , <&sdma2 21 23 0>,
928c2ecf20Sopenharmony_ci                  <&sdma2 22 23 0> , <&sdma2 23 23 0>;
938c2ecf20Sopenharmony_ci           dma-names = "ctx0_rx", "ctx0_tx",
948c2ecf20Sopenharmony_ci                       "ctx1_rx", "ctx1_tx",
958c2ecf20Sopenharmony_ci                       "ctx2_rx", "ctx2_tx",
968c2ecf20Sopenharmony_ci                       "ctx3_rx", "ctx3_tx";
978c2ecf20Sopenharmony_ci           firmware-name = "imx/easrc/easrc-imx8mn.bin";
988c2ecf20Sopenharmony_ci           fsl,asrc-rate  = <8000>;
998c2ecf20Sopenharmony_ci           fsl,asrc-format = <2>;
1008c2ecf20Sopenharmony_ci    };
101