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 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 | # Copyright 2020 Lubomir Rintel <lkundrak@v3.sk> %YAML 1.2 --- $id: http://devicetree.org/schemas/serial/8250.yaml# $schema: http://devicetree.org/meta-schemas/core.yaml# title: UART (Universal Asynchronous Receiver/Transmitter) maintainers: - devicetree@vger.kernel.org allOf: - $ref: serial.yaml# - $ref: /schemas/memory-controllers/mc-peripheral-props.yaml# - if: anyOf: - required: - aspeed,lpc-io-reg - required: - aspeed,lpc-interrupts - required: - aspeed,sirq-polarity-sense then: properties: compatible: const: aspeed,ast2500-vuart - if: properties: compatible: const: mrvl,mmp-uart then: properties: reg-shift: const: 2 required: - reg-shift - if: not: properties: compatible: items: - enum: - ns8250 - ns16450 - ns16550 - ns16550a then: anyOf: - required: [ clock-frequency ] - required: [ clocks ] properties: compatible: oneOf: - const: ns8250 - const: ns16450 - const: ns16550 - const: ns16550a - const: ns16850 - const: aspeed,ast2400-vuart - const: aspeed,ast2500-vuart - const: intel,xscale-uart - const: mrvl,pxa-uart - const: nuvoton,wpcm450-uart - const: nuvoton,npcm750-uart - const: nvidia,tegra20-uart - const: nxp,lpc3220-uart - items: - enum: - exar,xr16l2552 - exar,xr16l2551 - exar,xr16l2550 - const: ns8250 - items: - enum: - altr,16550-FIFO32 - altr,16550-FIFO64 - altr,16550-FIFO128 - fsl,16550-FIFO64 - fsl,ns16550 - andestech,uart16550 - nxp,lpc1850-uart - opencores,uart16550-rtlsvn105 - ti,da830-uart - const: ns16550a - items: - enum: - ns16750 - cavium,octeon-3860-uart - xlnx,xps-uart16550-2.00.b - ralink,rt2880-uart - enum: - ns16550 # Deprecated, unless the FIFO really is broken - ns16550a - items: - enum: - nuvoton,npcm845-uart - const: nuvoton,npcm750-uart - items: - enum: - ralink,mt7620a-uart - ralink,rt3052-uart - ralink,rt3883-uart - const: ralink,rt2880-uart - enum: - ns16550 # Deprecated, unless the FIFO really is broken - ns16550a - items: - enum: - mediatek,mt7622-btif - mediatek,mt7623-btif - const: mediatek,mtk-btif - items: - const: mrvl,mmp-uart - const: intel,xscale-uart - items: - enum: - nvidia,tegra30-uart - nvidia,tegra114-uart - nvidia,tegra124-uart - nvidia,tegra210-uart - nvidia,tegra186-uart - nvidia,tegra194-uart - nvidia,tegra234-uart - const: nvidia,tegra20-uart reg: maxItems: 1 interrupts: maxItems: 1 clock-frequency: true clocks: maxItems: 1 resets: maxItems: 1 current-speed: $ref: /schemas/types.yaml#/definitions/uint32 description: The current active speed of the UART. reg-offset: $ref: /schemas/types.yaml#/definitions/uint32 description: | Offset to apply to the mapbase from the start of the registers. reg-shift: description: Quantity to shift the register offsets by. reg-io-width: description: | The size (in bytes) of the IO accesses that should be performed on the device. There are some systems that require 32-bit accesses to the UART (e.g. TI davinci). used-by-rtas: type: boolean description: | Set to indicate that the port is in use by the OpenFirmware RTAS and should not be registered. no-loopback-test: type: boolean description: | Set to indicate that the port does not implement loopback test mode. fifo-size: $ref: /schemas/types.yaml#/definitions/uint32 description: The fifo size of the UART. auto-flow-control: type: boolean description: | One way to enable automatic flow control support. The driver is allowed to detect support for the capability even without this property. tx-threshold: description: | Specify the TX FIFO low water indication for parts with programmable TX FIFO thresholds. overrun-throttle-ms: description: | How long to pause uart rx when input overrun is encountered. rts-gpios: true cts-gpios: true dtr-gpios: true dsr-gpios: true rng-gpios: true dcd-gpios: true aspeed,sirq-polarity-sense: $ref: /schemas/types.yaml#/definitions/phandle-array description: | Phandle to aspeed,ast2500-scu compatible syscon alongside register offset and bit number to identify how the SIRQ polarity should be configured. One possible data source is the LPC/eSPI mode bit. Only applicable to aspeed,ast2500-vuart. deprecated: true aspeed,lpc-io-reg: $ref: /schemas/types.yaml#/definitions/uint32-array maxItems: 1 description: | The VUART LPC address. Only applicable to aspeed,ast2500-vuart. aspeed,lpc-interrupts: $ref: /schemas/types.yaml#/definitions/uint32-array minItems: 2 maxItems: 2 description: | A 2-cell property describing the VUART SIRQ number and SIRQ polarity (IRQ_TYPE_LEVEL_LOW or IRQ_TYPE_LEVEL_HIGH). Only applicable to aspeed,ast2500-vuart. required: - reg - interrupts unevaluatedProperties: false examples: - | serial@80230000 { compatible = "ns8250"; reg = <0x80230000 0x100>; interrupts = <10>; reg-shift = <2>; clock-frequency = <48000000>; }; - | #include <dt-bindings/gpio/gpio.h> serial@49042000 { compatible = "andestech,uart16550", "ns16550a"; reg = <0x49042000 0x400>; interrupts = <80>; clock-frequency = <48000000>; cts-gpios = <&gpio3 5 GPIO_ACTIVE_LOW>; rts-gpios = <&gpio3 6 GPIO_ACTIVE_LOW>; dtr-gpios = <&gpio1 12 GPIO_ACTIVE_LOW>; dsr-gpios = <&gpio1 13 GPIO_ACTIVE_LOW>; dcd-gpios = <&gpio1 14 GPIO_ACTIVE_LOW>; rng-gpios = <&gpio1 15 GPIO_ACTIVE_LOW>; }; - | #include <dt-bindings/clock/aspeed-clock.h> #include <dt-bindings/interrupt-controller/irq.h> serial@1e787000 { compatible = "aspeed,ast2500-vuart"; reg = <0x1e787000 0x40>; reg-shift = <2>; interrupts = <8>; clocks = <&syscon ASPEED_CLK_APB>; no-loopback-test; aspeed,lpc-io-reg = <0x3f8>; aspeed,lpc-interrupts = <4 IRQ_TYPE_LEVEL_LOW>; }; ... |