Andrew Davis | 5c12edd | 2023-04-11 13:24:57 -0500 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0-only |
Tom Rini | 85554e5 | 2017-05-16 14:46:38 -0400 | [diff] [blame] | 2 | |
| 3 | &scrm { |
| 4 | main_fapll: main_fapll { |
| 5 | #clock-cells = <1>; |
| 6 | compatible = "ti,dm816-fapll-clock"; |
| 7 | reg = <0x400 0x40>; |
| 8 | clocks = <&sys_clkin_ck &sys_clkin_ck>; |
| 9 | clock-indices = <1>, <2>, <3>, <4>, <5>, |
| 10 | <6>, <7>; |
| 11 | clock-output-names = "main_pll_clk1", |
| 12 | "main_pll_clk2", |
| 13 | "main_pll_clk3", |
| 14 | "main_pll_clk4", |
| 15 | "main_pll_clk5", |
| 16 | "main_pll_clk6", |
| 17 | "main_pll_clk7"; |
| 18 | }; |
| 19 | |
| 20 | ddr_fapll: ddr_fapll { |
| 21 | #clock-cells = <1>; |
| 22 | compatible = "ti,dm816-fapll-clock"; |
| 23 | reg = <0x440 0x30>; |
| 24 | clocks = <&sys_clkin_ck &sys_clkin_ck>; |
| 25 | clock-indices = <1>, <2>, <3>, <4>; |
| 26 | clock-output-names = "ddr_pll_clk1", |
| 27 | "ddr_pll_clk2", |
| 28 | "ddr_pll_clk3", |
| 29 | "ddr_pll_clk4"; |
| 30 | }; |
| 31 | |
| 32 | video_fapll: video_fapll { |
| 33 | #clock-cells = <1>; |
| 34 | compatible = "ti,dm816-fapll-clock"; |
| 35 | reg = <0x470 0x30>; |
| 36 | clocks = <&sys_clkin_ck &sys_clkin_ck>; |
| 37 | clock-indices = <1>, <2>, <3>; |
| 38 | clock-output-names = "video_pll_clk1", |
| 39 | "video_pll_clk2", |
| 40 | "video_pll_clk3"; |
| 41 | }; |
| 42 | |
| 43 | audio_fapll: audio_fapll { |
| 44 | #clock-cells = <1>; |
| 45 | compatible = "ti,dm816-fapll-clock"; |
| 46 | reg = <0x4a0 0x30>; |
| 47 | clocks = <&main_fapll 7>, < &sys_clkin_ck>; |
| 48 | clock-indices = <1>, <2>, <3>, <4>, <5>; |
| 49 | clock-output-names = "audio_pll_clk1", |
| 50 | "audio_pll_clk2", |
| 51 | "audio_pll_clk3", |
| 52 | "audio_pll_clk4", |
| 53 | "audio_pll_clk5"; |
| 54 | }; |
| 55 | }; |
| 56 | |
| 57 | &scrm_clocks { |
| 58 | secure_32k_ck: secure_32k_ck { |
| 59 | #clock-cells = <0>; |
| 60 | compatible = "fixed-clock"; |
| 61 | clock-frequency = <32768>; |
| 62 | }; |
| 63 | |
| 64 | sys_32k_ck: sys_32k_ck { |
| 65 | #clock-cells = <0>; |
| 66 | compatible = "fixed-clock"; |
| 67 | clock-frequency = <32768>; |
| 68 | }; |
| 69 | |
| 70 | tclkin_ck: tclkin_ck { |
| 71 | #clock-cells = <0>; |
| 72 | compatible = "fixed-clock"; |
| 73 | clock-frequency = <32768>; |
| 74 | }; |
| 75 | |
| 76 | sys_clkin_ck: sys_clkin_ck { |
| 77 | #clock-cells = <0>; |
| 78 | compatible = "fixed-clock"; |
| 79 | clock-frequency = <27000000>; |
| 80 | }; |
| 81 | }; |
| 82 | |
| 83 | /* 0x48180000 */ |
| 84 | &prcm_clocks { |
| 85 | clkout_pre_ck: clkout_pre_ck@100 { |
| 86 | #clock-cells = <0>; |
| 87 | compatible = "ti,mux-clock"; |
| 88 | clocks = <&main_fapll 5 &ddr_fapll 1 &video_fapll 1 |
| 89 | &audio_fapll 1>; |
| 90 | reg = <0x100>; |
| 91 | }; |
| 92 | |
| 93 | clkout_div_ck: clkout_div_ck@100 { |
| 94 | #clock-cells = <0>; |
| 95 | compatible = "ti,divider-clock"; |
| 96 | clocks = <&clkout_pre_ck>; |
| 97 | ti,bit-shift = <3>; |
| 98 | ti,max-div = <8>; |
| 99 | reg = <0x100>; |
| 100 | }; |
| 101 | |
| 102 | clkout_ck: clkout_ck@100 { |
| 103 | #clock-cells = <0>; |
| 104 | compatible = "ti,gate-clock"; |
| 105 | clocks = <&clkout_div_ck>; |
| 106 | ti,bit-shift = <7>; |
| 107 | reg = <0x100>; |
| 108 | }; |
| 109 | |
| 110 | /* CM_DPLL clocks p1795 */ |
| 111 | sysclk1_ck: sysclk1_ck@300 { |
| 112 | #clock-cells = <0>; |
| 113 | compatible = "ti,divider-clock"; |
| 114 | clocks = <&main_fapll 1>; |
| 115 | ti,max-div = <7>; |
| 116 | reg = <0x0300>; |
| 117 | }; |
| 118 | |
| 119 | sysclk2_ck: sysclk2_ck@304 { |
| 120 | #clock-cells = <0>; |
| 121 | compatible = "ti,divider-clock"; |
| 122 | clocks = <&main_fapll 2>; |
| 123 | ti,max-div = <7>; |
| 124 | reg = <0x0304>; |
| 125 | }; |
| 126 | |
| 127 | sysclk3_ck: sysclk3_ck@308 { |
| 128 | #clock-cells = <0>; |
| 129 | compatible = "ti,divider-clock"; |
| 130 | clocks = <&main_fapll 3>; |
| 131 | ti,max-div = <7>; |
| 132 | reg = <0x0308>; |
| 133 | }; |
| 134 | |
| 135 | sysclk4_ck: sysclk4_ck@30c { |
| 136 | #clock-cells = <0>; |
| 137 | compatible = "ti,divider-clock"; |
| 138 | clocks = <&main_fapll 4>; |
| 139 | ti,max-div = <1>; |
| 140 | reg = <0x030c>; |
| 141 | }; |
| 142 | |
| 143 | sysclk5_ck: sysclk5_ck@310 { |
| 144 | #clock-cells = <0>; |
| 145 | compatible = "ti,divider-clock"; |
| 146 | clocks = <&sysclk4_ck>; |
| 147 | ti,max-div = <1>; |
| 148 | reg = <0x0310>; |
| 149 | }; |
| 150 | |
| 151 | sysclk6_ck: sysclk6_ck@314 { |
| 152 | #clock-cells = <0>; |
| 153 | compatible = "ti,divider-clock"; |
| 154 | clocks = <&main_fapll 4>; |
| 155 | ti,dividers = <2>, <4>; |
| 156 | reg = <0x0314>; |
| 157 | }; |
| 158 | |
| 159 | sysclk10_ck: sysclk10_ck@324 { |
| 160 | #clock-cells = <0>; |
| 161 | compatible = "ti,divider-clock"; |
| 162 | clocks = <&ddr_fapll 2>; |
| 163 | ti,max-div = <7>; |
| 164 | reg = <0x0324>; |
| 165 | }; |
| 166 | |
| 167 | sysclk24_ck: sysclk24_ck@3b4 { |
| 168 | #clock-cells = <0>; |
| 169 | compatible = "ti,divider-clock"; |
| 170 | clocks = <&main_fapll 5>; |
| 171 | ti,max-div = <7>; |
| 172 | reg = <0x03b4>; |
| 173 | }; |
| 174 | |
| 175 | mpu_ck: mpu_ck@15dc { |
| 176 | #clock-cells = <0>; |
| 177 | compatible = "ti,gate-clock"; |
| 178 | clocks = <&sysclk2_ck>; |
| 179 | ti,bit-shift = <1>; |
| 180 | reg = <0x15dc>; |
| 181 | }; |
| 182 | |
| 183 | audio_pll_a_ck: audio_pll_a_ck@35c { |
| 184 | #clock-cells = <0>; |
| 185 | compatible = "ti,divider-clock"; |
| 186 | clocks = <&audio_fapll 1>; |
| 187 | ti,max-div = <7>; |
| 188 | reg = <0x035c>; |
| 189 | }; |
| 190 | |
| 191 | sysclk18_ck: sysclk18_ck@378 { |
| 192 | #clock-cells = <0>; |
| 193 | compatible = "ti,mux-clock"; |
| 194 | clocks = <&sys_32k_ck>, <&audio_pll_a_ck>; |
| 195 | reg = <0x0378>; |
| 196 | }; |
| 197 | |
| 198 | timer1_fck: timer1_fck@390 { |
| 199 | #clock-cells = <0>; |
| 200 | compatible = "ti,mux-clock"; |
| 201 | clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>; |
| 202 | reg = <0x0390>; |
| 203 | }; |
| 204 | |
| 205 | timer2_fck: timer2_fck@394 { |
| 206 | #clock-cells = <0>; |
| 207 | compatible = "ti,mux-clock"; |
| 208 | clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>; |
| 209 | reg = <0x0394>; |
| 210 | }; |
| 211 | |
| 212 | timer3_fck: timer3_fck@398 { |
| 213 | #clock-cells = <0>; |
| 214 | compatible = "ti,mux-clock"; |
| 215 | clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>; |
| 216 | reg = <0x0398>; |
| 217 | }; |
| 218 | |
| 219 | timer4_fck: timer4_fck@39c { |
| 220 | #clock-cells = <0>; |
| 221 | compatible = "ti,mux-clock"; |
| 222 | clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>; |
| 223 | reg = <0x039c>; |
| 224 | }; |
| 225 | |
| 226 | timer5_fck: timer5_fck@3a0 { |
| 227 | #clock-cells = <0>; |
| 228 | compatible = "ti,mux-clock"; |
| 229 | clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>; |
| 230 | reg = <0x03a0>; |
| 231 | }; |
| 232 | |
| 233 | timer6_fck: timer6_fck@3a4 { |
| 234 | #clock-cells = <0>; |
| 235 | compatible = "ti,mux-clock"; |
| 236 | clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>; |
| 237 | reg = <0x03a4>; |
| 238 | }; |
| 239 | |
| 240 | timer7_fck: timer7_fck@3a8 { |
| 241 | #clock-cells = <0>; |
| 242 | compatible = "ti,mux-clock"; |
| 243 | clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>; |
| 244 | reg = <0x03a8>; |
| 245 | }; |
| 246 | }; |