ath79: add support for D-Link DIR-859 A3
[openwrt/staging/ldir.git] / target / linux / ath79 / dts / qca9563_dlink_dir-8x9-a1.dtsi
1 // SPDX-License-Identifier: GPL-2.0-or-later OR MIT
2
3 #include "qca956x.dtsi"
4
5 #include <dt-bindings/gpio/gpio.h>
6 #include <dt-bindings/input/input.h>
7
8 / {
9 keys {
10 compatible = "gpio-keys";
11
12 wps {
13 label = "wps";
14 linux,code = <KEY_WPS_BUTTON>;
15 gpios = <&gpio 1 GPIO_ACTIVE_LOW>;
16 debounce-interval = <60>;
17 };
18
19 reset {
20 label = "reset";
21 linux,code = <KEY_RESTART>;
22 gpios = <&gpio 2 GPIO_ACTIVE_LOW>;
23 debounce-interval = <60>;
24 };
25 };
26 };
27
28 &pcie {
29 status = "okay";
30
31 ath10k: wifi@0,0 {
32 compatible = "qcom,ath10k";
33 reg = <0x0000 0 0 0 0>;
34
35 nvmem-cells = <&calibration_ath10k>, <&macaddr_devdata_94>;
36 nvmem-cell-names = "calibration", "mac-address-ascii";
37 };
38 };
39
40 &spi {
41 status = "okay";
42
43 flash@0 {
44 compatible = "jedec,spi-nor";
45 reg = <0>;
46 spi-max-frequency = <25000000>;
47
48 partitions {
49 compatible = "fixed-partitions";
50 #address-cells = <1>;
51 #size-cells = <1>;
52
53 partition@0 {
54 label = "bootloader";
55 reg = <0x000000 0x040000>;
56 read-only;
57 };
58
59 bdcfg: partition@40000 {
60 compatible = "u-boot,env";
61 label = "bdcfg";
62 reg = <0x040000 0x010000>;
63 };
64
65 partition@50000 {
66 label = "devdata";
67 reg = <0x050000 0x010000>;
68 read-only;
69
70 compatible = "nvmem-cells";
71 #address-cells = <1>;
72 #size-cells = <1>;
73
74 macaddr_devdata_94: macaddr@94 {
75 reg = <0x94 0x11>;
76 };
77
78 macaddr_devdata_b0: macaddr@b0 {
79 reg = <0xb0 0x11>;
80 };
81 };
82
83 partition@60000 {
84 label = "devconf";
85 reg = <0x060000 0x010000>;
86 read-only;
87 };
88
89 partition@70000 {
90 compatible = "seama";
91 label = "firmware";
92 reg = <0x070000 0xf80000>;
93 };
94
95 partition@ff0000 {
96 label = "art";
97 reg = <0xff0000 0x010000>;
98 read-only;
99
100 compatible = "nvmem-cells";
101 #address-cells = <1>;
102 #size-cells = <1>;
103
104 calibration_ath9k: calibration@1000 {
105 reg = <0x1000 0x440>;
106 };
107
108 calibration_ath10k: calibration@5000 {
109 reg = <0x5000 0x844>;
110 };
111 };
112 };
113 };
114 };
115
116 &mdio0 {
117 status = "okay";
118
119 phy0: ethernet-phy@0 {
120 reg = <0>;
121 phy-mode = "sgmii";
122 qca,mib-poll-interval = <500>;
123
124 reset-gpios = <&gpio 11 GPIO_ACTIVE_LOW>;
125
126 qca,ar8327-initvals = <
127 0x04 0x00080080 /* PORT0 PAD MODE CTRL */
128 0x10 0x81000080 /* POWER_ON_STRAP */
129 0x50 0xcc35cc35 /* LED_CTRL0 */
130 0x54 0xcb37cb37 /* LED_CTRL1 */
131 0x58 0x00000000 /* LED_CTRL2 */
132 0x5c 0x00f3cf00 /* LED_CTRL3 */
133 0x7c 0x0000007e /* PORT0_STATUS */
134 >;
135 };
136 };
137
138 &eth0 {
139 status = "okay";
140
141 pll-data = <0x03000101 0x00000101 0x00001919>;
142
143 phy-mode = "sgmii";
144 phy-handle = <&phy0>;
145 };
146
147 &wmac {
148 status = "okay";
149
150 nvmem-cells = <&calibration_ath9k>, <&macaddr_devdata_b0>;
151 nvmem-cell-names = "calibration", "mac-address-ascii";
152 };