~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/arm64/boot/dts/amlogic/meson-a1.dtsi

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
  2 /*
  3  * Copyright (c) 2019 Amlogic, Inc. All rights reserved.
  4  */
  5 
  6 #include <dt-bindings/clock/amlogic,a1-pll-clkc.h>
  7 #include <dt-bindings/clock/amlogic,a1-peripherals-clkc.h>
  8 #include <dt-bindings/gpio/meson-a1-gpio.h>
  9 #include <dt-bindings/interrupt-controller/arm-gic.h>
 10 #include <dt-bindings/interrupt-controller/irq.h>
 11 #include <dt-bindings/power/meson-a1-power.h>
 12 #include <dt-bindings/reset/amlogic,meson-a1-reset.h>
 13 
 14 / {
 15         compatible = "amlogic,a1";
 16 
 17         interrupt-parent = <&gic>;
 18         #address-cells = <2>;
 19         #size-cells = <2>;
 20 
 21         cpus {
 22                 #address-cells = <2>;
 23                 #size-cells = <0>;
 24 
 25                 cpu0: cpu@0 {
 26                         device_type = "cpu";
 27                         compatible = "arm,cortex-a35";
 28                         reg = <0x0 0x0>;
 29                         enable-method = "psci";
 30                         next-level-cache = <&l2>;
 31                         #cooling-cells = <2>;
 32                 };
 33 
 34                 cpu1: cpu@1 {
 35                         device_type = "cpu";
 36                         compatible = "arm,cortex-a35";
 37                         reg = <0x0 0x1>;
 38                         enable-method = "psci";
 39                         next-level-cache = <&l2>;
 40                         #cooling-cells = <2>;
 41                 };
 42 
 43                 l2: l2-cache0 {
 44                         compatible = "cache";
 45                         cache-level = <2>;
 46                         cache-unified;
 47                 };
 48         };
 49 
 50         efuse: efuse {
 51                 compatible = "amlogic,meson-gxbb-efuse";
 52                 clocks = <&clkc_periphs CLKID_OTP>;
 53                 #address-cells = <1>;
 54                 #size-cells = <1>;
 55                 secure-monitor = <&sm>;
 56                 power-domains = <&pwrc PWRC_OTP_ID>;
 57         };
 58 
 59         psci {
 60                 compatible = "arm,psci-1.0";
 61                 method = "smc";
 62         };
 63 
 64         reserved-memory {
 65                 #address-cells = <2>;
 66                 #size-cells = <2>;
 67                 ranges;
 68 
 69                 linux,cma {
 70                         compatible = "shared-dma-pool";
 71                         reusable;
 72                         size = <0x0 0x800000>;
 73                         alignment = <0x0 0x400000>;
 74                         linux,cma-default;
 75                 };
 76         };
 77 
 78         sm: secure-monitor {
 79                 compatible = "amlogic,meson-gxbb-sm";
 80 
 81                 pwrc: power-controller {
 82                         compatible = "amlogic,meson-a1-pwrc";
 83                         #power-domain-cells = <1>;
 84                 };
 85         };
 86 
 87         soc {
 88                 compatible = "simple-bus";
 89                 #address-cells = <2>;
 90                 #size-cells = <2>;
 91                 ranges;
 92 
 93                 spifc: spi@fd000400 {
 94                         compatible = "amlogic,a1-spifc";
 95                         reg = <0x0 0xfd000400 0x0 0x290>;
 96                         clocks = <&clkc_periphs CLKID_SPIFC>;
 97                         #address-cells = <1>;
 98                         #size-cells = <0>;
 99                         power-domains = <&pwrc PWRC_SPIFC_ID>;
100                         status = "disabled";
101                 };
102 
103                 apb: bus@fe000000 {
104                         compatible = "simple-bus";
105                         reg = <0x0 0xfe000000 0x0 0x1000000>;
106                         #address-cells = <2>;
107                         #size-cells = <2>;
108                         ranges = <0x0 0x0 0x0 0xfe000000 0x0 0x1000000>;
109 
110                         reset: reset-controller@0 {
111                                 compatible = "amlogic,meson-a1-reset";
112                                 reg = <0x0 0x0 0x0 0x8c>;
113                                 #reset-cells = <1>;
114                         };
115 
116                         periphs_pinctrl: pinctrl@400 {
117                                 compatible = "amlogic,meson-a1-periphs-pinctrl";
118                                 #address-cells = <2>;
119                                 #size-cells = <2>;
120                                 ranges;
121 
122                                 gpio: bank@400 {
123                                         reg = <0x0 0x0400 0x0 0x003c>,
124                                               <0x0 0x0480 0x0 0x0118>;
125                                         reg-names = "mux", "gpio";
126                                         gpio-controller;
127                                         #gpio-cells = <2>;
128                                         gpio-ranges = <&periphs_pinctrl 0 0 62>;
129                                 };
130 
131                                 i2c0_f11_pins: i2c0-f11 {
132                                         mux {
133                                                 groups = "i2c0_sck_f11",
134                                                          "i2c0_sda_f12";
135                                                 function = "i2c0";
136                                                 bias-pull-up;
137                                                 drive-strength-microamp = <3000>;
138                                         };
139                                 };
140 
141                                 i2c0_f9_pins: i2c0-f9 {
142                                         mux {
143                                                 groups = "i2c0_sck_f9",
144                                                          "i2c0_sda_f10";
145                                                 function = "i2c0";
146                                                 bias-pull-up;
147                                                 drive-strength-microamp = <3000>;
148                                         };
149                                 };
150 
151                                 i2c1_x_pins: i2c1-x {
152                                         mux {
153                                                 groups = "i2c1_sck_x",
154                                                          "i2c1_sda_x";
155                                                 function = "i2c1";
156                                                 bias-pull-up;
157                                                 drive-strength-microamp = <3000>;
158                                         };
159                                 };
160 
161                                 i2c1_a_pins: i2c1-a {
162                                         mux {
163                                                 groups = "i2c1_sck_a",
164                                                          "i2c1_sda_a";
165                                                 function = "i2c1";
166                                                 bias-pull-up;
167                                                 drive-strength-microamp = <3000>;
168                                         };
169                                 };
170 
171                                 i2c2_x0_pins: i2c2-x0 {
172                                         mux {
173                                                 groups = "i2c2_sck_x0",
174                                                          "i2c2_sda_x1";
175                                                 function = "i2c2";
176                                                 bias-pull-up;
177                                                 drive-strength-microamp = <3000>;
178                                         };
179                                 };
180 
181                                 i2c2_x15_pins: i2c2-x15 {
182                                         mux {
183                                                 groups = "i2c2_sck_x15",
184                                                          "i2c2_sda_x16";
185                                                 function = "i2c2";
186                                                 bias-pull-up;
187                                                 drive-strength-microamp = <3000>;
188                                         };
189                                 };
190 
191                                 i2c2_a4_pins: i2c2-a4 {
192                                         mux {
193                                                 groups = "i2c2_sck_a4",
194                                                          "i2c2_sda_a5";
195                                                 function = "i2c2";
196                                                 bias-pull-up;
197                                                 drive-strength-microamp = <3000>;
198                                         };
199                                 };
200 
201                                 i2c2_a8_pins: i2c2-a8 {
202                                         mux {
203                                                 groups = "i2c2_sck_a8",
204                                                          "i2c2_sda_a9";
205                                                 function = "i2c2";
206                                                 bias-pull-up;
207                                                 drive-strength-microamp = <3000>;
208                                         };
209                                 };
210 
211                                 i2c3_x_pins: i2c3-x {
212                                         mux {
213                                                 groups = "i2c3_sck_x",
214                                                          "i2c3_sda_x";
215                                                 function = "i2c3";
216                                                 bias-pull-up;
217                                                 drive-strength-microamp = <3000>;
218                                         };
219                                 };
220 
221                                 i2c3_f_pins: i2c3-f {
222                                         mux {
223                                                 groups = "i2c3_sck_f",
224                                                          "i2c3_sda_f";
225                                                 function = "i2c3";
226                                                 bias-pull-up;
227                                                 drive-strength-microamp = <3000>;
228                                         };
229                                 };
230 
231                                 uart_a_pins: uart-a {
232                                         mux {
233                                                 groups = "uart_a_tx",
234                                                          "uart_a_rx";
235                                                 function = "uart_a";
236                                         };
237                                 };
238 
239                                 uart_a_cts_rts_pins: uart-a-cts-rts {
240                                         mux {
241                                                 groups = "uart_a_cts",
242                                                          "uart_a_rts";
243                                                 function = "uart_a";
244                                                 bias-pull-down;
245                                         };
246                                 };
247 
248                                 sdio_pins: sdio {
249                                         mux0 {
250                                                 groups = "sdcard_d0_x",
251                                                          "sdcard_d1_x",
252                                                          "sdcard_d2_x",
253                                                          "sdcard_d3_x",
254                                                          "sdcard_cmd_x";
255                                                 function = "sdcard";
256                                                 bias-pull-up;
257                                         };
258 
259                                         mux1 {
260                                                 groups = "sdcard_clk_x";
261                                                 function = "sdcard";
262                                                 bias-disable;
263                                         };
264                                 };
265 
266                                 sdio_clk_gate_pins: sdio-clk-gate {
267                                         mux {
268                                                 groups = "sdcard_clk_x";
269                                                 function = "sdcard";
270                                                 bias-pull-down;
271                                         };
272                                 };
273 
274                                 spifc_pins: spifc {
275                                         mux {
276                                                 groups = "spif_mo",
277                                                          "spif_mi",
278                                                          "spif_clk",
279                                                          "spif_cs",
280                                                          "spif_hold_n",
281                                                          "spif_wp_n";
282                                                 function = "spif";
283                                         };
284                                 };
285                         };
286 
287                         gpio_intc: interrupt-controller@440 {
288                                 compatible = "amlogic,meson-a1-gpio-intc",
289                                              "amlogic,meson-gpio-intc";
290                                 reg = <0x0 0x0440 0x0 0x14>;
291                                 interrupt-controller;
292                                 #interrupt-cells = <2>;
293                                 amlogic,channel-interrupts =
294                                         <49 50 51 52 53 54 55 56>;
295                         };
296 
297                         clkc_periphs: clock-controller@800 {
298                                 compatible = "amlogic,a1-peripherals-clkc";
299                                 reg = <0 0x800 0 0x104>;
300                                 #clock-cells = <1>;
301                                 clocks = <&clkc_pll CLKID_FCLK_DIV2>,
302                                          <&clkc_pll CLKID_FCLK_DIV3>,
303                                          <&clkc_pll CLKID_FCLK_DIV5>,
304                                          <&clkc_pll CLKID_FCLK_DIV7>,
305                                          <&clkc_pll CLKID_HIFI_PLL>,
306                                          <&xtal>;
307                                 clock-names = "fclk_div2", "fclk_div3",
308                                               "fclk_div5", "fclk_div7",
309                                               "hifi_pll", "xtal";
310                         };
311 
312                         i2c0: i2c@1400 {
313                                 compatible = "amlogic,meson-axg-i2c";
314                                 status = "disabled";
315                                 reg = <0x0 0x1400 0x0 0x20>;
316                                 interrupts = <GIC_SPI 32 IRQ_TYPE_EDGE_RISING>;
317                                 #address-cells = <1>;
318                                 #size-cells = <0>;
319                                 clocks = <&clkc_periphs CLKID_I2C_M_A>;
320                                 power-domains = <&pwrc PWRC_I2C_ID>;
321                         };
322 
323                         uart_AO: serial@1c00 {
324                                 compatible = "amlogic,meson-a1-uart",
325                                              "amlogic,meson-ao-uart";
326                                 reg = <0x0 0x1c00 0x0 0x18>;
327                                 interrupts = <GIC_SPI 25 IRQ_TYPE_EDGE_RISING>;
328                                 clocks = <&xtal>, <&xtal>, <&xtal>;
329                                 clock-names = "xtal", "pclk", "baud";
330                                 status = "disabled";
331                         };
332 
333                         uart_AO_B: serial@2000 {
334                                 compatible = "amlogic,meson-a1-uart",
335                                              "amlogic,meson-ao-uart";
336                                 reg = <0x0 0x2000 0x0 0x18>;
337                                 interrupts = <GIC_SPI 26 IRQ_TYPE_EDGE_RISING>;
338                                 clocks = <&xtal>, <&xtal>, <&xtal>;
339                                 clock-names = "xtal", "pclk", "baud";
340                                 status = "disabled";
341                         };
342 
343                         saradc: adc@2c00 {
344                                 compatible = "amlogic,meson-g12a-saradc",
345                                         "amlogic,meson-saradc";
346                                 reg = <0x0 0x2c00 0x0 0x48>;
347                                 #io-channel-cells = <1>;
348                                 power-domains = <&pwrc PWRC_I2C_ID>;
349                                 interrupts = <GIC_SPI 35 IRQ_TYPE_EDGE_RISING>;
350                                 clocks = <&xtal>,
351                                         <&clkc_periphs CLKID_SARADC_EN>,
352                                         <&clkc_periphs CLKID_SARADC>,
353                                         <&clkc_periphs CLKID_SARADC_SEL>;
354                                 clock-names = "clkin", "core",
355                                         "adc_clk", "adc_sel";
356                                 status = "disabled";
357                         };
358 
359                         i2c1: i2c@5c00 {
360                                 compatible = "amlogic,meson-axg-i2c";
361                                 status = "disabled";
362                                 reg = <0x0 0x5c00 0x0 0x20>;
363                                 interrupts = <GIC_SPI 68 IRQ_TYPE_EDGE_RISING>;
364                                 #address-cells = <1>;
365                                 #size-cells = <0>;
366                                 clocks = <&clkc_periphs CLKID_I2C_M_B>;
367                                 power-domains = <&pwrc PWRC_I2C_ID>;
368                         };
369 
370                         i2c2: i2c@6800 {
371                                 compatible = "amlogic,meson-axg-i2c";
372                                 status = "disabled";
373                                 reg = <0x0 0x6800 0x0 0x20>;
374                                 interrupts = <GIC_SPI 76 IRQ_TYPE_EDGE_RISING>;
375                                 #address-cells = <1>;
376                                 #size-cells = <0>;
377                                 clocks = <&clkc_periphs CLKID_I2C_M_C>;
378                                 power-domains = <&pwrc PWRC_I2C_ID>;
379                         };
380 
381                         i2c3: i2c@6c00 {
382                                 compatible = "amlogic,meson-axg-i2c";
383                                 status = "disabled";
384                                 reg = <0x0 0x6c00 0x0 0x20>;
385                                 interrupts = <GIC_SPI 78 IRQ_TYPE_EDGE_RISING>;
386                                 #address-cells = <1>;
387                                 #size-cells = <0>;
388                                 clocks = <&clkc_periphs CLKID_I2C_M_D>;
389                                 power-domains = <&pwrc PWRC_I2C_ID>;
390                         };
391 
392                         usb2_phy1: phy@4000 {
393                                 compatible = "amlogic,a1-usb2-phy";
394                                 clocks = <&clkc_periphs CLKID_USB_PHY_IN>;
395                                 clock-names = "xtal";
396                                 reg = <0x0 0x4000 0x0 0x60>;
397                                 resets = <&reset RESET_USBPHY>;
398                                 reset-names = "phy";
399                                 #phy-cells = <0>;
400                                 power-domains = <&pwrc PWRC_USB_ID>;
401                         };
402 
403                         cpu_temp: temperature-sensor@4c00 {
404                                 compatible = "amlogic,a1-cpu-thermal";
405                                 reg = <0x0 0x4c00 0x0 0x50>;
406                                 interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
407                                 clocks = <&clkc_periphs CLKID_TS>;
408                                 assigned-clocks = <&clkc_periphs CLKID_TS>;
409                                 assigned-clock-rates = <500000>;
410                                 #thermal-sensor-cells = <0>;
411                                 amlogic,ao-secure = <&sec_AO>;
412                         };
413 
414                         hwrng: rng@5118 {
415                                 compatible = "amlogic,meson-rng";
416                                 reg = <0x0 0x5118 0x0 0x4>;
417                                 power-domains = <&pwrc PWRC_OTP_ID>;
418                         };
419 
420                         sec_AO: ao-secure@5a20 {
421                                 compatible = "amlogic,meson-gx-ao-secure", "syscon";
422                                 reg = <0x0 0x5a20 0x0 0x140>;
423                                 amlogic,has-chip-id;
424                         };
425 
426                         clkc_pll: pll-clock-controller@7c80 {
427                                 compatible = "amlogic,a1-pll-clkc";
428                                 reg = <0 0x7c80 0 0x18c>;
429                                 #clock-cells = <1>;
430                                 clocks = <&clkc_periphs CLKID_FIXPLL_IN>,
431                                          <&clkc_periphs CLKID_HIFIPLL_IN>;
432                                 clock-names = "fixpll_in", "hifipll_in";
433                         };
434 
435                         sd_emmc: mmc@10000 {
436                                 compatible = "amlogic,meson-axg-mmc";
437                                 reg = <0x0 0x10000 0x0 0x800>;
438                                 interrupts = <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>;
439                                 clocks = <&clkc_periphs CLKID_SD_EMMC_A>,
440                                          <&clkc_periphs CLKID_SD_EMMC>,
441                                          <&clkc_pll CLKID_FCLK_DIV2>;
442                                 clock-names = "core",
443                                               "clkin0",
444                                               "clkin1";
445                                 assigned-clocks = <&clkc_periphs CLKID_SD_EMMC_SEL2>;
446                                 assigned-clock-parents = <&xtal>;
447                                 resets = <&reset RESET_SD_EMMC_A>;
448                                 power-domains = <&pwrc PWRC_SD_EMMC_ID>;
449                                 status = "disabled";
450                         };
451                 };
452 
453                 usb: usb@fe004400 {
454                         status = "disabled";
455                         compatible = "amlogic,meson-a1-usb-ctrl";
456                         reg = <0x0 0xfe004400 0x0 0xa0>;
457                         interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
458                         #address-cells = <2>;
459                         #size-cells = <2>;
460                         ranges;
461 
462                         clocks = <&clkc_periphs CLKID_USB_CTRL>,
463                                  <&clkc_periphs CLKID_USB_BUS>,
464                                  <&clkc_periphs CLKID_USB_CTRL_IN>;
465                         clock-names = "usb_ctrl", "usb_bus", "xtal_usb_ctrl";
466                         assigned-clocks = <&clkc_periphs CLKID_USB_BUS>;
467                         assigned-clock-rates = <64000000>;
468                         resets = <&reset RESET_USBCTRL>;
469 
470                         dr_mode = "otg";
471 
472                         phys = <&usb2_phy1>;
473                         phy-names = "usb2-phy1";
474 
475                         dwc3: usb@ff400000 {
476                                 compatible = "snps,dwc3";
477                                 reg = <0x0 0xff400000 0x0 0x100000>;
478                                 interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
479                                 dr_mode = "host";
480                                 snps,dis_u2_susphy_quirk;
481                                 snps,quirk-frame-length-adjustment = <0x20>;
482                                 snps,parkmode-disable-ss-quirk;
483                         };
484 
485                         dwc2: usb@ff500000 {
486                                 compatible = "amlogic,meson-a1-usb", "snps,dwc2";
487                                 reg = <0x0 0xff500000 0x0 0x40000>;
488                                 interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
489                                 phys = <&usb2_phy1>;
490                                 phy-names = "usb2-phy";
491                                 clocks = <&clkc_periphs CLKID_USB_PHY>;
492                                 clock-names = "otg";
493                                 dr_mode = "peripheral";
494                                 g-rx-fifo-size = <192>;
495                                 g-np-tx-fifo-size = <128>;
496                                 g-tx-fifo-size = <128 128 16 16 16>;
497                         };
498                 };
499 
500                 gic: interrupt-controller@ff901000 {
501                         compatible = "arm,gic-400";
502                         reg = <0x0 0xff901000 0x0 0x1000>,
503                               <0x0 0xff902000 0x0 0x2000>,
504                               <0x0 0xff904000 0x0 0x2000>,
505                               <0x0 0xff906000 0x0 0x2000>;
506                         interrupt-controller;
507                         interrupts = <GIC_PPI 9
508                                 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_HIGH)>;
509                         #interrupt-cells = <3>;
510                         #address-cells = <0>;
511                 };
512         };
513 
514         timer {
515                 compatible = "arm,armv8-timer";
516                 interrupts = <GIC_PPI 13
517                         (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>,
518                              <GIC_PPI 14
519                         (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>,
520                              <GIC_PPI 11
521                         (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>,
522                              <GIC_PPI 10
523                         (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>;
524         };
525 
526         xtal: xtal-clk {
527                 compatible = "fixed-clock";
528                 clock-frequency = <24000000>;
529                 clock-output-names = "xtal";
530                 #clock-cells = <0>;
531         };
532 };

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php