1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (C) 2019-20 Sean Anderson <seanga2@gmail.com>
6 #include <dt-bindings/clock/k210-sysctl.h>
7 #include <dt-bindings/mfd/k210-sysctl.h>
8 #include <dt-bindings/pinctrl/k210-pinctrl.h>
9 #include <dt-bindings/reset/k210-sysctl.h>
13 * Although the K210 is a 64-bit CPU, the address bus is only 32-bits
14 * wide, and the upper half of all addresses is ignored.
18 compatible = "canaan,kendryte-k210";
46 timebase-frequency = <7800000>;
49 compatible = "canaan,k210", "sifive,rocket0", "riscv";
51 riscv,isa = "rv64imafdgc";
53 i-cache-block-size = <64>;
54 i-cache-size = <0x8000>;
55 d-cache-block-size = <64>;
56 d-cache-size = <0x8000>;
57 clocks = <&sysclk K210_CLK_CPU>;
58 cpu0_intc: interrupt-controller {
59 #interrupt-cells = <1>;
61 compatible = "riscv,cpu-intc";
66 compatible = "canaan,k210", "sifive,rocket0", "riscv";
68 riscv,isa = "rv64imafdgc";
70 i-cache-block-size = <64>;
71 i-cache-size = <0x8000>;
72 d-cache-block-size = <64>;
73 d-cache-size = <0x8000>;
74 clocks = <&sysclk K210_CLK_CPU>;
75 cpu1_intc: interrupt-controller {
76 #interrupt-cells = <1>;
78 compatible = "riscv,cpu-intc";
83 sram: memory@80000000 {
84 device_type = "memory";
85 compatible = "canaan,k210-sram";
86 reg = <0x80000000 0x400000>,
87 <0x80400000 0x200000>,
88 <0x80600000 0x200000>;
89 reg-names = "sram0", "sram1", "aisram";
90 clocks = <&sysclk K210_CLK_SRAM0>,
91 <&sysclk K210_CLK_SRAM1>,
92 <&sysclk K210_CLK_AI>;
93 clock-names = "sram0", "sram1", "aisram";
99 compatible = "fixed-clock";
101 clock-frequency = <26000000>;
107 #address-cells = <1>;
109 compatible = "canaan,k210-soc", "simple-bus";
111 interrupt-parent = <&plic0>;
114 compatible = "canaan,k210-debug", "riscv,debug";
119 reg = <0x1000 0x1000>;
123 clint0: clint@2000000 {
124 #interrupt-cells = <1>;
125 compatible = "canaan,k210-clint", "sifive,clint0", "riscv,clint0";
126 reg = <0x2000000 0xC000>;
127 interrupts-extended = <&cpu0_intc 3>, <&cpu0_intc 7>,
128 <&cpu1_intc 3>, <&cpu1_intc 7>;
129 clocks = <&sysclk K210_CLK_CLINT>;
132 plic0: interrupt-controller@C000000 {
133 #interrupt-cells = <1>;
134 compatible = "canaan,k210-plic", "sifive,plic-1.0.0", "riscv,plic0";
135 reg = <0xC000000 0x4000000>;
136 interrupt-controller;
137 interrupts-extended = <&cpu0_intc 11>, <&cpu0_intc 9>,
138 <&cpu1_intc 11>, <&cpu1_intc 9>;
140 riscv,max-priority = <7>;
143 uarths0: serial@38000000 {
144 compatible = "canaan,k210-uarths", "sifive,uart0";
145 reg = <0x38000000 0x1000>;
147 clocks = <&sysclk K210_CLK_CPU>;
151 gpio0: gpio-controller@38001000 {
152 #interrupt-cells = <2>;
154 compatible = "canaan,k210-gpiohs", "sifive,gpio0";
155 reg = <0x38001000 0x1000>;
156 interrupt-controller;
157 interrupts = <34 35 36 37 38 39 40 41
158 42 43 44 45 46 47 48 49
159 50 51 52 53 54 55 56 57
160 58 59 60 61 62 63 64 65>;
167 compatible = "canaan,k210-kpu";
168 reg = <0x40800000 0xc00000>;
170 clocks = <&sysclk K210_CLK_AI>;
175 compatible = "canaan,k210-fft";
176 reg = <0x42000000 0x400000>;
178 clocks = <&sysclk K210_CLK_FFT>;
179 resets = <&sysrst K210_RST_FFT>;
183 dmac0: dma-controller@50000000 {
184 compatible = "canaan,k210-dmac", "snps,axi-dma-1.01a";
185 reg = <0x50000000 0x1000>;
186 interrupts = <27 28 29 30 31 32>;
187 clocks = <&sysclk K210_CLK_DMA>, <&sysclk K210_CLK_DMA>;
188 clock-names = "core-clk", "cfgr-clk";
189 resets = <&sysrst K210_RST_DMA>;
191 snps,dma-masters = <2>;
192 snps,data-width = <5>;
193 snps,block-size = <0x200000 0x200000 0x200000
194 0x200000 0x200000 0x200000>;
195 snps,axi-max-burst-len = <256>;
200 #address-cells = <1>;
202 compatible = "canaan,k210-apb", "simple-pm-bus";
204 clocks = <&sysclk K210_CLK_APB0>;
206 gpio1: gpio-controller@50200000 {
207 #address-cells = <1>;
209 compatible = "canaan,k210-gpio",
211 reg = <0x50200000 0x80>;
212 clocks = <&sysclk K210_CLK_APB0>,
213 <&sysclk K210_CLK_GPIO>;
214 clock-names = "bus", "db";
215 resets = <&sysrst K210_RST_GPIO>;
220 #interrupt-cells = <2>;
221 compatible = "snps,dw-apb-gpio-port";
223 interrupt-controller;
230 uart1: serial@50210000 {
231 compatible = "canaan,k210-uart",
233 reg = <0x50210000 0x100>;
235 clocks = <&sysclk K210_CLK_UART1>,
236 <&sysclk K210_CLK_APB0>;
237 clock-names = "baudclk", "apb_pclk";
238 resets = <&sysrst K210_RST_UART1>;
248 uart2: serial@50220000 {
249 compatible = "canaan,k210-uart",
251 reg = <0x50220000 0x100>;
253 clocks = <&sysclk K210_CLK_UART2>,
254 <&sysclk K210_CLK_APB0>;
255 clock-names = "baudclk", "apb_pclk";
256 resets = <&sysrst K210_RST_UART2>;
266 uart3: serial@50230000 {
267 compatible = "canaan,k210-uart",
269 reg = <0x50230000 0x100>;
271 clocks = <&sysclk K210_CLK_UART3>,
272 <&sysclk K210_CLK_APB0>;
273 clock-names = "baudclk", "apb_pclk";
274 resets = <&sysrst K210_RST_UART3>;
285 compatible = "canaan,k210-spi",
286 "snps,dw-apb-ssi-4.01",
289 reg = <0x50240000 0x100>;
291 clocks = <&sysclk K210_CLK_SPI2>,
292 <&sysclk K210_CLK_APB0>;
293 clock-names = "ssi_clk", "pclk";
294 resets = <&sysrst K210_RST_SPI2>;
295 spi-max-frequency = <25000000>;
300 compatible = "canaan,k210-i2s",
301 "snps,designware-i2s";
302 reg = <0x50250000 0x200>;
304 clocks = <&sysclk K210_CLK_I2S0>;
305 clock-names = "i2sclk";
306 resets = <&sysrst K210_RST_I2S0>;
310 apu0: sound@520250200 {
311 compatible = "canaan,k210-apu";
312 reg = <0x50250200 0x200>;
317 compatible = "canaan,k210-i2s",
318 "snps,designware-i2s";
319 reg = <0x50260000 0x200>;
321 clocks = <&sysclk K210_CLK_I2S1>;
322 clock-names = "i2sclk";
323 resets = <&sysrst K210_RST_I2S1>;
328 compatible = "canaan,k210-i2s",
329 "snps,designware-i2s";
330 reg = <0x50270000 0x200>;
332 clocks = <&sysclk K210_CLK_I2S2>;
333 clock-names = "i2sclk";
334 resets = <&sysrst K210_RST_I2S2>;
339 compatible = "canaan,k210-i2c",
340 "snps,designware-i2c";
341 reg = <0x50280000 0x100>;
343 clocks = <&sysclk K210_CLK_I2C0>,
344 <&sysclk K210_CLK_APB0>;
345 clock-names = "ref", "pclk";
346 resets = <&sysrst K210_RST_I2C0>;
351 compatible = "canaan,k210-i2c",
352 "snps,designware-i2c";
353 reg = <0x50290000 0x100>;
355 clocks = <&sysclk K210_CLK_I2C1>,
356 <&sysclk K210_CLK_APB0>;
357 clock-names = "ref", "pclk";
358 resets = <&sysrst K210_RST_I2C1>;
363 compatible = "canaan,k210-i2c",
364 "snps,designware-i2c";
365 reg = <0x502A0000 0x100>;
367 clocks = <&sysclk K210_CLK_I2C2>,
368 <&sysclk K210_CLK_APB0>;
369 clock-names = "ref", "pclk";
370 resets = <&sysrst K210_RST_I2C2>;
374 fpioa: pinmux@502B0000 {
375 compatible = "canaan,k210-fpioa";
376 reg = <0x502B0000 0x100>;
377 clocks = <&sysclk K210_CLK_FPIOA>,
378 <&sysclk K210_CLK_APB0>;
379 clock-names = "ref", "pclk";
380 resets = <&sysrst K210_RST_FPIOA>;
381 canaan,k210-sysctl-power = <&sysctl K210_SYSCTL_POWER_SEL>;
382 pinctrl-0 = <&fpioa_jtag>;
383 pinctrl-names = "default";
387 pinmux = <K210_FPIOA(0, K210_PCF_JTAG_TCLK)>,
388 <K210_FPIOA(1, K210_PCF_JTAG_TDI)>,
389 <K210_FPIOA(2, K210_PCF_JTAG_TMS)>,
390 <K210_FPIOA(3, K210_PCF_JTAG_TDO)>;
394 sha256: sha256@502C0000 {
395 compatible = "canaan,k210-sha256";
396 reg = <0x502C0000 0x100>;
397 clocks = <&sysclk K210_CLK_SHA>;
398 resets = <&sysrst K210_RST_SHA>;
402 timer0: timer@502D0000 {
403 compatible = "canaan,k210-timer",
405 reg = <0x502D0000 0x100>;
406 interrupts = <14 15>;
407 clocks = <&sysclk K210_CLK_TIMER0>,
408 <&sysclk K210_CLK_APB0>;
409 clock-names = "timer", "pclk";
410 resets = <&sysrst K210_RST_TIMER0>;
414 timer1: timer@502E0000 {
415 compatible = "canaan,k210-timer",
417 reg = <0x502E0000 0x100>;
418 interrupts = <16 17>;
419 clocks = <&sysclk K210_CLK_TIMER1>,
420 <&sysclk K210_CLK_APB0>;
421 clock-names = "timer", "pclk";
422 resets = <&sysrst K210_RST_TIMER1>;
426 timer2: timer@502F0000 {
427 compatible = "canaan,k210-timer",
429 reg = <0x502F0000 0x100>;
430 interrupts = <18 19>;
431 clocks = <&sysclk K210_CLK_TIMER2>,
432 <&sysclk K210_CLK_APB0>;
433 clock-names = "timer", "pclk";
434 resets = <&sysrst K210_RST_TIMER2>;
440 #address-cells = <1>;
442 compatible = "canaan,k210-apb", "simple-pm-bus";
444 clocks = <&sysclk K210_CLK_APB1>;
446 wdt0: watchdog@50400000 {
447 compatible = "canaan,k210-wdt", "snps,dw-wdt";
448 reg = <0x50400000 0x100>;
450 clocks = <&sysclk K210_CLK_WDT0>,
451 <&sysclk K210_CLK_APB1>;
452 clock-names = "tclk", "pclk";
453 resets = <&sysrst K210_RST_WDT0>;
456 wdt1: watchdog@50410000 {
457 compatible = "canaan,k210-wdt", "snps,dw-wdt";
458 reg = <0x50410000 0x100>;
460 clocks = <&sysclk K210_CLK_WDT1>,
461 <&sysclk K210_CLK_APB1>;
462 clock-names = "tclk", "pclk";
463 resets = <&sysrst K210_RST_WDT1>;
467 otp0: nvmem@50420000 {
468 #address-cells = <1>;
470 compatible = "canaan,k210-otp";
471 reg = <0x50420000 0x100>,
472 <0x88000000 0x20000>;
473 reg-names = "reg", "mem";
474 clocks = <&sysclk K210_CLK_ROM>;
475 resets = <&sysrst K210_RST_ROM>;
481 reg = <0x00000 0xC200>;
485 * config string as described in RISC-V
486 * privileged spec 1.9
489 reg = <0x1C000 0x1000>;
493 * Device tree containing only registers,
494 * interrupts, and cpus
497 reg = <0x1D000 0x2000>;
500 /* CPU/ROM credits */
502 reg = <0x1F000 0x1000>;
506 dvp0: camera@50430000 {
507 compatible = "canaan,k210-dvp";
508 reg = <0x50430000 0x100>;
510 clocks = <&sysclk K210_CLK_DVP>;
511 resets = <&sysrst K210_RST_DVP>;
512 canaan,k210-sysctl = <&sysctl>;
513 canaan,k210-misc-offset = <K210_SYSCTL_MISC>;
517 sysctl: syscon@50440000 {
518 compatible = "canaan,k210-sysctl",
519 "syscon", "simple-mfd";
520 reg = <0x50440000 0x100>;
521 clocks = <&sysclk K210_CLK_APB1>;
522 clock-names = "pclk";
526 sysclk: clock-controller {
528 compatible = "canaan,k210-clk";
530 assigned-clocks = <&sysclk K210_CLK_PLL1>;
531 assigned-clock-rates = <390000000>;
535 sysrst: reset-controller {
536 compatible = "canaan,k210-rst",
540 offset = <K210_SYSCTL_PERI_RESET>;
546 compatible = "syscon-reboot";
548 offset = <K210_SYSCTL_SOFT_RESET>;
555 compatible = "canaan,k210-aes";
556 reg = <0x50450000 0x100>;
557 clocks = <&sysclk K210_CLK_AES>;
558 resets = <&sysrst K210_RST_AES>;
563 compatible = "canaan,k210-rtc";
564 reg = <0x50460000 0x100>;
566 resets = <&sysrst K210_RST_RTC>;
573 #address-cells = <1>;
575 compatible = "canaan,k210-apb", "simple-pm-bus";
577 clocks = <&sysclk K210_CLK_APB2>;
580 #address-cells = <1>;
582 compatible = "canaan,k210-spi",
583 "snps,dw-apb-ssi-4.01",
585 reg = <0x52000000 0x100>;
587 clocks = <&sysclk K210_CLK_SPI0>,
588 <&sysclk K210_CLK_APB2>;
589 clock-names = "ssi_clk", "pclk";
590 resets = <&sysrst K210_RST_SPI0>;
591 spi-max-frequency = <25000000>;
598 #address-cells = <1>;
600 compatible = "canaan,k210-spi",
601 "snps,dw-apb-ssi-4.01",
603 reg = <0x53000000 0x100>;
605 clocks = <&sysclk K210_CLK_SPI1>,
606 <&sysclk K210_CLK_APB2>;
607 clock-names = "ssi_clk", "pclk";
608 resets = <&sysrst K210_RST_SPI1>;
609 spi-max-frequency = <25000000>;
616 #address-cells = <1>;
618 compatible = "canaan,k210-ssi",
619 "snps,dwc-ssi-1.01a";
620 reg = <0x54000000 0x200>;
622 clocks = <&sysclk K210_CLK_SPI3>,
623 <&sysclk K210_CLK_APB2>;
624 clock-names = "ssi_clk", "pclk";
625 resets = <&sysrst K210_RST_SPI3>;
626 /* Could possibly go up to 200 MHz */
627 spi-max-frequency = <100000000>;