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/clock/apple,nco.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Apple SoCs' NCO block
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Martin Povišer <povik+lin@cutebit.org>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription: |
1362306a36Sopenharmony_ci  The NCO (Numerically Controlled Oscillator) block found on Apple SoCs
1462306a36Sopenharmony_ci  such as the t8103 (M1) is a programmable clock generator performing
1562306a36Sopenharmony_ci  fractional division of a high frequency input clock.
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci  It carries a number of independent channels and is typically used for
1862306a36Sopenharmony_ci  generation of audio bitclocks.
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ciproperties:
2162306a36Sopenharmony_ci  compatible:
2262306a36Sopenharmony_ci    items:
2362306a36Sopenharmony_ci      - enum:
2462306a36Sopenharmony_ci          - apple,t6000-nco
2562306a36Sopenharmony_ci          - apple,t8103-nco
2662306a36Sopenharmony_ci          - apple,t8112-nco
2762306a36Sopenharmony_ci      - const: apple,nco
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci  clocks:
3062306a36Sopenharmony_ci    description:
3162306a36Sopenharmony_ci      Specifies the reference clock from which the output clocks
3262306a36Sopenharmony_ci      are derived through fractional division.
3362306a36Sopenharmony_ci    maxItems: 1
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci  '#clock-cells':
3662306a36Sopenharmony_ci    const: 1
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci  reg:
3962306a36Sopenharmony_ci    maxItems: 1
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_cirequired:
4262306a36Sopenharmony_ci  - compatible
4362306a36Sopenharmony_ci  - clocks
4462306a36Sopenharmony_ci  - '#clock-cells'
4562306a36Sopenharmony_ci  - reg
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_ciadditionalProperties: false
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ciexamples:
5062306a36Sopenharmony_ci  - |
5162306a36Sopenharmony_ci    nco_clkref: clock-ref {
5262306a36Sopenharmony_ci      compatible = "fixed-clock";
5362306a36Sopenharmony_ci      #clock-cells = <0>;
5462306a36Sopenharmony_ci      clock-frequency = <900000000>;
5562306a36Sopenharmony_ci      clock-output-names = "nco-ref";
5662306a36Sopenharmony_ci    };
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci    nco: clock-controller@23b044000 {
5962306a36Sopenharmony_ci      compatible = "apple,t8103-nco", "apple,nco";
6062306a36Sopenharmony_ci      reg = <0x3b044000 0x14000>;
6162306a36Sopenharmony_ci      #clock-cells = <1>;
6262306a36Sopenharmony_ci      clocks = <&nco_clkref>;
6362306a36Sopenharmony_ci    };
64