Merge branch 'bind_unbind' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh...
[GitHub/LineageOS/android_kernel_motorola_exynos9610.git] / arch / arm / boot / dts / keystone-k2l-netcp.dtsi
CommitLineData
9df14694
MK
1/*
2 * Device Tree Source for Keystone 2 Lamarr Netcp driver
3 *
4 * Copyright 2015 Texas Instruments, Inc.
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
9 */
10
11qmss: qmss@2a40000 {
12 compatible = "ti,keystone-navigator-qmss";
13 dma-coherent;
14 #address-cells = <1>;
15 #size-cells = <1>;
16 clocks = <&chipclk13>;
17 ranges;
18 queue-range = <0 0x2000>;
19 linkram0 = <0x100000 0x4000>;
20 linkram1 = <0x70000000 0x10000>; /* 1MB OSR mem */
21
22 qmgrs {
23 #address-cells = <1>;
24 #size-cells = <1>;
25 ranges;
26 qmgr0 {
27 managed-queues = <0 0x2000>;
28 reg = <0x2a40000 0x20000>,
29 <0x2a06000 0x400>,
30 <0x2a02000 0x1000>,
31 <0x2a03000 0x1000>,
32 <0x23a80000 0x20000>,
33 <0x2a80000 0x20000>;
34 reg-names = "peek", "status", "config",
35 "region", "push", "pop";
36 };
37 };
38 queue-pools {
39 qpend {
40 qpend-0 {
41 qrange = <658 8>;
42 interrupts =<0 40 0xf04 0 41 0xf04 0 42 0xf04
43 0 43 0xf04 0 44 0xf04 0 45 0xf04
44 0 46 0xf04 0 47 0xf04>;
45 };
46 qpend-1 {
47 qrange = <528 16>;
48 interrupts = <0 48 0xf04 0 49 0xf04 0 50 0xf04
49 0 51 0xf04 0 52 0xf04 0 53 0xf04
50 0 54 0xf04 0 55 0xf04 0 56 0xf04
51 0 57 0xf04 0 58 0xf04 0 59 0xf04
52 0 60 0xf04 0 61 0xf04 0 62 0xf04
53 0 63 0xf04>;
54 qalloc-by-id;
55 };
56 qpend-2 {
57 qrange = <544 16>;
58 interrupts = <0 64 0xf04 0 65 0xf04 0 66 0xf04
59 0 59 0xf04 0 68 0xf04 0 69 0xf04
60 0 70 0xf04 0 71 0xf04 0 72 0xf04
61 0 73 0xf04 0 74 0xf04 0 75 0xf04
62 0 76 0xf04 0 77 0xf04 0 78 0xf04
63 0 79 0xf04>;
64 };
65 };
66 general-purpose {
67 gp-0 {
68 qrange = <4000 64>;
69 };
70 netcp-tx {
71 qrange = <896 128>;
72 qalloc-by-id;
73 };
74 };
9d45708f
MK
75 accumulator {
76 acc-low-0 {
77 qrange = <480 32>;
78 accumulator = <0 47 16 2 50>;
79 interrupts = <0 226 0xf01>;
80 multi-queue;
81 };
82 };
9df14694 83 };
9d45708f 84
9df14694
MK
85 descriptor-regions {
86 #address-cells = <1>;
87 #size-cells = <1>;
88 ranges;
89 region-12 {
90 id = <12>;
91 region-spec = <8192 128>; /* num_desc desc_size */
92 link-index = <0x4000>;
93 };
94 };
9d45708f
MK
95
96 pdsps {
97 #address-cells = <1>;
98 #size-cells = <1>;
99 ranges;
100 pdsp0@0x2a10000 {
101 reg = <0x2a10000 0x1000 /*iram */
102 0x2a0f000 0x100 /*reg*/
103 0x2a0c000 0x3c8 /*intd */
104 0x2a20000 0x4000>; /*cmd*/
105 id = <0>;
106 };
107 };
108
9df14694
MK
109}; /* qmss */
110
111knav_dmas: knav_dmas@0 {
112 compatible = "ti,keystone-navigator-dma";
113 clocks = <&papllclk>;
114 #address-cells = <1>;
115 #size-cells = <1>;
116 ranges;
117 ti,navigator-cloud-address = <0x23a80000 0x23a90000>;
118
119 dma_gbe: dma_gbe@0 {
120 reg = <0x26186000 0x100>,
121 <0x26187000 0x2a0>,
122 <0x26188000 0xb60>,
123 <0x26186100 0x80>,
124 <0x26189000 0x1000>;
125 reg-names = "global", "txchan", "rxchan",
126 "txsched", "rxflow";
127 };
128};
129
130netcp: netcp@26000000 {
131 reg = <0x2620110 0x8>;
132 reg-names = "efuse";
133 compatible = "ti,netcp-1.0";
134 #address-cells = <1>;
135 #size-cells = <1>;
136
137 /* NetCP address range */
0b239342 138 ranges = <0 0x26000000 0x1000000>;
9df14694 139
791229f1
MK
140 clocks = <&clkpa>, <&clkcpgmac>, <&chipclk12>;
141 clock-names = "pa_clk", "ethss_clk", "cpts";
9df14694
MK
142 dma-coherent;
143
144 ti,navigator-dmas = <&dma_gbe 0>,
145 <&dma_gbe 8>,
146 <&dma_gbe 0>;
147 ti,navigator-dma-names = "netrx0", "netrx1", "nettx";
148
149 netcp-devices {
150 #address-cells = <1>;
151 #size-cells = <1>;
152 ranges;
153 gbe@200000 { /* ETHSS */
154 label = "netcp-gbe";
155 compatible = "ti,netcp-gbe-5";
0b239342 156 reg = <0x200000 0x900>, <0x220000 0x20000>;
9df14694
MK
157 /* enable-ale; */
158 tx-queue = <896>;
159 tx-channel = "nettx";
160
161 interfaces {
162 gbe0: interface-0 {
163 slave-port = <0>;
164 link-interface = <1>;
165 phy-handle = <&ethphy0>;
166 };
167 gbe1: interface-1 {
168 slave-port = <1>;
169 link-interface = <1>;
170 phy-handle = <&ethphy1>;
171 };
172 };
173
174 secondary-slave-ports {
175 port-2 {
176 slave-port = <2>;
177 link-interface = <2>;
178 };
179 port-3 {
180 slave-port = <3>;
181 link-interface = <2>;
182 };
183 };
184 };
185 };
186
187 netcp-interfaces {
188 interface-0 {
189 rx-channel = "netrx0";
190 rx-pool = <1024 12>;
191 tx-pool = <1024 12>;
192 rx-queue-depth = <128 128 0 0>;
193 rx-buffer-size = <1518 4096 0 0>;
194 rx-queue = <528>;
195 tx-completion-queue = <530>;
196 efuse-mac = <1>;
197 netcp-gbe = <&gbe0>;
198
199 };
200 interface-1 {
201 rx-channel = "netrx1";
202 rx-pool = <1024 12>;
203 tx-pool = <1024 12>;
204 rx-queue-depth = <128 128 0 0>;
205 rx-buffer-size = <1518 4096 0 0>;
206 rx-queue = <529>;
207 tx-completion-queue = <531>;
208 efuse-mac = <0>;
209 local-mac-address = [02 18 31 7e 3e 7f];
210 netcp-gbe = <&gbe1>;
211 };
212 };
213};