-
Notifications
You must be signed in to change notification settings - Fork 833
/
zynqmp-zcu102-rev10-adrv9008-1.dts
181 lines (154 loc) · 4.43 KB
/
zynqmp-zcu102-rev10-adrv9008-1.dts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
// SPDX-License-Identifier: GPL-2.0
/*
* Analog Devices ADRV9008-1
* https://wiki.analog.com/resources/eval/user-guides/adrv9009
* https://wiki.analog.com/resources/tools-software/linux-drivers/iio-transceiver/adrv9009
* https://wiki.analog.com/resources/tools-software/linux-software/adrv9009_advanced_plugin
*
* hdl_project: <adrv9009/zcu102>
* board_revision: <>
*
* Copyright (C) 2019 Analog Devices Inc.
*/
#include "zynqmp-zcu102-rev1.0.dts"
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/jesd204/adxcvr.h>
&i2c1 {
i2c-mux@75 {
i2c@1 { /* HPC1 */
#address-cells = <1>;
#size-cells = <0>;
reg = <1>;
ad7291@2f {
compatible = "adi,ad7291";
reg = <0x2f>;
};
eeprom@50 {
compatible = "at24,24c02";
reg = <0x50>;
};
};
};
};
/ {
fpga_axi: fpga-axi@0 {
interrupt-parent = <&gic>;
compatible = "simple-bus";
#address-cells = <0x1>;
#size-cells = <0x1>;
ranges = <0 0 0 0xffffffff>;
rx_dma: dma@9c400000 {
compatible = "adi,axi-dmac-1.00.a";
reg = <0x9c400000 0x10000>;
#dma-cells = <1>;
#clock-cells = <0>;
interrupts = <0 109 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&zynqmp_clk 73>;
adi,channels {
#size-cells = <0>;
#address-cells = <1>;
dma-channel@0 {
reg = <0>;
adi,source-bus-width = <64>;
adi,source-bus-type = <2>;
adi,destination-bus-width = <64>;
adi,destination-bus-type = <0>;
};
};
};
axi_adrv9009_core_rx: axi-adrv9009-rx-hpc@84a00000 {
compatible = "adi,axi-adrv9009-rx-1.0";
reg = <0x84a00000 0x2000>;
dmas = <&rx_dma 0>;
dma-names = "rx";
spibus-connected = <&trx0_adrv9009>;
adi,axi-decimation-core-available;
decimation-gpios = <&gpio 139 GPIO_ACTIVE_HIGH>;
};
axi_adrv9009_rx_jesd: axi-jesd204-rx@84aa0000 {
compatible = "adi,axi-jesd204-rx-1.0";
reg = <0x84aa0000 0x1000>;
interrupts = <0 106 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&zynqmp_clk 71>, <&axi_rx_clkgen>, <&axi_adrv9009_adxcvr_rx 0>;
clock-names = "s_axi_aclk", "device_clk", "lane_clk";
#clock-cells = <0>;
clock-output-names = "jesd_rx_lane_clk";
adi,octets-per-frame = <4>;
adi,frames-per-multiframe = <32>;
};
axi_rx_clkgen: axi-clkgen@83c10000 {
compatible = "adi,axi-clkgen-2.00.a";
reg = <0x83c10000 0x10000>;
#clock-cells = <0>;
clocks = <&zynqmp_clk 71>, <&clk0_ad9528 1>;
clock-names = "s_axi_aclk", "clkin1";
clock-output-names = "axi_rx_clkgen";
};
axi_adrv9009_adxcvr_rx: axi-adxcvr-rx@84a60000 {
#address-cells = <1>;
#size-cells = <0>;
compatible = "adi,axi-adxcvr-1.0";
reg = <0x84a60000 0x1000>;
clocks = <&clk0_ad9528 1>, <&axi_rx_clkgen 0>;
clock-names = "conv", "div40";
#clock-cells = <1>;
clock-output-names = "rx_gt_clk", "rx_out_clk";
adi,sys-clk-select = <XCVR_CPLL>;
adi,out-clk-select = <XCVR_REFCLK>;
adi,use-lpm-enable;
};
axi_sysid_0: axi-sysid-0@85000000 {
compatible = "adi,axi-sysid-1.00.a";
reg = <0x85000000 0x10000>;
};
};
};
&spi0 {
status = "okay";
};
#define fmc_spi spi0
#include "adi-adrv9009.dtsi"
// adrv9009_dac_fifo_bypass_s 60
// ad9528_reset_b, // 59
// ad9528_sysref_req, // 58
// adrv9009_tx1_enable, // 57
// adrv9009_tx2_enable, // 56
// adrv9009_rx1_enable, // 55
// adrv9009_rx2_enable, // 54
// adrv9009_test, // 53
// adrv9009_reset_b, // 52
// adrv9009_gpint, // 51
// adrv9009_gpio_00, // 50
// adrv9009_gpio_01, // 49
// adrv9009_gpio_02, // 48
// adrv9009_gpio_03, // 47
// adrv9009_gpio_04, // 46
// adrv9009_gpio_05, // 45
// adrv9009_gpio_06, // 44
// adrv9009_gpio_07, // 43
// adrv9009_gpio_15, // 42
// adrv9009_gpio_08, // 41
// adrv9009_gpio_09, // 40
// adrv9009_gpio_10, // 39
// adrv9009_gpio_11, // 38
// adrv9009_gpio_12, // 37
// adrv9009_gpio_14, // 36
// adrv9009_gpio_13, // 35
// adrv9009_gpio_17, // 34
// adrv9009_gpio_16, // 33
// adrv9009_gpio_18})); // 32 + 78
&trx0_adrv9009 {
compatible = "adrv9008-1";
clocks = <&axi_adrv9009_rx_jesd>, <&clk0_ad9528 13>,
<&clk0_ad9528 1>, <&clk0_ad9528 12>, <&clk0_ad9528 3>;
clock-names = "jesd_rx_clk", "dev_clk", "fmc_clk", "sysref_dev_clk",
"sysref_fmc_clk";
reset-gpios = <&gpio 130 0>;
test-gpios = <&gpio 131 0>;
sysref-req-gpios = <&gpio 136 0>;
rx2-enable-gpios = <&gpio 132 0>;
rx1-enable-gpios = <&gpio 133 0>;
};
&clk0_ad9528 {
reset-gpios = <&gpio 137 0>;
};