Based on kernel version 6.11
. Page generated on 2024-09-24 08:21 EST
.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 | # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) %YAML 1.2 --- $id: http://devicetree.org/schemas/bus/qcom,ssc-block-bus.yaml# $schema: http://devicetree.org/meta-schemas/core.yaml# title: The AHB Bus Providing a Global View of the SSC Block on (some) qcom SoCs maintainers: - Michael Srba <Michael.Srba@seznam.cz> description: | This binding describes the dependencies (clocks, resets, power domains) which need to be turned on in a sequence before communication over the AHB bus becomes possible. Additionally, the reg property is used to pass to the driver the location of two sadly undocumented registers which need to be poked as part of the sequence. The SSC (Snapdragon Sensor Core) block contains a gpio controller, i2c/spi/uart controllers, a hexagon core, and a clock controller which provides clocks for the above. properties: compatible: items: - const: qcom,msm8998-ssc-block-bus - const: qcom,ssc-block-bus reg: items: - description: SSCAON_CONFIG0 registers - description: SSCAON_CONFIG1 registers reg-names: items: - const: mpm_sscaon_config0 - const: mpm_sscaon_config1 '#address-cells': enum: [ 1, 2 ] '#size-cells': enum: [ 1, 2 ] ranges: true clocks: maxItems: 6 clock-names: items: - const: xo - const: aggre2 - const: gcc_im_sleep - const: aggre2_north - const: ssc_xo - const: ssc_ahbs power-domains: items: - description: CX power domain - description: MX power domain power-domain-names: items: - const: ssc_cx - const: ssc_mx resets: items: - description: Main reset - description: SSC Branch Control Register reset (associated with the ssc_xo and ssc_ahbs clocks) reset-names: items: - const: ssc_reset - const: ssc_bcr qcom,halt-regs: $ref: /schemas/types.yaml#/definitions/phandle-array description: describes how to locate the ssc AXI halt register items: - items: - description: Phandle reference to a syscon representing TCSR - description: offset for the ssc AXI halt register required: - compatible - reg - reg-names - '#address-cells' - '#size-cells' - ranges - clocks - clock-names - power-domains - power-domain-names - resets - reset-names - qcom,halt-regs additionalProperties: type: object examples: - | #include <dt-bindings/clock/qcom,gcc-msm8998.h> #include <dt-bindings/clock/qcom,rpmcc.h> #include <dt-bindings/power/qcom-rpmpd.h> soc { #address-cells = <1>; #size-cells = <1>; // devices under this node are physically located in the SSC block, connected to an ssc-internal bus; ssc_ahb_slave: bus@10ac008 { #address-cells = <1>; #size-cells = <1>; ranges; compatible = "qcom,msm8998-ssc-block-bus", "qcom,ssc-block-bus"; reg = <0x10ac008 0x4>, <0x10ac010 0x4>; reg-names = "mpm_sscaon_config0", "mpm_sscaon_config1"; clocks = <&xo>, <&rpmcc RPM_SMD_AGGR2_NOC_CLK>, <&gcc GCC_IM_SLEEP>, <&gcc AGGRE2_SNOC_NORTH_AXI>, <&gcc SSC_XO>, <&gcc SSC_CNOC_AHBS_CLK>; clock-names = "xo", "aggre2", "gcc_im_sleep", "aggre2_north", "ssc_xo", "ssc_ahbs"; resets = <&gcc GCC_SSC_RESET>, <&gcc GCC_SSC_BCR>; reset-names = "ssc_reset", "ssc_bcr"; power-domains = <&rpmpd MSM8998_SSCCX>, <&rpmpd MSM8998_SSCMX>; power-domain-names = "ssc_cx", "ssc_mx"; qcom,halt-regs = <&tcsr_mutex_regs 0x26000>; }; }; |