Tom Rini | 53633a8 | 2024-02-29 12:33:36 -0500 | [diff] [blame] | 1 | # SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) |
| 2 | %YAML 1.2 |
| 3 | --- |
| 4 | $id: http://devicetree.org/schemas/mmc/arm,pl18x.yaml# |
| 5 | $schema: http://devicetree.org/meta-schemas/core.yaml# |
| 6 | |
| 7 | title: ARM PrimeCell MultiMedia Card Interface (MMCI) PL180 and PL181 |
| 8 | |
| 9 | maintainers: |
| 10 | - Linus Walleij <linus.walleij@linaro.org> |
| 11 | - Ulf Hansson <ulf.hansson@linaro.org> |
| 12 | |
| 13 | description: |
| 14 | The ARM PrimeCells MMCI PL180 and PL181 provides an interface for |
| 15 | reading and writing to MultiMedia and SD cards alike. Over the years |
| 16 | vendors have use the VHDL code from ARM to create derivative MMC/SD/SDIO |
| 17 | host controllers with very similar characteristics. |
| 18 | |
| 19 | allOf: |
| 20 | - $ref: /schemas/arm/primecell.yaml# |
| 21 | - $ref: mmc-controller.yaml# |
| 22 | |
| 23 | # We need a select here so we don't match all nodes with 'arm,primecell' |
| 24 | select: |
| 25 | properties: |
| 26 | compatible: |
| 27 | contains: |
| 28 | enum: |
| 29 | - arm,pl180 |
| 30 | - arm,pl181 |
| 31 | - arm,pl18x |
| 32 | required: |
| 33 | - compatible |
| 34 | |
| 35 | properties: |
| 36 | compatible: |
| 37 | oneOf: |
| 38 | - description: The first version of the block, simply called |
| 39 | PL180 and found in the ARM Integrator IM/PD1 logic module. |
| 40 | items: |
| 41 | - const: arm,pl180 |
| 42 | - const: arm,primecell |
| 43 | - description: The improved version of the block, found in the |
| 44 | ARM Versatile and later reference designs. Further revisions |
| 45 | exist but get detected at runtime by reading some magic numbers |
| 46 | in the PrimeCell ID registers. |
| 47 | items: |
| 48 | - const: arm,pl181 |
| 49 | - const: arm,primecell |
| 50 | - description: Wildcard entry that will let the operating system |
| 51 | inspect the PrimeCell ID registers to determine which hardware |
| 52 | variant of PL180 or PL181 this is. |
| 53 | items: |
| 54 | - const: arm,pl18x |
| 55 | - const: arm,primecell |
| 56 | - description: Entries for STMicroelectronics variant of PL18x. |
| 57 | items: |
| 58 | - enum: |
| 59 | - st,stm32-sdmmc2 |
| 60 | - st,stm32mp25-sdmmc2 |
| 61 | - const: arm,pl18x |
| 62 | - const: arm,primecell |
| 63 | |
| 64 | clocks: |
| 65 | description: One or two clocks, the "apb_pclk" and the "MCLK" |
| 66 | which is the core block clock. The names are not compulsory. |
| 67 | minItems: 1 |
| 68 | maxItems: 2 |
| 69 | |
| 70 | dmas: |
| 71 | maxItems: 2 |
| 72 | |
| 73 | dma-names: |
| 74 | oneOf: |
| 75 | - items: |
| 76 | - const: tx |
| 77 | - const: rx |
| 78 | - items: |
| 79 | - const: rx |
| 80 | - const: tx |
| 81 | |
Tom Rini | 762f85b | 2024-07-20 11:15:10 -0600 | [diff] [blame] | 82 | access-controllers: |
| 83 | minItems: 1 |
| 84 | maxItems: 2 |
| 85 | |
Tom Rini | 53633a8 | 2024-02-29 12:33:36 -0500 | [diff] [blame] | 86 | power-domains: true |
| 87 | |
| 88 | resets: |
| 89 | maxItems: 1 |
| 90 | |
| 91 | reg: |
| 92 | description: the MMIO memory window must be exactly 4KB (0x1000) and the |
| 93 | layout should provide the PrimeCell ID registers so that the device can |
| 94 | be discovered. On ST Micro variants, a second register window may be |
| 95 | defined if a delay block is present and used for tuning. |
| 96 | |
| 97 | interrupts: |
| 98 | description: The first interrupt is the command interrupt and corresponds |
| 99 | to the event at the end of a command. The second interrupt is the |
| 100 | PIO (polled I/O) interrupt and occurs when the FIFO needs to be |
| 101 | emptied as part of a bulk read from the card. Some variants have these |
| 102 | two interrupts wired into the same line (logic OR) and in that case |
| 103 | only one interrupt may be provided. The interrupt-names property is |
| 104 | not used due to inconsistency of existing DTs regarding its content. |
| 105 | deprecated: false |
| 106 | minItems: 1 |
| 107 | maxItems: 2 |
| 108 | |
| 109 | st,sig-dir-dat0: |
| 110 | $ref: /schemas/types.yaml#/definitions/flag |
| 111 | description: ST Micro-specific property, bus signal direction pins used for |
| 112 | DAT[0]. |
| 113 | |
| 114 | st,sig-dir-dat2: |
| 115 | $ref: /schemas/types.yaml#/definitions/flag |
| 116 | description: ST Micro-specific property, bus signal direction pins used for |
| 117 | DAT[2]. |
| 118 | |
| 119 | st,sig-dir-dat31: |
| 120 | $ref: /schemas/types.yaml#/definitions/flag |
| 121 | description: ST Micro-specific property, bus signal direction pins used for |
| 122 | DAT[3] and DAT[1]. |
| 123 | |
| 124 | st,sig-dir-dat74: |
| 125 | $ref: /schemas/types.yaml#/definitions/flag |
| 126 | description: ST Micro-specific property, bus signal direction pins used for |
| 127 | DAT[7] and DAT[4]. |
| 128 | |
| 129 | st,sig-dir-cmd: |
| 130 | $ref: /schemas/types.yaml#/definitions/flag |
| 131 | description: ST Micro-specific property, CMD signal direction used for |
| 132 | pin CMD. |
| 133 | |
| 134 | st,sig-pin-fbclk: |
| 135 | $ref: /schemas/types.yaml#/definitions/flag |
| 136 | description: ST Micro-specific property, feedback clock FBCLK signal pin |
| 137 | in use. |
| 138 | |
| 139 | st,sig-dir: |
| 140 | $ref: /schemas/types.yaml#/definitions/flag |
| 141 | description: ST Micro-specific property, signal direction polarity used for |
| 142 | pins CMD, DAT[0], DAT[1], DAT[2] and DAT[3]. |
| 143 | |
| 144 | st,neg-edge: |
| 145 | $ref: /schemas/types.yaml#/definitions/flag |
| 146 | description: ST Micro-specific property, data and command phase relation, |
| 147 | generated on the sd clock falling edge. |
| 148 | |
| 149 | st,use-ckin: |
| 150 | $ref: /schemas/types.yaml#/definitions/flag |
| 151 | description: ST Micro-specific property, use CKIN pin from an external |
| 152 | driver to sample the receive data (for example with a voltage switch |
| 153 | transceiver). |
| 154 | |
| 155 | st,cmd-gpios: |
| 156 | maxItems: 1 |
| 157 | description: |
| 158 | The GPIO matching the CMD pin. |
| 159 | |
| 160 | st,ck-gpios: |
| 161 | maxItems: 1 |
| 162 | description: |
| 163 | The GPIO matching the CK pin. |
| 164 | |
| 165 | st,ckin-gpios: |
| 166 | maxItems: 1 |
| 167 | description: |
| 168 | The GPIO matching the CKIN pin. |
| 169 | |
| 170 | dependencies: |
| 171 | st,cmd-gpios: [ "st,use-ckin" ] |
| 172 | st,ck-gpios: [ "st,use-ckin" ] |
| 173 | st,ckin-gpios: [ "st,use-ckin" ] |
| 174 | |
| 175 | unevaluatedProperties: false |
| 176 | |
| 177 | required: |
| 178 | - compatible |
| 179 | - reg |
| 180 | - interrupts |
| 181 | |
| 182 | examples: |
| 183 | - | |
| 184 | #include <dt-bindings/interrupt-controller/irq.h> |
| 185 | #include <dt-bindings/gpio/gpio.h> |
| 186 | |
| 187 | mmc@5000 { |
| 188 | compatible = "arm,pl180", "arm,primecell"; |
| 189 | reg = <0x5000 0x1000>; |
| 190 | interrupts-extended = <&vic 22 &sic 1>; |
| 191 | clocks = <&xtal24mhz>, <&pclk>; |
| 192 | clock-names = "mclk", "apb_pclk"; |
| 193 | }; |
| 194 | |
| 195 | - | |
| 196 | #include <dt-bindings/interrupt-controller/irq.h> |
| 197 | |
| 198 | mmc@80126000 { |
| 199 | compatible = "arm,pl18x", "arm,primecell"; |
| 200 | reg = <0x80126000 0x1000>; |
| 201 | interrupts = <0 60 IRQ_TYPE_LEVEL_HIGH>; |
| 202 | dmas = <&dma 29 0 0x2>, <&dma 29 0 0x0>; |
| 203 | dma-names = "rx", "tx"; |
| 204 | clocks = <&prcc_kclk 1 5>, <&prcc_pclk 1 5>; |
| 205 | clock-names = "sdi", "apb_pclk"; |
| 206 | max-frequency = <100000000>; |
| 207 | bus-width = <4>; |
| 208 | cap-sd-highspeed; |
| 209 | cap-mmc-highspeed; |
Tom Rini | 93743d2 | 2024-04-01 09:08:13 -0400 | [diff] [blame] | 210 | cd-gpios = <&gpio2 31 0x4>; |
Tom Rini | 53633a8 | 2024-02-29 12:33:36 -0500 | [diff] [blame] | 211 | st,sig-dir-dat0; |
| 212 | st,sig-dir-dat2; |
| 213 | st,sig-dir-cmd; |
| 214 | st,sig-pin-fbclk; |
| 215 | vmmc-supply = <&ab8500_ldo_aux3_reg>; |
| 216 | vqmmc-supply = <&vmmci>; |
| 217 | }; |
| 218 | |
| 219 | - | |
| 220 | mmc@101f6000 { |
| 221 | compatible = "arm,pl18x", "arm,primecell"; |
| 222 | reg = <0x101f6000 0x1000>; |
| 223 | clocks = <&sdiclk>, <&pclksdi>; |
| 224 | clock-names = "mclk", "apb_pclk"; |
| 225 | interrupts = <22>; |
| 226 | max-frequency = <400000>; |
| 227 | bus-width = <4>; |
| 228 | cap-mmc-highspeed; |
| 229 | cap-sd-highspeed; |
| 230 | full-pwr-cycle; |
| 231 | st,sig-dir-dat0; |
| 232 | st,sig-dir-dat2; |
| 233 | st,sig-dir-dat31; |
| 234 | st,sig-dir-cmd; |
| 235 | st,sig-pin-fbclk; |
| 236 | vmmc-supply = <&vmmc_regulator>; |
| 237 | }; |
| 238 | |
| 239 | - | |
| 240 | mmc@52007000 { |
| 241 | compatible = "arm,pl18x", "arm,primecell"; |
| 242 | arm,primecell-periphid = <0x10153180>; |
| 243 | reg = <0x52007000 0x1000>; |
| 244 | interrupts = <49>; |
| 245 | clocks = <&rcc 0>; |
| 246 | clock-names = "apb_pclk"; |
| 247 | resets = <&rcc 1>; |
| 248 | cap-sd-highspeed; |
| 249 | cap-mmc-highspeed; |
| 250 | max-frequency = <120000000>; |
| 251 | }; |