blob: c7a8a041da507755485676a26fa5b30bb3888356 [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/memory-controllers/ti,gpmc.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: Texas Instruments GPMC Memory Controller
8
9maintainers:
10 - Tony Lindgren <tony@atomide.com>
11 - Roger Quadros <rogerq@kernel.org>
12
13description:
14 The GPMC is a unified memory controller dedicated for interfacing
15 with external memory devices like
16 - Asynchronous SRAM-like memories and ASICs
17 - Asynchronous, synchronous, and page mode burst NOR flash
18 - NAND flash
19 - Pseudo-SRAM devices
20
21properties:
22 compatible:
23 items:
24 - enum:
25 - ti,am3352-gpmc
26 - ti,am64-gpmc
27 - ti,omap2420-gpmc
28 - ti,omap2430-gpmc
29 - ti,omap3430-gpmc
30 - ti,omap4430-gpmc
31
32 reg:
33 minItems: 1
34 maxItems: 2
35
36 reg-names:
37 items:
38 - const: cfg
39 - const: data
40
41 interrupts:
42 maxItems: 1
43
44 clocks:
45 maxItems: 1
46 description: |
47 Functional clock. Used for bus timing calculations and
48 GPMC configuration.
49
50 clock-names:
51 items:
52 - const: fck
53
54 power-domains:
55 maxItems: 1
56
57 dmas:
58 items:
59 - description: DMA channel for GPMC NAND prefetch
60
61 dma-names:
62 items:
63 - const: rxtx
64
65 "#address-cells": true
66
67 "#size-cells": true
68
69 gpmc,num-cs:
70 description: maximum number of supported chip-select lines.
71 $ref: /schemas/types.yaml#/definitions/uint32
72
73 gpmc,num-waitpins:
74 description: maximum number of supported wait pins.
75 $ref: /schemas/types.yaml#/definitions/uint32
76
77 ranges:
78 minItems: 1
79 description: |
80 Must be set up to reflect the memory layout with four
81 integer values for each chip-select line in use,
82 <cs-number> 0 <physical address of mapping> <size>
83 items:
84 - description: NAND bank 0
85 - description: NOR/SRAM bank 0
86 - description: NOR/SRAM bank 1
87
88 '#interrupt-cells':
89 const: 2
90
91 interrupt-controller:
92 description: |
93 The GPMC driver implements an interrupt controller for
94 the NAND events "fifoevent" and "termcount" plus the
95 rising/falling edges on the GPMC_WAIT pins.
96 The interrupt number mapping is as follows
97 0 - NAND_fifoevent
98 1 - NAND_termcount
99 2 - GPMC_WAIT0 pin edge
100 3 - GPMC_WAIT1 pin edge, and so on.
101
102 '#gpio-cells':
103 const: 2
104
105 gpio-controller:
106 description: |
107 The GPMC driver implements a GPIO controller for the
108 GPMC WAIT pins that can be used as general purpose inputs.
109 0 maps to GPMC_WAIT0 pin.
110
111 ti,hwmods:
112 description:
113 Name of the HWMOD associated with GPMC. This is for legacy
114 omap2/3 platforms only.
115 $ref: /schemas/types.yaml#/definitions/string
116 deprecated: true
117
118 ti,no-idle-on-init:
119 description:
120 Prevent idling the module at init. This is for legacy omap2/3
121 platforms only.
122 type: boolean
123 deprecated: true
124
125patternProperties:
126 "@[0-7],[a-f0-9]+$":
127 type: object
128 description: |
129 The child device node represents the device connected to the GPMC
130 bus. The device can be a NAND chip, SRAM device, NOR device
131 or an ASIC.
132 $ref: ti,gpmc-child.yaml
133 additionalProperties: true
134
135required:
136 - compatible
137 - reg
138 - gpmc,num-cs
139 - gpmc,num-waitpins
140 - "#address-cells"
141 - "#size-cells"
142
143allOf:
144 - if:
145 properties:
146 compatible:
147 contains:
148 const: ti,am64-gpmc
149 then:
150 required:
151 - reg-names
152 - power-domains
153
154additionalProperties: false
155
156examples:
157 - |
158 #include <dt-bindings/interrupt-controller/arm-gic.h>
159 #include <dt-bindings/gpio/gpio.h>
160
161 gpmc: memory-controller@50000000 {
162 compatible = "ti,am3352-gpmc";
163 reg = <0x50000000 0x2000>;
164 interrupts = <100>;
165 clocks = <&l3s_clkctrl>;
166 clock-names = "fck";
167 dmas = <&edma 52 0>;
168 dma-names = "rxtx";
169 gpmc,num-cs = <8>;
170 gpmc,num-waitpins = <2>;
171 #address-cells = <2>;
172 #size-cells = <1>;
173 ranges = <0 0 0x08000000 0x10000000>; /* CS0 @addr 0x8000000, size 0x10000000 */
174 interrupt-controller;
175 #interrupt-cells = <2>;
176 gpio-controller;
177 #gpio-cells = <2>;
178
179 nand@0,0 {
180 compatible = "ti,omap2-nand";
181 reg = <0 0 4>;
182 interrupt-parent = <&gpmc>;
183 interrupts = <0 IRQ_TYPE_NONE>, /* fifoevent */
184 <1 IRQ_TYPE_NONE>; /* termcount */
185 ti,nand-xfer-type = "prefetch-dma";
186 ti,nand-ecc-opt = "bch16";
187 ti,elm-id = <&elm>;
188 rb-gpios = <&gpmc 0 GPIO_ACTIVE_HIGH>; /* gpmc_wait0 pin */
189 };
190 };