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/nvmem/qcom,qfprom.yaml#
58c2ecf20Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
68c2ecf20Sopenharmony_ci
78c2ecf20Sopenharmony_cititle: Qualcomm Technologies Inc, QFPROM Efuse bindings
88c2ecf20Sopenharmony_ci
98c2ecf20Sopenharmony_cimaintainers:
108c2ecf20Sopenharmony_ci  - Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_ciallOf:
138c2ecf20Sopenharmony_ci  - $ref: "nvmem.yaml#"
148c2ecf20Sopenharmony_ci
158c2ecf20Sopenharmony_ciproperties:
168c2ecf20Sopenharmony_ci  compatible:
178c2ecf20Sopenharmony_ci    const: qcom,qfprom
188c2ecf20Sopenharmony_ci
198c2ecf20Sopenharmony_ci  reg:
208c2ecf20Sopenharmony_ci    # If the QFPROM is read-only OS image then only the corrected region
218c2ecf20Sopenharmony_ci    # needs to be provided.  If the QFPROM is writable then all 4 regions
228c2ecf20Sopenharmony_ci    # must be provided.
238c2ecf20Sopenharmony_ci    oneOf:
248c2ecf20Sopenharmony_ci      - items:
258c2ecf20Sopenharmony_ci          - description: The corrected region.
268c2ecf20Sopenharmony_ci      - items:
278c2ecf20Sopenharmony_ci          - description: The corrected region.
288c2ecf20Sopenharmony_ci          - description: The raw region.
298c2ecf20Sopenharmony_ci          - description: The config region.
308c2ecf20Sopenharmony_ci          - description: The security control region.
318c2ecf20Sopenharmony_ci
328c2ecf20Sopenharmony_ci  # Clock must be provided if QFPROM is writable from the OS image.
338c2ecf20Sopenharmony_ci  clocks:
348c2ecf20Sopenharmony_ci    maxItems: 1
358c2ecf20Sopenharmony_ci  clock-names:
368c2ecf20Sopenharmony_ci    const: core
378c2ecf20Sopenharmony_ci
388c2ecf20Sopenharmony_ci  # Supply reference must be provided if QFPROM is writable from the OS image.
398c2ecf20Sopenharmony_ci  vcc-supply:
408c2ecf20Sopenharmony_ci    description: Our power supply.
418c2ecf20Sopenharmony_ci
428c2ecf20Sopenharmony_ci  # Needed if any child nodes are present.
438c2ecf20Sopenharmony_ci  "#address-cells":
448c2ecf20Sopenharmony_ci    const: 1
458c2ecf20Sopenharmony_ci  "#size-cells":
468c2ecf20Sopenharmony_ci    const: 1
478c2ecf20Sopenharmony_ci
488c2ecf20Sopenharmony_cirequired:
498c2ecf20Sopenharmony_ci  - compatible
508c2ecf20Sopenharmony_ci  - reg
518c2ecf20Sopenharmony_ci
528c2ecf20Sopenharmony_ciunevaluatedProperties: false
538c2ecf20Sopenharmony_ci
548c2ecf20Sopenharmony_ciexamples:
558c2ecf20Sopenharmony_ci  - |
568c2ecf20Sopenharmony_ci    #include <dt-bindings/clock/qcom,gcc-sc7180.h>
578c2ecf20Sopenharmony_ci
588c2ecf20Sopenharmony_ci    soc {
598c2ecf20Sopenharmony_ci      #address-cells = <2>;
608c2ecf20Sopenharmony_ci      #size-cells = <2>;
618c2ecf20Sopenharmony_ci
628c2ecf20Sopenharmony_ci      efuse@784000 {
638c2ecf20Sopenharmony_ci        compatible = "qcom,qfprom";
648c2ecf20Sopenharmony_ci        reg = <0 0x00784000 0 0x8ff>,
658c2ecf20Sopenharmony_ci              <0 0x00780000 0 0x7a0>,
668c2ecf20Sopenharmony_ci              <0 0x00782000 0 0x100>,
678c2ecf20Sopenharmony_ci              <0 0x00786000 0 0x1fff>;
688c2ecf20Sopenharmony_ci        clocks = <&gcc GCC_SEC_CTRL_CLK_SRC>;
698c2ecf20Sopenharmony_ci        clock-names = "core";
708c2ecf20Sopenharmony_ci        #address-cells = <1>;
718c2ecf20Sopenharmony_ci        #size-cells = <1>;
728c2ecf20Sopenharmony_ci
738c2ecf20Sopenharmony_ci        vcc-supply = <&vreg_l11a_1p8>;
748c2ecf20Sopenharmony_ci
758c2ecf20Sopenharmony_ci        hstx-trim-primary@25b {
768c2ecf20Sopenharmony_ci          reg = <0x25b 0x1>;
778c2ecf20Sopenharmony_ci          bits = <1 3>;
788c2ecf20Sopenharmony_ci        };
798c2ecf20Sopenharmony_ci      };
808c2ecf20Sopenharmony_ci    };
818c2ecf20Sopenharmony_ci
828c2ecf20Sopenharmony_ci  - |
838c2ecf20Sopenharmony_ci    soc {
848c2ecf20Sopenharmony_ci      #address-cells = <2>;
858c2ecf20Sopenharmony_ci      #size-cells = <2>;
868c2ecf20Sopenharmony_ci
878c2ecf20Sopenharmony_ci      efuse@784000 {
888c2ecf20Sopenharmony_ci        compatible = "qcom,qfprom";
898c2ecf20Sopenharmony_ci        reg = <0 0x00784000 0 0x8ff>;
908c2ecf20Sopenharmony_ci        #address-cells = <1>;
918c2ecf20Sopenharmony_ci        #size-cells = <1>;
928c2ecf20Sopenharmony_ci
938c2ecf20Sopenharmony_ci        hstx-trim-primary@1eb {
948c2ecf20Sopenharmony_ci          reg = <0x1eb 0x1>;
958c2ecf20Sopenharmony_ci          bits = <1 4>;
968c2ecf20Sopenharmony_ci        };
978c2ecf20Sopenharmony_ci      };
988c2ecf20Sopenharmony_ci    };
99