Merge tag 'tomoyo-pr-20230903' of git://git.osdn.net/gitroot/tomoyo/tomoyo-test1
[linux-2.6-microblaze.git] / drivers / gpu / drm / i915 / display / intel_cx0_phy.c
1 // SPDX-License-Identifier: MIT
2 /*
3  * Copyright © 2023 Intel Corporation
4  */
5
6 #include <linux/log2.h>
7 #include <linux/math64.h>
8 #include "i915_reg.h"
9 #include "intel_cx0_phy.h"
10 #include "intel_cx0_phy_regs.h"
11 #include "intel_ddi.h"
12 #include "intel_ddi_buf_trans.h"
13 #include "intel_de.h"
14 #include "intel_display_types.h"
15 #include "intel_dp.h"
16 #include "intel_hdmi.h"
17 #include "intel_panel.h"
18 #include "intel_psr.h"
19 #include "intel_tc.h"
20
21 #define MB_WRITE_COMMITTED      true
22 #define MB_WRITE_UNCOMMITTED    false
23
24 #define for_each_cx0_lane_in_mask(__lane_mask, __lane) \
25         for ((__lane) = 0; (__lane) < 2; (__lane)++) \
26                 for_each_if((__lane_mask) & BIT(__lane))
27
28 #define INTEL_CX0_LANE0         BIT(0)
29 #define INTEL_CX0_LANE1         BIT(1)
30 #define INTEL_CX0_BOTH_LANES    (INTEL_CX0_LANE1 | INTEL_CX0_LANE0)
31
32 bool intel_is_c10phy(struct drm_i915_private *i915, enum phy phy)
33 {
34         if (IS_METEORLAKE(i915) && (phy < PHY_C))
35                 return true;
36
37         return false;
38 }
39
40 static int lane_mask_to_lane(u8 lane_mask)
41 {
42         if (WARN_ON((lane_mask & ~INTEL_CX0_BOTH_LANES) ||
43                     hweight8(lane_mask) != 1))
44                 return 0;
45
46         return ilog2(lane_mask);
47 }
48
49 static void
50 assert_dc_off(struct drm_i915_private *i915)
51 {
52         bool enabled;
53
54         enabled = intel_display_power_is_enabled(i915, POWER_DOMAIN_DC_OFF);
55         drm_WARN_ON(&i915->drm, !enabled);
56 }
57
58 /*
59  * Prepare HW for CX0 phy transactions.
60  *
61  * It is required that PSR and DC5/6 are disabled before any CX0 message
62  * bus transaction is executed.
63  */
64 static intel_wakeref_t intel_cx0_phy_transaction_begin(struct intel_encoder *encoder)
65 {
66         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
67         struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
68
69         intel_psr_pause(intel_dp);
70         return intel_display_power_get(i915, POWER_DOMAIN_DC_OFF);
71 }
72
73 static void intel_cx0_phy_transaction_end(struct intel_encoder *encoder, intel_wakeref_t wakeref)
74 {
75         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
76         struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
77
78         intel_psr_resume(intel_dp);
79         intel_display_power_put(i915, POWER_DOMAIN_DC_OFF, wakeref);
80 }
81
82 static void intel_clear_response_ready_flag(struct drm_i915_private *i915,
83                                             enum port port, int lane)
84 {
85         intel_de_rmw(i915, XELPDP_PORT_P2M_MSGBUS_STATUS(port, lane),
86                      0, XELPDP_PORT_P2M_RESPONSE_READY | XELPDP_PORT_P2M_ERROR_SET);
87 }
88
89 static void intel_cx0_bus_reset(struct drm_i915_private *i915, enum port port, int lane)
90 {
91         enum phy phy = intel_port_to_phy(i915, port);
92
93         intel_de_write(i915, XELPDP_PORT_M2P_MSGBUS_CTL(port, lane),
94                        XELPDP_PORT_M2P_TRANSACTION_RESET);
95
96         if (intel_de_wait_for_clear(i915, XELPDP_PORT_M2P_MSGBUS_CTL(port, lane),
97                                     XELPDP_PORT_M2P_TRANSACTION_RESET,
98                                     XELPDP_MSGBUS_TIMEOUT_SLOW)) {
99                 drm_err_once(&i915->drm, "Failed to bring PHY %c to idle.\n", phy_name(phy));
100                 return;
101         }
102
103         intel_clear_response_ready_flag(i915, port, lane);
104 }
105
106 static int intel_cx0_wait_for_ack(struct drm_i915_private *i915, enum port port,
107                                   int command, int lane, u32 *val)
108 {
109         enum phy phy = intel_port_to_phy(i915, port);
110
111         if (__intel_de_wait_for_register(i915,
112                                          XELPDP_PORT_P2M_MSGBUS_STATUS(port, lane),
113                                          XELPDP_PORT_P2M_RESPONSE_READY,
114                                          XELPDP_PORT_P2M_RESPONSE_READY,
115                                          XELPDP_MSGBUS_TIMEOUT_FAST_US,
116                                          XELPDP_MSGBUS_TIMEOUT_SLOW, val)) {
117                 drm_dbg_kms(&i915->drm, "PHY %c Timeout waiting for message ACK. Status: 0x%x\n",
118                             phy_name(phy), *val);
119                 intel_cx0_bus_reset(i915, port, lane);
120                 return -ETIMEDOUT;
121         }
122
123         if (*val & XELPDP_PORT_P2M_ERROR_SET) {
124                 drm_dbg_kms(&i915->drm, "PHY %c Error occurred during %s command. Status: 0x%x\n", phy_name(phy),
125                             command == XELPDP_PORT_P2M_COMMAND_READ_ACK ? "read" : "write", *val);
126                 intel_cx0_bus_reset(i915, port, lane);
127                 return -EINVAL;
128         }
129
130         if (REG_FIELD_GET(XELPDP_PORT_P2M_COMMAND_TYPE_MASK, *val) != command) {
131                 drm_dbg_kms(&i915->drm, "PHY %c Not a %s response. MSGBUS Status: 0x%x.\n", phy_name(phy),
132                             command == XELPDP_PORT_P2M_COMMAND_READ_ACK ? "read" : "write", *val);
133                 intel_cx0_bus_reset(i915, port, lane);
134                 return -EINVAL;
135         }
136
137         return 0;
138 }
139
140 static int __intel_cx0_read_once(struct drm_i915_private *i915, enum port port,
141                                  int lane, u16 addr)
142 {
143         enum phy phy = intel_port_to_phy(i915, port);
144         int ack;
145         u32 val;
146
147         if (intel_de_wait_for_clear(i915, XELPDP_PORT_M2P_MSGBUS_CTL(port, lane),
148                                     XELPDP_PORT_M2P_TRANSACTION_PENDING,
149                                     XELPDP_MSGBUS_TIMEOUT_SLOW)) {
150                 drm_dbg_kms(&i915->drm,
151                             "PHY %c Timeout waiting for previous transaction to complete. Reset the bus and retry.\n", phy_name(phy));
152                 intel_cx0_bus_reset(i915, port, lane);
153                 return -ETIMEDOUT;
154         }
155
156         intel_de_write(i915, XELPDP_PORT_M2P_MSGBUS_CTL(port, lane),
157                        XELPDP_PORT_M2P_TRANSACTION_PENDING |
158                        XELPDP_PORT_M2P_COMMAND_READ |
159                        XELPDP_PORT_M2P_ADDRESS(addr));
160
161         ack = intel_cx0_wait_for_ack(i915, port, XELPDP_PORT_P2M_COMMAND_READ_ACK, lane, &val);
162         if (ack < 0)
163                 return ack;
164
165         intel_clear_response_ready_flag(i915, port, lane);
166
167         return REG_FIELD_GET(XELPDP_PORT_P2M_DATA_MASK, val);
168 }
169
170 static u8 __intel_cx0_read(struct drm_i915_private *i915, enum port port,
171                            int lane, u16 addr)
172 {
173         enum phy phy = intel_port_to_phy(i915, port);
174         int i, status;
175
176         assert_dc_off(i915);
177
178         /* 3 tries is assumed to be enough to read successfully */
179         for (i = 0; i < 3; i++) {
180                 status = __intel_cx0_read_once(i915, port, lane, addr);
181
182                 if (status >= 0)
183                         return status;
184         }
185
186         drm_err_once(&i915->drm, "PHY %c Read %04x failed after %d retries.\n",
187                      phy_name(phy), addr, i);
188
189         return 0;
190 }
191
192 static u8 intel_cx0_read(struct drm_i915_private *i915, enum port port,
193                          u8 lane_mask, u16 addr)
194 {
195         int lane = lane_mask_to_lane(lane_mask);
196
197         return __intel_cx0_read(i915, port, lane, addr);
198 }
199
200 static int __intel_cx0_write_once(struct drm_i915_private *i915, enum port port,
201                                   int lane, u16 addr, u8 data, bool committed)
202 {
203         enum phy phy = intel_port_to_phy(i915, port);
204         int ack;
205         u32 val;
206
207         if (intel_de_wait_for_clear(i915, XELPDP_PORT_M2P_MSGBUS_CTL(port, lane),
208                                     XELPDP_PORT_M2P_TRANSACTION_PENDING,
209                                     XELPDP_MSGBUS_TIMEOUT_SLOW)) {
210                 drm_dbg_kms(&i915->drm,
211                             "PHY %c Timeout waiting for previous transaction to complete. Resetting the bus.\n", phy_name(phy));
212                 intel_cx0_bus_reset(i915, port, lane);
213                 return -ETIMEDOUT;
214         }
215
216         intel_de_write(i915, XELPDP_PORT_M2P_MSGBUS_CTL(port, lane),
217                        XELPDP_PORT_M2P_TRANSACTION_PENDING |
218                        (committed ? XELPDP_PORT_M2P_COMMAND_WRITE_COMMITTED :
219                                     XELPDP_PORT_M2P_COMMAND_WRITE_UNCOMMITTED) |
220                        XELPDP_PORT_M2P_DATA(data) |
221                        XELPDP_PORT_M2P_ADDRESS(addr));
222
223         if (intel_de_wait_for_clear(i915, XELPDP_PORT_M2P_MSGBUS_CTL(port, lane),
224                                     XELPDP_PORT_M2P_TRANSACTION_PENDING,
225                                     XELPDP_MSGBUS_TIMEOUT_SLOW)) {
226                 drm_dbg_kms(&i915->drm,
227                             "PHY %c Timeout waiting for write to complete. Resetting the bus.\n", phy_name(phy));
228                 intel_cx0_bus_reset(i915, port, lane);
229                 return -ETIMEDOUT;
230         }
231
232         if (committed) {
233                 ack = intel_cx0_wait_for_ack(i915, port, XELPDP_PORT_P2M_COMMAND_WRITE_ACK, lane, &val);
234                 if (ack < 0)
235                         return ack;
236         } else if ((intel_de_read(i915, XELPDP_PORT_P2M_MSGBUS_STATUS(port, lane)) &
237                     XELPDP_PORT_P2M_ERROR_SET)) {
238                 drm_dbg_kms(&i915->drm,
239                             "PHY %c Error occurred during write command.\n", phy_name(phy));
240                 intel_cx0_bus_reset(i915, port, lane);
241                 return -EINVAL;
242         }
243
244         intel_clear_response_ready_flag(i915, port, lane);
245
246         return 0;
247 }
248
249 static void __intel_cx0_write(struct drm_i915_private *i915, enum port port,
250                               int lane, u16 addr, u8 data, bool committed)
251 {
252         enum phy phy = intel_port_to_phy(i915, port);
253         int i, status;
254
255         assert_dc_off(i915);
256
257         /* 3 tries is assumed to be enough to write successfully */
258         for (i = 0; i < 3; i++) {
259                 status = __intel_cx0_write_once(i915, port, lane, addr, data, committed);
260
261                 if (status == 0)
262                         return;
263         }
264
265         drm_err_once(&i915->drm,
266                      "PHY %c Write %04x failed after %d retries.\n", phy_name(phy), addr, i);
267 }
268
269 static void intel_cx0_write(struct drm_i915_private *i915, enum port port,
270                             u8 lane_mask, u16 addr, u8 data, bool committed)
271 {
272         int lane;
273
274         for_each_cx0_lane_in_mask(lane_mask, lane)
275                 __intel_cx0_write(i915, port, lane, addr, data, committed);
276 }
277
278 static void intel_c20_sram_write(struct drm_i915_private *i915, enum port port,
279                                  int lane, u16 addr, u16 data)
280 {
281         assert_dc_off(i915);
282
283         intel_cx0_write(i915, port, lane, PHY_C20_WR_ADDRESS_H, addr >> 8, 0);
284         intel_cx0_write(i915, port, lane, PHY_C20_WR_ADDRESS_L, addr & 0xff, 0);
285
286         intel_cx0_write(i915, port, lane, PHY_C20_WR_DATA_H, data >> 8, 0);
287         intel_cx0_write(i915, port, lane, PHY_C20_WR_DATA_L, data & 0xff, 1);
288 }
289
290 static u16 intel_c20_sram_read(struct drm_i915_private *i915, enum port port,
291                                int lane, u16 addr)
292 {
293         u16 val;
294
295         assert_dc_off(i915);
296
297         intel_cx0_write(i915, port, lane, PHY_C20_RD_ADDRESS_H, addr >> 8, 0);
298         intel_cx0_write(i915, port, lane, PHY_C20_RD_ADDRESS_L, addr & 0xff, 1);
299
300         val = intel_cx0_read(i915, port, lane, PHY_C20_RD_DATA_H);
301         val <<= 8;
302         val |= intel_cx0_read(i915, port, lane, PHY_C20_RD_DATA_L);
303
304         return val;
305 }
306
307 static void __intel_cx0_rmw(struct drm_i915_private *i915, enum port port,
308                             int lane, u16 addr, u8 clear, u8 set, bool committed)
309 {
310         u8 old, val;
311
312         old = __intel_cx0_read(i915, port, lane, addr);
313         val = (old & ~clear) | set;
314
315         if (val != old)
316                 __intel_cx0_write(i915, port, lane, addr, val, committed);
317 }
318
319 static void intel_cx0_rmw(struct drm_i915_private *i915, enum port port,
320                           u8 lane_mask, u16 addr, u8 clear, u8 set, bool committed)
321 {
322         u8 lane;
323
324         for_each_cx0_lane_in_mask(lane_mask, lane)
325                 __intel_cx0_rmw(i915, port, lane, addr, clear, set, committed);
326 }
327
328 static u8 intel_c10_get_tx_vboost_lvl(const struct intel_crtc_state *crtc_state)
329 {
330         if (intel_crtc_has_dp_encoder(crtc_state)) {
331                 if (!intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP) &&
332                     (crtc_state->port_clock == 540000 ||
333                      crtc_state->port_clock == 810000))
334                         return 5;
335                 else
336                         return 4;
337         } else {
338                 return 5;
339         }
340 }
341
342 static u8 intel_c10_get_tx_term_ctl(const struct intel_crtc_state *crtc_state)
343 {
344         if (intel_crtc_has_dp_encoder(crtc_state)) {
345                 if (!intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP) &&
346                     (crtc_state->port_clock == 540000 ||
347                      crtc_state->port_clock == 810000))
348                         return 5;
349                 else
350                         return 2;
351         } else {
352                 return 6;
353         }
354 }
355
356 void intel_cx0_phy_set_signal_levels(struct intel_encoder *encoder,
357                                      const struct intel_crtc_state *crtc_state)
358 {
359         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
360         const struct intel_ddi_buf_trans *trans;
361         enum phy phy = intel_port_to_phy(i915, encoder->port);
362         intel_wakeref_t wakeref;
363         int n_entries, ln;
364
365         wakeref = intel_cx0_phy_transaction_begin(encoder);
366
367         trans = encoder->get_buf_trans(encoder, crtc_state, &n_entries);
368         if (drm_WARN_ON_ONCE(&i915->drm, !trans)) {
369                 intel_cx0_phy_transaction_end(encoder, wakeref);
370                 return;
371         }
372
373         if (intel_is_c10phy(i915, phy)) {
374                 intel_cx0_rmw(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C10_VDR_CONTROL(1),
375                               0, C10_VDR_CTRL_MSGBUS_ACCESS, MB_WRITE_COMMITTED);
376                 intel_cx0_rmw(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C10_VDR_CMN(3),
377                               C10_CMN3_TXVBOOST_MASK,
378                               C10_CMN3_TXVBOOST(intel_c10_get_tx_vboost_lvl(crtc_state)),
379                               MB_WRITE_UNCOMMITTED);
380                 intel_cx0_rmw(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C10_VDR_TX(1),
381                               C10_TX1_TERMCTL_MASK,
382                               C10_TX1_TERMCTL(intel_c10_get_tx_term_ctl(crtc_state)),
383                               MB_WRITE_COMMITTED);
384         }
385
386         for (ln = 0; ln < crtc_state->lane_count; ln++) {
387                 int level = intel_ddi_level(encoder, crtc_state, ln);
388                 int lane, tx;
389
390                 lane = ln / 2;
391                 tx = ln % 2;
392
393                 intel_cx0_rmw(i915, encoder->port, BIT(lane), PHY_CX0_VDROVRD_CTL(lane, tx, 0),
394                               C10_PHY_OVRD_LEVEL_MASK,
395                               C10_PHY_OVRD_LEVEL(trans->entries[level].snps.pre_cursor),
396                               MB_WRITE_COMMITTED);
397                 intel_cx0_rmw(i915, encoder->port, BIT(lane), PHY_CX0_VDROVRD_CTL(lane, tx, 1),
398                               C10_PHY_OVRD_LEVEL_MASK,
399                               C10_PHY_OVRD_LEVEL(trans->entries[level].snps.vswing),
400                               MB_WRITE_COMMITTED);
401                 intel_cx0_rmw(i915, encoder->port, BIT(lane), PHY_CX0_VDROVRD_CTL(lane, tx, 2),
402                               C10_PHY_OVRD_LEVEL_MASK,
403                               C10_PHY_OVRD_LEVEL(trans->entries[level].snps.post_cursor),
404                               MB_WRITE_COMMITTED);
405         }
406
407         /* Write Override enables in 0xD71 */
408         intel_cx0_rmw(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C10_VDR_OVRD,
409                       0, PHY_C10_VDR_OVRD_TX1 | PHY_C10_VDR_OVRD_TX2,
410                       MB_WRITE_COMMITTED);
411
412         if (intel_is_c10phy(i915, phy))
413                 intel_cx0_rmw(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C10_VDR_CONTROL(1),
414                               0, C10_VDR_CTRL_UPDATE_CFG, MB_WRITE_COMMITTED);
415
416         intel_cx0_phy_transaction_end(encoder, wakeref);
417 }
418
419 /*
420  * Basic DP link rates with 38.4 MHz reference clock.
421  * Note: The tables below are with SSC. In non-ssc
422  * registers 0xC04 to 0xC08(pll[4] to pll[8]) will be
423  * programmed 0.
424  */
425
426 static const struct intel_c10pll_state mtl_c10_dp_rbr = {
427         .clock = 162000,
428         .tx = 0x10,
429         .cmn = 0x21,
430         .pll[0] = 0xB4,
431         .pll[1] = 0,
432         .pll[2] = 0x30,
433         .pll[3] = 0x1,
434         .pll[4] = 0x26,
435         .pll[5] = 0x0C,
436         .pll[6] = 0x98,
437         .pll[7] = 0x46,
438         .pll[8] = 0x1,
439         .pll[9] = 0x1,
440         .pll[10] = 0,
441         .pll[11] = 0,
442         .pll[12] = 0xC0,
443         .pll[13] = 0,
444         .pll[14] = 0,
445         .pll[15] = 0x2,
446         .pll[16] = 0x84,
447         .pll[17] = 0x4F,
448         .pll[18] = 0xE5,
449         .pll[19] = 0x23,
450 };
451
452 static const struct intel_c10pll_state mtl_c10_edp_r216 = {
453         .clock = 216000,
454         .tx = 0x10,
455         .cmn = 0x21,
456         .pll[0] = 0x4,
457         .pll[1] = 0,
458         .pll[2] = 0xA2,
459         .pll[3] = 0x1,
460         .pll[4] = 0x33,
461         .pll[5] = 0x10,
462         .pll[6] = 0x75,
463         .pll[7] = 0xB3,
464         .pll[8] = 0x1,
465         .pll[9] = 0x1,
466         .pll[10] = 0,
467         .pll[11] = 0,
468         .pll[12] = 0,
469         .pll[13] = 0,
470         .pll[14] = 0,
471         .pll[15] = 0x2,
472         .pll[16] = 0x85,
473         .pll[17] = 0x0F,
474         .pll[18] = 0xE6,
475         .pll[19] = 0x23,
476 };
477
478 static const struct intel_c10pll_state mtl_c10_edp_r243 = {
479         .clock = 243000,
480         .tx = 0x10,
481         .cmn = 0x21,
482         .pll[0] = 0x34,
483         .pll[1] = 0,
484         .pll[2] = 0xDA,
485         .pll[3] = 0x1,
486         .pll[4] = 0x39,
487         .pll[5] = 0x12,
488         .pll[6] = 0xE3,
489         .pll[7] = 0xE9,
490         .pll[8] = 0x1,
491         .pll[9] = 0x1,
492         .pll[10] = 0,
493         .pll[11] = 0,
494         .pll[12] = 0x20,
495         .pll[13] = 0,
496         .pll[14] = 0,
497         .pll[15] = 0x2,
498         .pll[16] = 0x85,
499         .pll[17] = 0x8F,
500         .pll[18] = 0xE6,
501         .pll[19] = 0x23,
502 };
503
504 static const struct intel_c10pll_state mtl_c10_dp_hbr1 = {
505         .clock = 270000,
506         .tx = 0x10,
507         .cmn = 0x21,
508         .pll[0] = 0xF4,
509         .pll[1] = 0,
510         .pll[2] = 0xF8,
511         .pll[3] = 0x0,
512         .pll[4] = 0x20,
513         .pll[5] = 0x0A,
514         .pll[6] = 0x29,
515         .pll[7] = 0x10,
516         .pll[8] = 0x1,   /* Verify */
517         .pll[9] = 0x1,
518         .pll[10] = 0,
519         .pll[11] = 0,
520         .pll[12] = 0xA0,
521         .pll[13] = 0,
522         .pll[14] = 0,
523         .pll[15] = 0x1,
524         .pll[16] = 0x84,
525         .pll[17] = 0x4F,
526         .pll[18] = 0xE5,
527         .pll[19] = 0x23,
528 };
529
530 static const struct intel_c10pll_state mtl_c10_edp_r324 = {
531         .clock = 324000,
532         .tx = 0x10,
533         .cmn = 0x21,
534         .pll[0] = 0xB4,
535         .pll[1] = 0,
536         .pll[2] = 0x30,
537         .pll[3] = 0x1,
538         .pll[4] = 0x26,
539         .pll[5] = 0x0C,
540         .pll[6] = 0x98,
541         .pll[7] = 0x46,
542         .pll[8] = 0x1,
543         .pll[9] = 0x1,
544         .pll[10] = 0,
545         .pll[11] = 0,
546         .pll[12] = 0xC0,
547         .pll[13] = 0,
548         .pll[14] = 0,
549         .pll[15] = 0x1,
550         .pll[16] = 0x85,
551         .pll[17] = 0x4F,
552         .pll[18] = 0xE6,
553         .pll[19] = 0x23,
554 };
555
556 static const struct intel_c10pll_state mtl_c10_edp_r432 = {
557         .clock = 432000,
558         .tx = 0x10,
559         .cmn = 0x21,
560         .pll[0] = 0x4,
561         .pll[1] = 0,
562         .pll[2] = 0xA2,
563         .pll[3] = 0x1,
564         .pll[4] = 0x33,
565         .pll[5] = 0x10,
566         .pll[6] = 0x75,
567         .pll[7] = 0xB3,
568         .pll[8] = 0x1,
569         .pll[9] = 0x1,
570         .pll[10] = 0,
571         .pll[11] = 0,
572         .pll[12] = 0,
573         .pll[13] = 0,
574         .pll[14] = 0,
575         .pll[15] = 0x1,
576         .pll[16] = 0x85,
577         .pll[17] = 0x0F,
578         .pll[18] = 0xE6,
579         .pll[19] = 0x23,
580 };
581
582 static const struct intel_c10pll_state mtl_c10_dp_hbr2 = {
583         .clock = 540000,
584         .tx = 0x10,
585         .cmn = 0x21,
586         .pll[0] = 0xF4,
587         .pll[1] = 0,
588         .pll[2] = 0xF8,
589         .pll[3] = 0,
590         .pll[4] = 0x20,
591         .pll[5] = 0x0A,
592         .pll[6] = 0x29,
593         .pll[7] = 0x10,
594         .pll[8] = 0x1,
595         .pll[9] = 0x1,
596         .pll[10] = 0,
597         .pll[11] = 0,
598         .pll[12] = 0xA0,
599         .pll[13] = 0,
600         .pll[14] = 0,
601         .pll[15] = 0,
602         .pll[16] = 0x84,
603         .pll[17] = 0x4F,
604         .pll[18] = 0xE5,
605         .pll[19] = 0x23,
606 };
607
608 static const struct intel_c10pll_state mtl_c10_edp_r675 = {
609         .clock = 675000,
610         .tx = 0x10,
611         .cmn = 0x21,
612         .pll[0] = 0xB4,
613         .pll[1] = 0,
614         .pll[2] = 0x3E,
615         .pll[3] = 0x1,
616         .pll[4] = 0xA8,
617         .pll[5] = 0x0C,
618         .pll[6] = 0x33,
619         .pll[7] = 0x54,
620         .pll[8] = 0x1,
621         .pll[9] = 0x1,
622         .pll[10] = 0,
623         .pll[11] = 0,
624         .pll[12] = 0xC8,
625         .pll[13] = 0,
626         .pll[14] = 0,
627         .pll[15] = 0,
628         .pll[16] = 0x85,
629         .pll[17] = 0x8F,
630         .pll[18] = 0xE6,
631         .pll[19] = 0x23,
632 };
633
634 static const struct intel_c10pll_state mtl_c10_dp_hbr3 = {
635         .clock = 810000,
636         .tx = 0x10,
637         .cmn = 0x21,
638         .pll[0] = 0x34,
639         .pll[1] = 0,
640         .pll[2] = 0x84,
641         .pll[3] = 0x1,
642         .pll[4] = 0x30,
643         .pll[5] = 0x0F,
644         .pll[6] = 0x3D,
645         .pll[7] = 0x98,
646         .pll[8] = 0x1,
647         .pll[9] = 0x1,
648         .pll[10] = 0,
649         .pll[11] = 0,
650         .pll[12] = 0xF0,
651         .pll[13] = 0,
652         .pll[14] = 0,
653         .pll[15] = 0,
654         .pll[16] = 0x84,
655         .pll[17] = 0x0F,
656         .pll[18] = 0xE5,
657         .pll[19] = 0x23,
658 };
659
660 static const struct intel_c10pll_state * const mtl_c10_dp_tables[] = {
661         &mtl_c10_dp_rbr,
662         &mtl_c10_dp_hbr1,
663         &mtl_c10_dp_hbr2,
664         &mtl_c10_dp_hbr3,
665         NULL,
666 };
667
668 static const struct intel_c10pll_state * const mtl_c10_edp_tables[] = {
669         &mtl_c10_dp_rbr,
670         &mtl_c10_edp_r216,
671         &mtl_c10_edp_r243,
672         &mtl_c10_dp_hbr1,
673         &mtl_c10_edp_r324,
674         &mtl_c10_edp_r432,
675         &mtl_c10_dp_hbr2,
676         &mtl_c10_edp_r675,
677         &mtl_c10_dp_hbr3,
678         NULL,
679 };
680
681 /* C20 basic DP 1.4 tables */
682 static const struct intel_c20pll_state mtl_c20_dp_rbr = {
683         .link_bit_rate = 162000,
684         .clock = 162000,
685         .tx = { 0xbe88, /* tx cfg0 */
686                 0x5800, /* tx cfg1 */
687                 0x0000, /* tx cfg2 */
688                 },
689         .cmn = {0x0500, /* cmn cfg0*/
690                 0x0005, /* cmn cfg1 */
691                 0x0000, /* cmn cfg2 */
692                 0x0000, /* cmn cfg3 */
693                 },
694         .mpllb = { 0x50a8,      /* mpllb cfg0 */
695                 0x2120,         /* mpllb cfg1 */
696                 0xcd9a,         /* mpllb cfg2 */
697                 0xbfc1,         /* mpllb cfg3 */
698                 0x5ab8,         /* mpllb cfg4 */
699                 0x4c34,         /* mpllb cfg5 */
700                 0x2000,         /* mpllb cfg6 */
701                 0x0001,         /* mpllb cfg7 */
702                 0x6000,         /* mpllb cfg8 */
703                 0x0000,         /* mpllb cfg9 */
704                 0x0000,         /* mpllb cfg10 */
705                 },
706 };
707
708 static const struct intel_c20pll_state mtl_c20_dp_hbr1 = {
709         .link_bit_rate = 270000,
710         .clock = 270000,
711         .tx = { 0xbe88, /* tx cfg0 */
712                 0x4800, /* tx cfg1 */
713                 0x0000, /* tx cfg2 */
714                 },
715         .cmn = {0x0500, /* cmn cfg0*/
716                 0x0005, /* cmn cfg1 */
717                 0x0000, /* cmn cfg2 */
718                 0x0000, /* cmn cfg3 */
719                 },
720         .mpllb = { 0x308c,      /* mpllb cfg0 */
721                 0x2110,         /* mpllb cfg1 */
722                 0xcc9c,         /* mpllb cfg2 */
723                 0xbfc1,         /* mpllb cfg3 */
724                 0x4b9a,         /* mpllb cfg4 */
725                 0x3f81,         /* mpllb cfg5 */
726                 0x2000,         /* mpllb cfg6 */
727                 0x0001,         /* mpllb cfg7 */
728                 0x5000,         /* mpllb cfg8 */
729                 0x0000,         /* mpllb cfg9 */
730                 0x0000,         /* mpllb cfg10 */
731                 },
732 };
733
734 static const struct intel_c20pll_state mtl_c20_dp_hbr2 = {
735         .link_bit_rate = 540000,
736         .clock = 540000,
737         .tx = { 0xbe88, /* tx cfg0 */
738                 0x4800, /* tx cfg1 */
739                 0x0000, /* tx cfg2 */
740                 },
741         .cmn = {0x0500, /* cmn cfg0*/
742                 0x0005, /* cmn cfg1 */
743                 0x0000, /* cmn cfg2 */
744                 0x0000, /* cmn cfg3 */
745                 },
746         .mpllb = { 0x108c,      /* mpllb cfg0 */
747                 0x2108,         /* mpllb cfg1 */
748                 0xcc9c,         /* mpllb cfg2 */
749                 0xbfc1,         /* mpllb cfg3 */
750                 0x4b9a,         /* mpllb cfg4 */
751                 0x3f81,         /* mpllb cfg5 */
752                 0x2000,         /* mpllb cfg6 */
753                 0x0001,         /* mpllb cfg7 */
754                 0x5000,         /* mpllb cfg8 */
755                 0x0000,         /* mpllb cfg9 */
756                 0x0000,         /* mpllb cfg10 */
757                 },
758 };
759
760 static const struct intel_c20pll_state mtl_c20_dp_hbr3 = {
761         .link_bit_rate = 810000,
762         .clock = 810000,
763         .tx = { 0xbe88, /* tx cfg0 */
764                 0x4800, /* tx cfg1 */
765                 0x0000, /* tx cfg2 */
766                 },
767         .cmn = {0x0500, /* cmn cfg0*/
768                 0x0005, /* cmn cfg1 */
769                 0x0000, /* cmn cfg2 */
770                 0x0000, /* cmn cfg3 */
771                 },
772         .mpllb = { 0x10d2,      /* mpllb cfg0 */
773                 0x2108,         /* mpllb cfg1 */
774                 0x8d98,         /* mpllb cfg2 */
775                 0xbfc1,         /* mpllb cfg3 */
776                 0x7166,         /* mpllb cfg4 */
777                 0x5f42,         /* mpllb cfg5 */
778                 0x2000,         /* mpllb cfg6 */
779                 0x0001,         /* mpllb cfg7 */
780                 0x7800,         /* mpllb cfg8 */
781                 0x0000,         /* mpllb cfg9 */
782                 0x0000,         /* mpllb cfg10 */
783                 },
784 };
785
786 /* C20 basic DP 2.0 tables */
787 static const struct intel_c20pll_state mtl_c20_dp_uhbr10 = {
788         .link_bit_rate = 1000000, /* 10 Gbps */
789         .clock = 312500,
790         .tx = { 0xbe21, /* tx cfg0 */
791                 0x4800, /* tx cfg1 */
792                 0x0000, /* tx cfg2 */
793                 },
794         .cmn = {0x0500, /* cmn cfg0*/
795                 0x0005, /* cmn cfg1 */
796                 0x0000, /* cmn cfg2 */
797                 0x0000, /* cmn cfg3 */
798                 },
799         .mplla = { 0x3104,      /* mplla cfg0 */
800                 0xd105,         /* mplla cfg1 */
801                 0xc025,         /* mplla cfg2 */
802                 0xc025,         /* mplla cfg3 */
803                 0x8c00,         /* mplla cfg4 */
804                 0x759a,         /* mplla cfg5 */
805                 0x4000,         /* mplla cfg6 */
806                 0x0003,         /* mplla cfg7 */
807                 0x3555,         /* mplla cfg8 */
808                 0x0001,         /* mplla cfg9 */
809                 },
810 };
811
812 static const struct intel_c20pll_state mtl_c20_dp_uhbr13_5 = {
813         .link_bit_rate = 1350000, /* 13.5 Gbps */
814         .clock = 421875,
815         .tx = { 0xbea0, /* tx cfg0 */
816                 0x4800, /* tx cfg1 */
817                 0x0000, /* tx cfg2 */
818                 },
819         .cmn = {0x0500, /* cmn cfg0*/
820                 0x0005, /* cmn cfg1 */
821                 0x0000, /* cmn cfg2 */
822                 0x0000, /* cmn cfg3 */
823                 },
824         .mpllb = { 0x015f,      /* mpllb cfg0 */
825                 0x2205,         /* mpllb cfg1 */
826                 0x1b17,         /* mpllb cfg2 */
827                 0xffc1,         /* mpllb cfg3 */
828                 0xe100,         /* mpllb cfg4 */
829                 0xbd00,         /* mpllb cfg5 */
830                 0x2000,         /* mpllb cfg6 */
831                 0x0001,         /* mpllb cfg7 */
832                 0x4800,         /* mpllb cfg8 */
833                 0x0000,         /* mpllb cfg9 */
834                 0x0000,         /* mpllb cfg10 */
835                 },
836 };
837
838 static const struct intel_c20pll_state mtl_c20_dp_uhbr20 = {
839         .link_bit_rate = 2000000, /* 20 Gbps */
840         .clock = 625000,
841         .tx = { 0xbe20, /* tx cfg0 */
842                 0x4800, /* tx cfg1 */
843                 0x0000, /* tx cfg2 */
844                 },
845         .cmn = {0x0500, /* cmn cfg0*/
846                 0x0005, /* cmn cfg1 */
847                 0x0000, /* cmn cfg2 */
848                 0x0000, /* cmn cfg3 */
849                 },
850         .mplla = { 0x3104,      /* mplla cfg0 */
851                 0xd105,         /* mplla cfg1 */
852                 0xc025,         /* mplla cfg2 */
853                 0xc025,         /* mplla cfg3 */
854                 0xa6ab,         /* mplla cfg4 */
855                 0x8c00,         /* mplla cfg5 */
856                 0x4000,         /* mplla cfg6 */
857                 0x0003,         /* mplla cfg7 */
858                 0x3555,         /* mplla cfg8 */
859                 0x0001,         /* mplla cfg9 */
860                 },
861 };
862
863 static const struct intel_c20pll_state * const mtl_c20_dp_tables[] = {
864         &mtl_c20_dp_rbr,
865         &mtl_c20_dp_hbr1,
866         &mtl_c20_dp_hbr2,
867         &mtl_c20_dp_hbr3,
868         &mtl_c20_dp_uhbr10,
869         &mtl_c20_dp_uhbr13_5,
870         &mtl_c20_dp_uhbr20,
871         NULL,
872 };
873
874 /*
875  * HDMI link rates with 38.4 MHz reference clock.
876  */
877
878 static const struct intel_c10pll_state mtl_c10_hdmi_25_2 = {
879         .clock = 25200,
880         .tx = 0x10,
881         .cmn = 0x1,
882         .pll[0] = 0x4,
883         .pll[1] = 0,
884         .pll[2] = 0xB2,
885         .pll[3] = 0,
886         .pll[4] = 0,
887         .pll[5] = 0,
888         .pll[6] = 0,
889         .pll[7] = 0,
890         .pll[8] = 0x20,
891         .pll[9] = 0x1,
892         .pll[10] = 0,
893         .pll[11] = 0,
894         .pll[12] = 0,
895         .pll[13] = 0,
896         .pll[14] = 0,
897         .pll[15] = 0xD,
898         .pll[16] = 0x6,
899         .pll[17] = 0x8F,
900         .pll[18] = 0x84,
901         .pll[19] = 0x23,
902 };
903
904 static const struct intel_c10pll_state mtl_c10_hdmi_27_0 = {
905         .clock = 27000,
906         .tx = 0x10,
907         .cmn = 0x1,
908         .pll[0] = 0x34,
909         .pll[1] = 0,
910         .pll[2] = 0xC0,
911         .pll[3] = 0,
912         .pll[4] = 0,
913         .pll[5] = 0,
914         .pll[6] = 0,
915         .pll[7] = 0,
916         .pll[8] = 0x20,
917         .pll[9] = 0x1,
918         .pll[10] = 0,
919         .pll[11] = 0,
920         .pll[12] = 0x80,
921         .pll[13] = 0,
922         .pll[14] = 0,
923         .pll[15] = 0xD,
924         .pll[16] = 0x6,
925         .pll[17] = 0xCF,
926         .pll[18] = 0x84,
927         .pll[19] = 0x23,
928 };
929
930 static const struct intel_c10pll_state mtl_c10_hdmi_74_25 = {
931         .clock = 74250,
932         .tx = 0x10,
933         .cmn = 0x1,
934         .pll[0] = 0xF4,
935         .pll[1] = 0,
936         .pll[2] = 0x7A,
937         .pll[3] = 0,
938         .pll[4] = 0,
939         .pll[5] = 0,
940         .pll[6] = 0,
941         .pll[7] = 0,
942         .pll[8] = 0x20,
943         .pll[9] = 0x1,
944         .pll[10] = 0,
945         .pll[11] = 0,
946         .pll[12] = 0x58,
947         .pll[13] = 0,
948         .pll[14] = 0,
949         .pll[15] = 0xB,
950         .pll[16] = 0x6,
951         .pll[17] = 0xF,
952         .pll[18] = 0x85,
953         .pll[19] = 0x23,
954 };
955
956 static const struct intel_c10pll_state mtl_c10_hdmi_148_5 = {
957         .clock = 148500,
958         .tx = 0x10,
959         .cmn = 0x1,
960         .pll[0] = 0xF4,
961         .pll[1] = 0,
962         .pll[2] = 0x7A,
963         .pll[3] = 0,
964         .pll[4] = 0,
965         .pll[5] = 0,
966         .pll[6] = 0,
967         .pll[7] = 0,
968         .pll[8] = 0x20,
969         .pll[9] = 0x1,
970         .pll[10] = 0,
971         .pll[11] = 0,
972         .pll[12] = 0x58,
973         .pll[13] = 0,
974         .pll[14] = 0,
975         .pll[15] = 0xA,
976         .pll[16] = 0x6,
977         .pll[17] = 0xF,
978         .pll[18] = 0x85,
979         .pll[19] = 0x23,
980 };
981
982 static const struct intel_c10pll_state mtl_c10_hdmi_594 = {
983         .clock = 594000,
984         .tx = 0x10,
985         .cmn = 0x1,
986         .pll[0] = 0xF4,
987         .pll[1] = 0,
988         .pll[2] = 0x7A,
989         .pll[3] = 0,
990         .pll[4] = 0,
991         .pll[5] = 0,
992         .pll[6] = 0,
993         .pll[7] = 0,
994         .pll[8] = 0x20,
995         .pll[9] = 0x1,
996         .pll[10] = 0,
997         .pll[11] = 0,
998         .pll[12] = 0x58,
999         .pll[13] = 0,
1000         .pll[14] = 0,
1001         .pll[15] = 0x8,
1002         .pll[16] = 0x6,
1003         .pll[17] = 0xF,
1004         .pll[18] = 0x85,
1005         .pll[19] = 0x23,
1006 };
1007
1008 /* Precomputed C10 HDMI PLL tables */
1009 static const struct intel_c10pll_state mtl_c10_hdmi_27027 = {
1010         .clock = 27027,
1011         .tx = 0x10,
1012         .cmn = 0x1,
1013         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xC0, .pll[3] = 0x00, .pll[4] = 0x00,
1014         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1015         .pll[10] = 0xFF, .pll[11] = 0xCC, .pll[12] = 0x9C, .pll[13] = 0xCB, .pll[14] = 0xCC,
1016         .pll[15] = 0x0D, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1017 };
1018
1019 static const struct intel_c10pll_state mtl_c10_hdmi_28320 = {
1020         .clock = 28320,
1021         .tx = 0x10,
1022         .cmn = 0x1,
1023         .pll[0] = 0x04, .pll[1] = 0x00, .pll[2] = 0xCC, .pll[3] = 0x00, .pll[4] = 0x00,
1024         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1025         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x00, .pll[13] = 0x00, .pll[14] = 0x00,
1026         .pll[15] = 0x0D, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1027 };
1028
1029 static const struct intel_c10pll_state mtl_c10_hdmi_30240 = {
1030         .clock = 30240,
1031         .tx = 0x10,
1032         .cmn = 0x1,
1033         .pll[0] = 0x04, .pll[1] = 0x00, .pll[2] = 0xDC, .pll[3] = 0x00, .pll[4] = 0x00,
1034         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1035         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x00, .pll[13] = 0x00, .pll[14] = 0x00,
1036         .pll[15] = 0x0D, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1037 };
1038
1039 static const struct intel_c10pll_state mtl_c10_hdmi_31500 = {
1040         .clock = 31500,
1041         .tx = 0x10,
1042         .cmn = 0x1,
1043         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x62, .pll[3] = 0x00, .pll[4] = 0x00,
1044         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1045         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0xA0, .pll[13] = 0x00, .pll[14] = 0x00,
1046         .pll[15] = 0x0C, .pll[16] = 0x09, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1047 };
1048
1049 static const struct intel_c10pll_state mtl_c10_hdmi_36000 = {
1050         .clock = 36000,
1051         .tx = 0x10,
1052         .cmn = 0x1,
1053         .pll[0] = 0xC4, .pll[1] = 0x00, .pll[2] = 0x76, .pll[3] = 0x00, .pll[4] = 0x00,
1054         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1055         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x00, .pll[13] = 0x00, .pll[14] = 0x00,
1056         .pll[15] = 0x0C, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1057 };
1058
1059 static const struct intel_c10pll_state mtl_c10_hdmi_40000 = {
1060         .clock = 40000,
1061         .tx = 0x10,
1062         .cmn = 0x1,
1063         .pll[0] = 0xB4, .pll[1] = 0x00, .pll[2] = 0x86, .pll[3] = 0x00, .pll[4] = 0x00,
1064         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1065         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0x55, .pll[13] = 0x55, .pll[14] = 0x55,
1066         .pll[15] = 0x0C, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1067 };
1068
1069 static const struct intel_c10pll_state mtl_c10_hdmi_49500 = {
1070         .clock = 49500,
1071         .tx = 0x10,
1072         .cmn = 0x1,
1073         .pll[0] = 0x74, .pll[1] = 0x00, .pll[2] = 0xAE, .pll[3] = 0x00, .pll[4] = 0x00,
1074         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1075         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x20, .pll[13] = 0x00, .pll[14] = 0x00,
1076         .pll[15] = 0x0C, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1077 };
1078
1079 static const struct intel_c10pll_state mtl_c10_hdmi_50000 = {
1080         .clock = 50000,
1081         .tx = 0x10,
1082         .cmn = 0x1,
1083         .pll[0] = 0x74, .pll[1] = 0x00, .pll[2] = 0xB0, .pll[3] = 0x00, .pll[4] = 0x00,
1084         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1085         .pll[10] = 0xFF, .pll[11] = 0xAA, .pll[12] = 0x2A, .pll[13] = 0xA9, .pll[14] = 0xAA,
1086         .pll[15] = 0x0C, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1087 };
1088
1089 static const struct intel_c10pll_state mtl_c10_hdmi_57284 = {
1090         .clock = 57284,
1091         .tx = 0x10,
1092         .cmn = 0x1,
1093         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xCE, .pll[3] = 0x00, .pll[4] = 0x00,
1094         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1095         .pll[10] = 0xFF, .pll[11] = 0x77, .pll[12] = 0x57, .pll[13] = 0x77, .pll[14] = 0x77,
1096         .pll[15] = 0x0C, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1097 };
1098
1099 static const struct intel_c10pll_state mtl_c10_hdmi_58000 = {
1100         .clock = 58000,
1101         .tx = 0x10,
1102         .cmn = 0x1,
1103         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xD0, .pll[3] = 0x00, .pll[4] = 0x00,
1104         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1105         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0xD5, .pll[13] = 0x55, .pll[14] = 0x55,
1106         .pll[15] = 0x0C, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1107 };
1108
1109 static const struct intel_c10pll_state mtl_c10_hdmi_65000 = {
1110         .clock = 65000,
1111         .tx = 0x10,
1112         .cmn = 0x1,
1113         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x66, .pll[3] = 0x00, .pll[4] = 0x00,
1114         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1115         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0xB5, .pll[13] = 0x55, .pll[14] = 0x55,
1116         .pll[15] = 0x0B, .pll[16] = 0x09, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1117 };
1118
1119 static const struct intel_c10pll_state mtl_c10_hdmi_71000 = {
1120         .clock = 71000,
1121         .tx = 0x10,
1122         .cmn = 0x1,
1123         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x72, .pll[3] = 0x00, .pll[4] = 0x00,
1124         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1125         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0xF5, .pll[13] = 0x55, .pll[14] = 0x55,
1126         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1127 };
1128
1129 static const struct intel_c10pll_state mtl_c10_hdmi_74176 = {
1130         .clock = 74176,
1131         .tx = 0x10,
1132         .cmn = 0x1,
1133         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x7A, .pll[3] = 0x00, .pll[4] = 0x00,
1134         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1135         .pll[10] = 0xFF, .pll[11] = 0x44, .pll[12] = 0x44, .pll[13] = 0x44, .pll[14] = 0x44,
1136         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1137 };
1138
1139 static const struct intel_c10pll_state mtl_c10_hdmi_75000 = {
1140         .clock = 75000,
1141         .tx = 0x10,
1142         .cmn = 0x1,
1143         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x7C, .pll[3] = 0x00, .pll[4] = 0x00,
1144         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1145         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x20, .pll[13] = 0x00, .pll[14] = 0x00,
1146         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1147 };
1148
1149 static const struct intel_c10pll_state mtl_c10_hdmi_78750 = {
1150         .clock = 78750,
1151         .tx = 0x10,
1152         .cmn = 0x1,
1153         .pll[0] = 0xB4, .pll[1] = 0x00, .pll[2] = 0x84, .pll[3] = 0x00, .pll[4] = 0x00,
1154         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1155         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x08, .pll[13] = 0x00, .pll[14] = 0x00,
1156         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1157 };
1158
1159 static const struct intel_c10pll_state mtl_c10_hdmi_85500 = {
1160         .clock = 85500,
1161         .tx = 0x10,
1162         .cmn = 0x1,
1163         .pll[0] = 0xB4, .pll[1] = 0x00, .pll[2] = 0x92, .pll[3] = 0x00, .pll[4] = 0x00,
1164         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1165         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x10, .pll[13] = 0x00, .pll[14] = 0x00,
1166         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1167 };
1168
1169 static const struct intel_c10pll_state mtl_c10_hdmi_88750 = {
1170         .clock = 88750,
1171         .tx = 0x10,
1172         .cmn = 0x1,
1173         .pll[0] = 0x74, .pll[1] = 0x00, .pll[2] = 0x98, .pll[3] = 0x00, .pll[4] = 0x00,
1174         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1175         .pll[10] = 0xFF, .pll[11] = 0xAA, .pll[12] = 0x72, .pll[13] = 0xA9, .pll[14] = 0xAA,
1176         .pll[15] = 0x0B, .pll[16] = 0x09, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1177 };
1178
1179 static const struct intel_c10pll_state mtl_c10_hdmi_106500 = {
1180         .clock = 106500,
1181         .tx = 0x10,
1182         .cmn = 0x1,
1183         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xBC, .pll[3] = 0x00, .pll[4] = 0x00,
1184         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1185         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0xF0, .pll[13] = 0x00, .pll[14] = 0x00,
1186         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1187 };
1188
1189 static const struct intel_c10pll_state mtl_c10_hdmi_108000 = {
1190         .clock = 108000,
1191         .tx = 0x10,
1192         .cmn = 0x1,
1193         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xC0, .pll[3] = 0x00, .pll[4] = 0x00,
1194         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1195         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x80, .pll[13] = 0x00, .pll[14] = 0x00,
1196         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1197 };
1198
1199 static const struct intel_c10pll_state mtl_c10_hdmi_115500 = {
1200         .clock = 115500,
1201         .tx = 0x10,
1202         .cmn = 0x1,
1203         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xD0, .pll[3] = 0x00, .pll[4] = 0x00,
1204         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1205         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x50, .pll[13] = 0x00, .pll[14] = 0x00,
1206         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1207 };
1208
1209 static const struct intel_c10pll_state mtl_c10_hdmi_119000 = {
1210         .clock = 119000,
1211         .tx = 0x10,
1212         .cmn = 0x1,
1213         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xD6, .pll[3] = 0x00, .pll[4] = 0x00,
1214         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1215         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0xF5, .pll[13] = 0x55, .pll[14] = 0x55,
1216         .pll[15] = 0x0B, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1217 };
1218
1219 static const struct intel_c10pll_state mtl_c10_hdmi_135000 = {
1220         .clock = 135000,
1221         .tx = 0x10,
1222         .cmn = 0x1,
1223         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x6C, .pll[3] = 0x00, .pll[4] = 0x00,
1224         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1225         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x50, .pll[13] = 0x00, .pll[14] = 0x00,
1226         .pll[15] = 0x0A, .pll[16] = 0x09, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1227 };
1228
1229 static const struct intel_c10pll_state mtl_c10_hdmi_138500 = {
1230         .clock = 138500,
1231         .tx = 0x10,
1232         .cmn = 0x1,
1233         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x70, .pll[3] = 0x00, .pll[4] = 0x00,
1234         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1235         .pll[10] = 0xFF, .pll[11] = 0xAA, .pll[12] = 0x22, .pll[13] = 0xA9, .pll[14] = 0xAA,
1236         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1237 };
1238
1239 static const struct intel_c10pll_state mtl_c10_hdmi_147160 = {
1240         .clock = 147160,
1241         .tx = 0x10,
1242         .cmn = 0x1,
1243         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x78, .pll[3] = 0x00, .pll[4] = 0x00,
1244         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1245         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0xA5, .pll[13] = 0x55, .pll[14] = 0x55,
1246         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1247 };
1248
1249 static const struct intel_c10pll_state mtl_c10_hdmi_148352 = {
1250         .clock = 148352,
1251         .tx = 0x10,
1252         .cmn = 0x1,
1253         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x7A, .pll[3] = 0x00, .pll[4] = 0x00,
1254         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1255         .pll[10] = 0xFF, .pll[11] = 0x44, .pll[12] = 0x44, .pll[13] = 0x44, .pll[14] = 0x44,
1256         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1257 };
1258
1259 static const struct intel_c10pll_state mtl_c10_hdmi_154000 = {
1260         .clock = 154000,
1261         .tx = 0x10,
1262         .cmn = 0x1,
1263         .pll[0] = 0xB4, .pll[1] = 0x00, .pll[2] = 0x80, .pll[3] = 0x00, .pll[4] = 0x00,
1264         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1265         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0x35, .pll[13] = 0x55, .pll[14] = 0x55,
1266         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1267 };
1268
1269 static const struct intel_c10pll_state mtl_c10_hdmi_162000 = {
1270         .clock = 162000,
1271         .tx = 0x10,
1272         .cmn = 0x1,
1273         .pll[0] = 0xB4, .pll[1] = 0x00, .pll[2] = 0x88, .pll[3] = 0x00, .pll[4] = 0x00,
1274         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1275         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x60, .pll[13] = 0x00, .pll[14] = 0x00,
1276         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1277 };
1278
1279 static const struct intel_c10pll_state mtl_c10_hdmi_167000 = {
1280         .clock = 167000,
1281         .tx = 0x10,
1282         .cmn = 0x1,
1283         .pll[0] = 0xB4, .pll[1] = 0x00, .pll[2] = 0x8C, .pll[3] = 0x00, .pll[4] = 0x00,
1284         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1285         .pll[10] = 0xFF, .pll[11] = 0xAA, .pll[12] = 0xFA, .pll[13] = 0xA9, .pll[14] = 0xAA,
1286         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1287 };
1288
1289 static const struct intel_c10pll_state mtl_c10_hdmi_197802 = {
1290         .clock = 197802,
1291         .tx = 0x10,
1292         .cmn = 0x1,
1293         .pll[0] = 0x74, .pll[1] = 0x00, .pll[2] = 0xAE, .pll[3] = 0x00, .pll[4] = 0x00,
1294         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1295         .pll[10] = 0xFF, .pll[11] = 0x99, .pll[12] = 0x05, .pll[13] = 0x98, .pll[14] = 0x99,
1296         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1297 };
1298
1299 static const struct intel_c10pll_state mtl_c10_hdmi_198000 = {
1300         .clock = 198000,
1301         .tx = 0x10,
1302         .cmn = 0x1,
1303         .pll[0] = 0x74, .pll[1] = 0x00, .pll[2] = 0xAE, .pll[3] = 0x00, .pll[4] = 0x00,
1304         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1305         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x20, .pll[13] = 0x00, .pll[14] = 0x00,
1306         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1307 };
1308
1309 static const struct intel_c10pll_state mtl_c10_hdmi_209800 = {
1310         .clock = 209800,
1311         .tx = 0x10,
1312         .cmn = 0x1,
1313         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xBA, .pll[3] = 0x00, .pll[4] = 0x00,
1314         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1315         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0x45, .pll[13] = 0x55, .pll[14] = 0x55,
1316         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1317 };
1318
1319 static const struct intel_c10pll_state mtl_c10_hdmi_241500 = {
1320         .clock = 241500,
1321         .tx = 0x10,
1322         .cmn = 0x1,
1323         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xDA, .pll[3] = 0x00, .pll[4] = 0x00,
1324         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1325         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0xC8, .pll[13] = 0x00, .pll[14] = 0x00,
1326         .pll[15] = 0x0A, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1327 };
1328
1329 static const struct intel_c10pll_state mtl_c10_hdmi_262750 = {
1330         .clock = 262750,
1331         .tx = 0x10,
1332         .cmn = 0x1,
1333         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x68, .pll[3] = 0x00, .pll[4] = 0x00,
1334         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1335         .pll[10] = 0xFF, .pll[11] = 0xAA, .pll[12] = 0x6C, .pll[13] = 0xA9, .pll[14] = 0xAA,
1336         .pll[15] = 0x09, .pll[16] = 0x09, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1337 };
1338
1339 static const struct intel_c10pll_state mtl_c10_hdmi_268500 = {
1340         .clock = 268500,
1341         .tx = 0x10,
1342         .cmn = 0x1,
1343         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x6A, .pll[3] = 0x00, .pll[4] = 0x00,
1344         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1345         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0xEC, .pll[13] = 0x00, .pll[14] = 0x00,
1346         .pll[15] = 0x09, .pll[16] = 0x09, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1347 };
1348
1349 static const struct intel_c10pll_state mtl_c10_hdmi_296703 = {
1350         .clock = 296703,
1351         .tx = 0x10,
1352         .cmn = 0x1,
1353         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x7A, .pll[3] = 0x00, .pll[4] = 0x00,
1354         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1355         .pll[10] = 0xFF, .pll[11] = 0x33, .pll[12] = 0x44, .pll[13] = 0x33, .pll[14] = 0x33,
1356         .pll[15] = 0x09, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1357 };
1358
1359 static const struct intel_c10pll_state mtl_c10_hdmi_297000 = {
1360         .clock = 297000,
1361         .tx = 0x10,
1362         .cmn = 0x1,
1363         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x7A, .pll[3] = 0x00, .pll[4] = 0x00,
1364         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1365         .pll[10] = 0xFF, .pll[11] = 0x00, .pll[12] = 0x58, .pll[13] = 0x00, .pll[14] = 0x00,
1366         .pll[15] = 0x09, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1367 };
1368
1369 static const struct intel_c10pll_state mtl_c10_hdmi_319750 = {
1370         .clock = 319750,
1371         .tx = 0x10,
1372         .cmn = 0x1,
1373         .pll[0] = 0xB4, .pll[1] = 0x00, .pll[2] = 0x86, .pll[3] = 0x00, .pll[4] = 0x00,
1374         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1375         .pll[10] = 0xFF, .pll[11] = 0xAA, .pll[12] = 0x44, .pll[13] = 0xA9, .pll[14] = 0xAA,
1376         .pll[15] = 0x09, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1377 };
1378
1379 static const struct intel_c10pll_state mtl_c10_hdmi_497750 = {
1380         .clock = 497750,
1381         .tx = 0x10,
1382         .cmn = 0x1,
1383         .pll[0] = 0x34, .pll[1] = 0x00, .pll[2] = 0xE2, .pll[3] = 0x00, .pll[4] = 0x00,
1384         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1385         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0x9F, .pll[13] = 0x55, .pll[14] = 0x55,
1386         .pll[15] = 0x09, .pll[16] = 0x08, .pll[17] = 0xCF, .pll[18] = 0x84, .pll[19] = 0x23,
1387 };
1388
1389 static const struct intel_c10pll_state mtl_c10_hdmi_592000 = {
1390         .clock = 592000,
1391         .tx = 0x10,
1392         .cmn = 0x1,
1393         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x7A, .pll[3] = 0x00, .pll[4] = 0x00,
1394         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1395         .pll[10] = 0xFF, .pll[11] = 0x55, .pll[12] = 0x15, .pll[13] = 0x55, .pll[14] = 0x55,
1396         .pll[15] = 0x08, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1397 };
1398
1399 static const struct intel_c10pll_state mtl_c10_hdmi_593407 = {
1400         .clock = 593407,
1401         .tx = 0x10,
1402         .cmn = 0x1,
1403         .pll[0] = 0xF4, .pll[1] = 0x00, .pll[2] = 0x7A, .pll[3] = 0x00, .pll[4] = 0x00,
1404         .pll[5] = 0x00, .pll[6] = 0x00, .pll[7] = 0x00, .pll[8] = 0x20, .pll[9] = 0xFF,
1405         .pll[10] = 0xFF, .pll[11] = 0x3B, .pll[12] = 0x44, .pll[13] = 0xBA, .pll[14] = 0xBB,
1406         .pll[15] = 0x08, .pll[16] = 0x08, .pll[17] = 0x8F, .pll[18] = 0x84, .pll[19] = 0x23,
1407 };
1408
1409 static const struct intel_c10pll_state * const mtl_c10_hdmi_tables[] = {
1410         &mtl_c10_hdmi_25_2, /* Consolidated Table */
1411         &mtl_c10_hdmi_27_0, /* Consolidated Table */
1412         &mtl_c10_hdmi_27027,
1413         &mtl_c10_hdmi_28320,
1414         &mtl_c10_hdmi_30240,
1415         &mtl_c10_hdmi_31500,
1416         &mtl_c10_hdmi_36000,
1417         &mtl_c10_hdmi_40000,
1418         &mtl_c10_hdmi_49500,
1419         &mtl_c10_hdmi_50000,
1420         &mtl_c10_hdmi_57284,
1421         &mtl_c10_hdmi_58000,
1422         &mtl_c10_hdmi_65000,
1423         &mtl_c10_hdmi_71000,
1424         &mtl_c10_hdmi_74176,
1425         &mtl_c10_hdmi_74_25, /* Consolidated Table */
1426         &mtl_c10_hdmi_75000,
1427         &mtl_c10_hdmi_78750,
1428         &mtl_c10_hdmi_85500,
1429         &mtl_c10_hdmi_88750,
1430         &mtl_c10_hdmi_106500,
1431         &mtl_c10_hdmi_108000,
1432         &mtl_c10_hdmi_115500,
1433         &mtl_c10_hdmi_119000,
1434         &mtl_c10_hdmi_135000,
1435         &mtl_c10_hdmi_138500,
1436         &mtl_c10_hdmi_147160,
1437         &mtl_c10_hdmi_148352,
1438         &mtl_c10_hdmi_148_5, /* Consolidated Table */
1439         &mtl_c10_hdmi_154000,
1440         &mtl_c10_hdmi_162000,
1441         &mtl_c10_hdmi_167000,
1442         &mtl_c10_hdmi_197802,
1443         &mtl_c10_hdmi_198000,
1444         &mtl_c10_hdmi_209800,
1445         &mtl_c10_hdmi_241500,
1446         &mtl_c10_hdmi_262750,
1447         &mtl_c10_hdmi_268500,
1448         &mtl_c10_hdmi_296703,
1449         &mtl_c10_hdmi_297000,
1450         &mtl_c10_hdmi_319750,
1451         &mtl_c10_hdmi_497750,
1452         &mtl_c10_hdmi_592000,
1453         &mtl_c10_hdmi_593407,
1454         &mtl_c10_hdmi_594, /* Consolidated Table */
1455         NULL,
1456 };
1457
1458 static const struct intel_c20pll_state mtl_c20_hdmi_25_175 = {
1459         .link_bit_rate = 25175,
1460         .clock = 25175,
1461         .tx = {  0xbe88, /* tx cfg0 */
1462                   0x9800, /* tx cfg1 */
1463                   0x0000, /* tx cfg2 */
1464                 },
1465         .cmn = { 0x0500, /* cmn cfg0*/
1466                   0x0005, /* cmn cfg1 */
1467                   0x0000, /* cmn cfg2 */
1468                   0x0000, /* cmn cfg3 */
1469                 },
1470         .mpllb = { 0xa0d2,      /* mpllb cfg0 */
1471                    0x7d80,      /* mpllb cfg1 */
1472                    0x0906,      /* mpllb cfg2 */
1473                    0xbe40,      /* mpllb cfg3 */
1474                    0x0000,      /* mpllb cfg4 */
1475                    0x0000,      /* mpllb cfg5 */
1476                    0x0200,      /* mpllb cfg6 */
1477                    0x0001,      /* mpllb cfg7 */
1478                    0x0000,      /* mpllb cfg8 */
1479                    0x0000,      /* mpllb cfg9 */
1480                    0x0001,      /* mpllb cfg10 */
1481                 },
1482 };
1483
1484 static const struct intel_c20pll_state mtl_c20_hdmi_27_0 = {
1485         .link_bit_rate = 27000,
1486         .clock = 27000,
1487         .tx = {  0xbe88, /* tx cfg0 */
1488                   0x9800, /* tx cfg1 */
1489                   0x0000, /* tx cfg2 */
1490                 },
1491         .cmn = { 0x0500, /* cmn cfg0*/
1492                   0x0005, /* cmn cfg1 */
1493                   0x0000, /* cmn cfg2 */
1494                   0x0000, /* cmn cfg3 */
1495                 },
1496         .mpllb = { 0xa0e0,      /* mpllb cfg0 */
1497                    0x7d80,      /* mpllb cfg1 */
1498                    0x0906,      /* mpllb cfg2 */
1499                    0xbe40,      /* mpllb cfg3 */
1500                    0x0000,      /* mpllb cfg4 */
1501                    0x0000,      /* mpllb cfg5 */
1502                    0x2200,      /* mpllb cfg6 */
1503                    0x0001,      /* mpllb cfg7 */
1504                    0x8000,      /* mpllb cfg8 */
1505                    0x0000,      /* mpllb cfg9 */
1506                    0x0001,      /* mpllb cfg10 */
1507                 },
1508 };
1509
1510 static const struct intel_c20pll_state mtl_c20_hdmi_74_25 = {
1511         .link_bit_rate = 74250,
1512         .clock = 74250,
1513         .tx = {  0xbe88, /* tx cfg0 */
1514                   0x9800, /* tx cfg1 */
1515                   0x0000, /* tx cfg2 */
1516                 },
1517         .cmn = { 0x0500, /* cmn cfg0*/
1518                   0x0005, /* cmn cfg1 */
1519                   0x0000, /* cmn cfg2 */
1520                   0x0000, /* cmn cfg3 */
1521                 },
1522         .mpllb = { 0x609a,      /* mpllb cfg0 */
1523                    0x7d40,      /* mpllb cfg1 */
1524                    0xca06,      /* mpllb cfg2 */
1525                    0xbe40,      /* mpllb cfg3 */
1526                    0x0000,      /* mpllb cfg4 */
1527                    0x0000,      /* mpllb cfg5 */
1528                    0x2200,      /* mpllb cfg6 */
1529                    0x0001,      /* mpllb cfg7 */
1530                    0x5800,      /* mpllb cfg8 */
1531                    0x0000,      /* mpllb cfg9 */
1532                    0x0001,      /* mpllb cfg10 */
1533                 },
1534 };
1535
1536 static const struct intel_c20pll_state mtl_c20_hdmi_148_5 = {
1537         .link_bit_rate = 148500,
1538         .clock = 148500,
1539         .tx = {  0xbe88, /* tx cfg0 */
1540                   0x9800, /* tx cfg1 */
1541                   0x0000, /* tx cfg2 */
1542                 },
1543         .cmn = { 0x0500, /* cmn cfg0*/
1544                   0x0005, /* cmn cfg1 */
1545                   0x0000, /* cmn cfg2 */
1546                   0x0000, /* cmn cfg3 */
1547                 },
1548         .mpllb = { 0x409a,      /* mpllb cfg0 */
1549                    0x7d20,      /* mpllb cfg1 */
1550                    0xca06,      /* mpllb cfg2 */
1551                    0xbe40,      /* mpllb cfg3 */
1552                    0x0000,      /* mpllb cfg4 */
1553                    0x0000,      /* mpllb cfg5 */
1554                    0x2200,      /* mpllb cfg6 */
1555                    0x0001,      /* mpllb cfg7 */
1556                    0x5800,      /* mpllb cfg8 */
1557                    0x0000,      /* mpllb cfg9 */
1558                    0x0001,      /* mpllb cfg10 */
1559                 },
1560 };
1561
1562 static const struct intel_c20pll_state mtl_c20_hdmi_594 = {
1563         .link_bit_rate = 594000,
1564         .clock = 594000,
1565         .tx = {  0xbe88, /* tx cfg0 */
1566                   0x9800, /* tx cfg1 */
1567                   0x0000, /* tx cfg2 */
1568                 },
1569         .cmn = { 0x0500, /* cmn cfg0*/
1570                   0x0005, /* cmn cfg1 */
1571                   0x0000, /* cmn cfg2 */
1572                   0x0000, /* cmn cfg3 */
1573                 },
1574         .mpllb = { 0x009a,      /* mpllb cfg0 */
1575                    0x7d08,      /* mpllb cfg1 */
1576                    0xca06,      /* mpllb cfg2 */
1577                    0xbe40,      /* mpllb cfg3 */
1578                    0x0000,      /* mpllb cfg4 */
1579                    0x0000,      /* mpllb cfg5 */
1580                    0x2200,      /* mpllb cfg6 */
1581                    0x0001,      /* mpllb cfg7 */
1582                    0x5800,      /* mpllb cfg8 */
1583                    0x0000,      /* mpllb cfg9 */
1584                    0x0001,      /* mpllb cfg10 */
1585                 },
1586 };
1587
1588 static const struct intel_c20pll_state mtl_c20_hdmi_300 = {
1589         .link_bit_rate = 3000000,
1590         .clock = 166670,
1591         .tx = {  0xbe98, /* tx cfg0 */
1592                   0x9800, /* tx cfg1 */
1593                   0x0000, /* tx cfg2 */
1594                 },
1595         .cmn = { 0x0500, /* cmn cfg0*/
1596                   0x0005, /* cmn cfg1 */
1597                   0x0000, /* cmn cfg2 */
1598                   0x0000, /* cmn cfg3 */
1599                 },
1600         .mpllb = { 0x209c,      /* mpllb cfg0 */
1601                    0x7d10,      /* mpllb cfg1 */
1602                    0xca06,      /* mpllb cfg2 */
1603                    0xbe40,      /* mpllb cfg3 */
1604                    0x0000,      /* mpllb cfg4 */
1605                    0x0000,      /* mpllb cfg5 */
1606                    0x2200,      /* mpllb cfg6 */
1607                    0x0001,      /* mpllb cfg7 */
1608                    0x2000,      /* mpllb cfg8 */
1609                    0x0000,      /* mpllb cfg9 */
1610                    0x0004,      /* mpllb cfg10 */
1611                 },
1612 };
1613
1614 static const struct intel_c20pll_state mtl_c20_hdmi_600 = {
1615         .link_bit_rate = 6000000,
1616         .clock = 333330,
1617         .tx = {  0xbe98, /* tx cfg0 */
1618                   0x9800, /* tx cfg1 */
1619                   0x0000, /* tx cfg2 */
1620                 },
1621         .cmn = { 0x0500, /* cmn cfg0*/
1622                   0x0005, /* cmn cfg1 */
1623                   0x0000, /* cmn cfg2 */
1624                   0x0000, /* cmn cfg3 */
1625                 },
1626         .mpllb = { 0x009c,      /* mpllb cfg0 */
1627                    0x7d08,      /* mpllb cfg1 */
1628                    0xca06,      /* mpllb cfg2 */
1629                    0xbe40,      /* mpllb cfg3 */
1630                    0x0000,      /* mpllb cfg4 */
1631                    0x0000,      /* mpllb cfg5 */
1632                    0x2200,      /* mpllb cfg6 */
1633                    0x0001,      /* mpllb cfg7 */
1634                    0x2000,      /* mpllb cfg8 */
1635                    0x0000,      /* mpllb cfg9 */
1636                    0x0004,      /* mpllb cfg10 */
1637                 },
1638 };
1639
1640 static const struct intel_c20pll_state mtl_c20_hdmi_800 = {
1641         .link_bit_rate = 8000000,
1642         .clock = 444440,
1643         .tx = {  0xbe98, /* tx cfg0 */
1644                   0x9800, /* tx cfg1 */
1645                   0x0000, /* tx cfg2 */
1646                 },
1647         .cmn = { 0x0500, /* cmn cfg0*/
1648                   0x0005, /* cmn cfg1 */
1649                   0x0000, /* cmn cfg2 */
1650                   0x0000, /* cmn cfg3 */
1651                 },
1652         .mpllb = { 0x00d0,      /* mpllb cfg0 */
1653                    0x7d08,      /* mpllb cfg1 */
1654                    0x4a06,      /* mpllb cfg2 */
1655                    0xbe40,      /* mpllb cfg3 */
1656                    0x0000,      /* mpllb cfg4 */
1657                    0x0000,      /* mpllb cfg5 */
1658                    0x2200,      /* mpllb cfg6 */
1659                    0x0003,      /* mpllb cfg7 */
1660                    0x2aaa,      /* mpllb cfg8 */
1661                    0x0002,      /* mpllb cfg9 */
1662                    0x0004,      /* mpllb cfg10 */
1663                 },
1664 };
1665
1666 static const struct intel_c20pll_state mtl_c20_hdmi_1000 = {
1667         .link_bit_rate = 10000000,
1668         .clock = 555560,
1669         .tx = {  0xbe98, /* tx cfg0 */
1670                   0x9800, /* tx cfg1 */
1671                   0x0000, /* tx cfg2 */
1672                 },
1673         .cmn = { 0x0500, /* cmn cfg0*/
1674                   0x0005, /* cmn cfg1 */
1675                   0x0000, /* cmn cfg2 */
1676                   0x0000, /* cmn cfg3 */
1677                 },
1678         .mpllb = { 0x1104,      /* mpllb cfg0 */
1679                    0x7d08,      /* mpllb cfg1 */
1680                    0x0a06,      /* mpllb cfg2 */
1681                    0xbe40,      /* mpllb cfg3 */
1682                    0x0000,      /* mpllb cfg4 */
1683                    0x0000,      /* mpllb cfg5 */
1684                    0x2200,      /* mpllb cfg6 */
1685                    0x0003,      /* mpllb cfg7 */
1686                    0x3555,      /* mpllb cfg8 */
1687                    0x0001,      /* mpllb cfg9 */
1688                    0x0004,      /* mpllb cfg10 */
1689                 },
1690 };
1691
1692 static const struct intel_c20pll_state mtl_c20_hdmi_1200 = {
1693         .link_bit_rate = 12000000,
1694         .clock = 666670,
1695         .tx = {  0xbe98, /* tx cfg0 */
1696                   0x9800, /* tx cfg1 */
1697                   0x0000, /* tx cfg2 */
1698                 },
1699         .cmn = { 0x0500, /* cmn cfg0*/
1700                   0x0005, /* cmn cfg1 */
1701                   0x0000, /* cmn cfg2 */
1702                   0x0000, /* cmn cfg3 */
1703                 },
1704         .mpllb = { 0x0138,      /* mpllb cfg0 */
1705                    0x7d08,      /* mpllb cfg1 */
1706                    0x5486,      /* mpllb cfg2 */
1707                    0xfe40,      /* mpllb cfg3 */
1708                    0x0000,      /* mpllb cfg4 */
1709                    0x0000,      /* mpllb cfg5 */
1710                    0x2200,      /* mpllb cfg6 */
1711                    0x0001,      /* mpllb cfg7 */
1712                    0x4000,      /* mpllb cfg8 */
1713                    0x0000,      /* mpllb cfg9 */
1714                    0x0004,      /* mpllb cfg10 */
1715                 },
1716 };
1717
1718 static const struct intel_c20pll_state * const mtl_c20_hdmi_tables[] = {
1719         &mtl_c20_hdmi_25_175,
1720         &mtl_c20_hdmi_27_0,
1721         &mtl_c20_hdmi_74_25,
1722         &mtl_c20_hdmi_148_5,
1723         &mtl_c20_hdmi_594,
1724         &mtl_c20_hdmi_300,
1725         &mtl_c20_hdmi_600,
1726         &mtl_c20_hdmi_800,
1727         &mtl_c20_hdmi_1000,
1728         &mtl_c20_hdmi_1200,
1729         NULL,
1730 };
1731
1732 static int intel_c10_phy_check_hdmi_link_rate(int clock)
1733 {
1734         const struct intel_c10pll_state * const *tables = mtl_c10_hdmi_tables;
1735         int i;
1736
1737         for (i = 0; tables[i]; i++) {
1738                 if (clock == tables[i]->clock)
1739                         return MODE_OK;
1740         }
1741
1742         return MODE_CLOCK_RANGE;
1743 }
1744
1745 static const struct intel_c10pll_state * const *
1746 intel_c10pll_tables_get(struct intel_crtc_state *crtc_state,
1747                         struct intel_encoder *encoder)
1748 {
1749         if (intel_crtc_has_dp_encoder(crtc_state)) {
1750                 if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP))
1751                         return mtl_c10_edp_tables;
1752                 else
1753                         return mtl_c10_dp_tables;
1754         } else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
1755                 return mtl_c10_hdmi_tables;
1756         }
1757
1758         MISSING_CASE(encoder->type);
1759         return NULL;
1760 }
1761
1762 static void intel_c10pll_update_pll(struct intel_crtc_state *crtc_state,
1763                                     struct intel_encoder *encoder)
1764 {
1765         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
1766         struct intel_cx0pll_state *pll_state = &crtc_state->cx0pll_state;
1767         int i;
1768
1769         if (intel_crtc_has_dp_encoder(crtc_state)) {
1770                 if (intel_panel_use_ssc(i915)) {
1771                         struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
1772
1773                         pll_state->ssc_enabled =
1774                                 (intel_dp->dpcd[DP_MAX_DOWNSPREAD] & DP_MAX_DOWNSPREAD_0_5);
1775                 }
1776         }
1777
1778         if (pll_state->ssc_enabled)
1779                 return;
1780
1781         drm_WARN_ON(&i915->drm, ARRAY_SIZE(pll_state->c10.pll) < 9);
1782         for (i = 4; i < 9; i++)
1783                 pll_state->c10.pll[i] = 0;
1784 }
1785
1786 static int intel_c10pll_calc_state(struct intel_crtc_state *crtc_state,
1787                                    struct intel_encoder *encoder)
1788 {
1789         const struct intel_c10pll_state * const *tables;
1790         int i;
1791
1792         tables = intel_c10pll_tables_get(crtc_state, encoder);
1793         if (!tables)
1794                 return -EINVAL;
1795
1796         for (i = 0; tables[i]; i++) {
1797                 if (crtc_state->port_clock == tables[i]->clock) {
1798                         crtc_state->cx0pll_state.c10 = *tables[i];
1799                         intel_c10pll_update_pll(crtc_state, encoder);
1800
1801                         return 0;
1802                 }
1803         }
1804
1805         return -EINVAL;
1806 }
1807
1808 void intel_c10pll_readout_hw_state(struct intel_encoder *encoder,
1809                                    struct intel_c10pll_state *pll_state)
1810 {
1811         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
1812         u8 lane = INTEL_CX0_LANE0;
1813         intel_wakeref_t wakeref;
1814         int i;
1815
1816         wakeref = intel_cx0_phy_transaction_begin(encoder);
1817
1818         /*
1819          * According to C10 VDR Register programming Sequence we need
1820          * to do this to read PHY internal registers from MsgBus.
1821          */
1822         intel_cx0_rmw(i915, encoder->port, lane, PHY_C10_VDR_CONTROL(1),
1823                       0, C10_VDR_CTRL_MSGBUS_ACCESS,
1824                       MB_WRITE_COMMITTED);
1825
1826         for (i = 0; i < ARRAY_SIZE(pll_state->pll); i++)
1827                 pll_state->pll[i] = intel_cx0_read(i915, encoder->port, lane,
1828                                                    PHY_C10_VDR_PLL(i));
1829
1830         pll_state->cmn = intel_cx0_read(i915, encoder->port, lane, PHY_C10_VDR_CMN(0));
1831         pll_state->tx = intel_cx0_read(i915, encoder->port, lane, PHY_C10_VDR_TX(0));
1832
1833         intel_cx0_phy_transaction_end(encoder, wakeref);
1834 }
1835
1836 static void intel_c10_pll_program(struct drm_i915_private *i915,
1837                                   const struct intel_crtc_state *crtc_state,
1838                                   struct intel_encoder *encoder)
1839 {
1840         const struct intel_c10pll_state *pll_state = &crtc_state->cx0pll_state.c10;
1841         int i;
1842
1843         intel_cx0_rmw(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C10_VDR_CONTROL(1),
1844                       0, C10_VDR_CTRL_MSGBUS_ACCESS,
1845                       MB_WRITE_COMMITTED);
1846
1847         /* Custom width needs to be programmed to 0 for both the phy lanes */
1848         intel_cx0_rmw(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C10_VDR_CUSTOM_WIDTH,
1849                       C10_VDR_CUSTOM_WIDTH_MASK, C10_VDR_CUSTOM_WIDTH_8_10,
1850                       MB_WRITE_COMMITTED);
1851         intel_cx0_rmw(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C10_VDR_CONTROL(1),
1852                       0, C10_VDR_CTRL_UPDATE_CFG,
1853                       MB_WRITE_COMMITTED);
1854
1855         /* Program the pll values only for the master lane */
1856         for (i = 0; i < ARRAY_SIZE(pll_state->pll); i++)
1857                 intel_cx0_write(i915, encoder->port, INTEL_CX0_LANE0, PHY_C10_VDR_PLL(i),
1858                                 pll_state->pll[i],
1859                                 (i % 4) ? MB_WRITE_UNCOMMITTED : MB_WRITE_COMMITTED);
1860
1861         intel_cx0_write(i915, encoder->port, INTEL_CX0_LANE0, PHY_C10_VDR_CMN(0), pll_state->cmn, MB_WRITE_COMMITTED);
1862         intel_cx0_write(i915, encoder->port, INTEL_CX0_LANE0, PHY_C10_VDR_TX(0), pll_state->tx, MB_WRITE_COMMITTED);
1863
1864         intel_cx0_rmw(i915, encoder->port, INTEL_CX0_LANE0, PHY_C10_VDR_CONTROL(1),
1865                       0, C10_VDR_CTRL_MASTER_LANE | C10_VDR_CTRL_UPDATE_CFG,
1866                       MB_WRITE_COMMITTED);
1867 }
1868
1869 void intel_c10pll_dump_hw_state(struct drm_i915_private *i915,
1870                                 const struct intel_c10pll_state *hw_state)
1871 {
1872         bool fracen;
1873         int i;
1874         unsigned int frac_quot = 0, frac_rem = 0, frac_den = 1;
1875         unsigned int multiplier, tx_clk_div;
1876
1877         fracen = hw_state->pll[0] & C10_PLL0_FRACEN;
1878         drm_dbg_kms(&i915->drm, "c10pll_hw_state: fracen: %s, ",
1879                     str_yes_no(fracen));
1880
1881         if (fracen) {
1882                 frac_quot = hw_state->pll[12] << 8 | hw_state->pll[11];
1883                 frac_rem =  hw_state->pll[14] << 8 | hw_state->pll[13];
1884                 frac_den =  hw_state->pll[10] << 8 | hw_state->pll[9];
1885                 drm_dbg_kms(&i915->drm, "quot: %u, rem: %u, den: %u,\n",
1886                             frac_quot, frac_rem, frac_den);
1887         }
1888
1889         multiplier = (REG_FIELD_GET8(C10_PLL3_MULTIPLIERH_MASK, hw_state->pll[3]) << 8 |
1890                       hw_state->pll[2]) / 2 + 16;
1891         tx_clk_div = REG_FIELD_GET8(C10_PLL15_TXCLKDIV_MASK, hw_state->pll[15]);
1892         drm_dbg_kms(&i915->drm,
1893                     "multiplier: %u, tx_clk_div: %u.\n", multiplier, tx_clk_div);
1894
1895         drm_dbg_kms(&i915->drm, "c10pll_rawhw_state:");
1896         drm_dbg_kms(&i915->drm, "tx: 0x%x, cmn: 0x%x\n", hw_state->tx, hw_state->cmn);
1897
1898         BUILD_BUG_ON(ARRAY_SIZE(hw_state->pll) % 4);
1899         for (i = 0; i < ARRAY_SIZE(hw_state->pll); i = i + 4)
1900                 drm_dbg_kms(&i915->drm, "pll[%d] = 0x%x, pll[%d] = 0x%x, pll[%d] = 0x%x, pll[%d] = 0x%x\n",
1901                             i, hw_state->pll[i], i + 1, hw_state->pll[i + 1],
1902                             i + 2, hw_state->pll[i + 2], i + 3, hw_state->pll[i + 3]);
1903 }
1904
1905 static int intel_c20_compute_hdmi_tmds_pll(u64 pixel_clock, struct intel_c20pll_state *pll_state)
1906 {
1907         u64 datarate;
1908         u64 mpll_tx_clk_div;
1909         u64 vco_freq_shift;
1910         u64 vco_freq;
1911         u64 multiplier;
1912         u64 mpll_multiplier;
1913         u64 mpll_fracn_quot;
1914         u64 mpll_fracn_rem;
1915         u8  mpllb_ana_freq_vco;
1916         u8  mpll_div_multiplier;
1917
1918         if (pixel_clock < 25175 || pixel_clock > 600000)
1919                 return -EINVAL;
1920
1921         datarate = ((u64)pixel_clock * 1000) * 10;
1922         mpll_tx_clk_div = ilog2(div64_u64((u64)CLOCK_9999MHZ, (u64)datarate));
1923         vco_freq_shift = ilog2(div64_u64((u64)CLOCK_4999MHZ * (u64)256, (u64)datarate));
1924         vco_freq = (datarate << vco_freq_shift) >> 8;
1925         multiplier = div64_u64((vco_freq << 28), (REFCLK_38_4_MHZ >> 4));
1926         mpll_multiplier = 2 * (multiplier >> 32);
1927
1928         mpll_fracn_quot = (multiplier >> 16) & 0xFFFF;
1929         mpll_fracn_rem  = multiplier & 0xFFFF;
1930
1931         mpll_div_multiplier = min_t(u8, div64_u64((vco_freq * 16 + (datarate >> 1)),
1932                                                   datarate), 255);
1933
1934         if (vco_freq <= DATARATE_3000000000)
1935                 mpllb_ana_freq_vco = MPLLB_ANA_FREQ_VCO_3;
1936         else if (vco_freq <= DATARATE_3500000000)
1937                 mpllb_ana_freq_vco = MPLLB_ANA_FREQ_VCO_2;
1938         else if (vco_freq <= DATARATE_4000000000)
1939                 mpllb_ana_freq_vco = MPLLB_ANA_FREQ_VCO_1;
1940         else
1941                 mpllb_ana_freq_vco = MPLLB_ANA_FREQ_VCO_0;
1942
1943         pll_state->link_bit_rate        = pixel_clock;
1944         pll_state->clock        = pixel_clock;
1945         pll_state->tx[0]        = 0xbe88;
1946         pll_state->tx[1]        = 0x9800;
1947         pll_state->tx[2]        = 0x0000;
1948         pll_state->cmn[0]       = 0x0500;
1949         pll_state->cmn[1]       = 0x0005;
1950         pll_state->cmn[2]       = 0x0000;
1951         pll_state->cmn[3]       = 0x0000;
1952         pll_state->mpllb[0]     = (MPLL_TX_CLK_DIV(mpll_tx_clk_div) |
1953                                    MPLL_MULTIPLIER(mpll_multiplier));
1954         pll_state->mpllb[1]     = (CAL_DAC_CODE(CAL_DAC_CODE_31) |
1955                                    WORD_CLK_DIV |
1956                                    MPLL_DIV_MULTIPLIER(mpll_div_multiplier));
1957         pll_state->mpllb[2]     = (MPLLB_ANA_FREQ_VCO(mpllb_ana_freq_vco) |
1958                                    CP_PROP(CP_PROP_20) |
1959                                    CP_INT(CP_INT_6));
1960         pll_state->mpllb[3]     = (V2I(V2I_2) |
1961                                    CP_PROP_GS(CP_PROP_GS_30) |
1962                                    CP_INT_GS(CP_INT_GS_28));
1963         pll_state->mpllb[4]     = 0x0000;
1964         pll_state->mpllb[5]     = 0x0000;
1965         pll_state->mpllb[6]     = (C20_MPLLB_FRACEN | SSC_UP_SPREAD);
1966         pll_state->mpllb[7]     = MPLL_FRACN_DEN;
1967         pll_state->mpllb[8]     = mpll_fracn_quot;
1968         pll_state->mpllb[9]     = mpll_fracn_rem;
1969         pll_state->mpllb[10]    = HDMI_DIV(HDMI_DIV_1);
1970
1971         return 0;
1972 }
1973
1974 static int intel_c20_phy_check_hdmi_link_rate(int clock)
1975 {
1976         const struct intel_c20pll_state * const *tables = mtl_c20_hdmi_tables;
1977         int i;
1978
1979         for (i = 0; tables[i]; i++) {
1980                 if (clock == tables[i]->link_bit_rate)
1981                         return MODE_OK;
1982         }
1983
1984         if (clock >= 25175 && clock <= 594000)
1985                 return MODE_OK;
1986
1987         return MODE_CLOCK_RANGE;
1988 }
1989
1990 int intel_cx0_phy_check_hdmi_link_rate(struct intel_hdmi *hdmi, int clock)
1991 {
1992         struct intel_digital_port *dig_port = hdmi_to_dig_port(hdmi);
1993         struct drm_i915_private *i915 = intel_hdmi_to_i915(hdmi);
1994         enum phy phy = intel_port_to_phy(i915, dig_port->base.port);
1995
1996         if (intel_is_c10phy(i915, phy))
1997                 return intel_c10_phy_check_hdmi_link_rate(clock);
1998         return intel_c20_phy_check_hdmi_link_rate(clock);
1999 }
2000
2001 static const struct intel_c20pll_state * const *
2002 intel_c20_pll_tables_get(struct intel_crtc_state *crtc_state,
2003                          struct intel_encoder *encoder)
2004 {
2005         if (intel_crtc_has_dp_encoder(crtc_state))
2006                 return mtl_c20_dp_tables;
2007         else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
2008                 return mtl_c20_hdmi_tables;
2009
2010         MISSING_CASE(encoder->type);
2011         return NULL;
2012 }
2013
2014 static int intel_c20pll_calc_state(struct intel_crtc_state *crtc_state,
2015                                    struct intel_encoder *encoder)
2016 {
2017         const struct intel_c20pll_state * const *tables;
2018         int i;
2019
2020         /* try computed C20 HDMI tables before using consolidated tables */
2021         if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
2022                 if (intel_c20_compute_hdmi_tmds_pll(crtc_state->port_clock,
2023                                                     &crtc_state->cx0pll_state.c20) == 0)
2024                         return 0;
2025         }
2026
2027         tables = intel_c20_pll_tables_get(crtc_state, encoder);
2028         if (!tables)
2029                 return -EINVAL;
2030
2031         for (i = 0; tables[i]; i++) {
2032                 if (crtc_state->port_clock == tables[i]->link_bit_rate) {
2033                         crtc_state->cx0pll_state.c20 = *tables[i];
2034                         return 0;
2035                 }
2036         }
2037
2038         return -EINVAL;
2039 }
2040
2041 int intel_cx0pll_calc_state(struct intel_crtc_state *crtc_state,
2042                             struct intel_encoder *encoder)
2043 {
2044         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2045         enum phy phy = intel_port_to_phy(i915, encoder->port);
2046
2047         if (intel_is_c10phy(i915, phy))
2048                 return intel_c10pll_calc_state(crtc_state, encoder);
2049         return intel_c20pll_calc_state(crtc_state, encoder);
2050 }
2051
2052 static bool intel_c20_use_mplla(u32 clock)
2053 {
2054         /* 10G and 20G rates use MPLLA */
2055         if (clock == 312500 || clock == 625000)
2056                 return true;
2057
2058         return false;
2059 }
2060
2061 void intel_c20pll_readout_hw_state(struct intel_encoder *encoder,
2062                                    struct intel_c20pll_state *pll_state)
2063 {
2064         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2065         bool cntx;
2066         intel_wakeref_t wakeref;
2067         int i;
2068
2069         wakeref = intel_cx0_phy_transaction_begin(encoder);
2070
2071         /* 1. Read current context selection */
2072         cntx = intel_cx0_read(i915, encoder->port, INTEL_CX0_LANE0, PHY_C20_VDR_CUSTOM_SERDES_RATE) & PHY_C20_CONTEXT_TOGGLE;
2073
2074         /* Read Tx configuration */
2075         for (i = 0; i < ARRAY_SIZE(pll_state->tx); i++) {
2076                 if (cntx)
2077                         pll_state->tx[i] = intel_c20_sram_read(i915, encoder->port, INTEL_CX0_LANE0,
2078                                                                PHY_C20_B_TX_CNTX_CFG(i));
2079                 else
2080                         pll_state->tx[i] = intel_c20_sram_read(i915, encoder->port, INTEL_CX0_LANE0,
2081                                                                PHY_C20_A_TX_CNTX_CFG(i));
2082         }
2083
2084         /* Read common configuration */
2085         for (i = 0; i < ARRAY_SIZE(pll_state->cmn); i++) {
2086                 if (cntx)
2087                         pll_state->cmn[i] = intel_c20_sram_read(i915, encoder->port, INTEL_CX0_LANE0,
2088                                                                 PHY_C20_B_CMN_CNTX_CFG(i));
2089                 else
2090                         pll_state->cmn[i] = intel_c20_sram_read(i915, encoder->port, INTEL_CX0_LANE0,
2091                                                                 PHY_C20_A_CMN_CNTX_CFG(i));
2092         }
2093
2094         if (pll_state->tx[0] & C20_PHY_USE_MPLLB) {
2095                 /* MPLLB configuration */
2096                 for (i = 0; i < ARRAY_SIZE(pll_state->mpllb); i++) {
2097                         if (cntx)
2098                                 pll_state->mpllb[i] = intel_c20_sram_read(i915, encoder->port, INTEL_CX0_LANE0,
2099                                                                           PHY_C20_B_MPLLB_CNTX_CFG(i));
2100                         else
2101                                 pll_state->mpllb[i] = intel_c20_sram_read(i915, encoder->port, INTEL_CX0_LANE0,
2102                                                                           PHY_C20_A_MPLLB_CNTX_CFG(i));
2103                 }
2104         } else {
2105                 /* MPLLA configuration */
2106                 for (i = 0; i < ARRAY_SIZE(pll_state->mplla); i++) {
2107                         if (cntx)
2108                                 pll_state->mplla[i] = intel_c20_sram_read(i915, encoder->port, INTEL_CX0_LANE0,
2109                                                                           PHY_C20_B_MPLLA_CNTX_CFG(i));
2110                         else
2111                                 pll_state->mplla[i] = intel_c20_sram_read(i915, encoder->port, INTEL_CX0_LANE0,
2112                                                                           PHY_C20_A_MPLLA_CNTX_CFG(i));
2113                 }
2114         }
2115
2116         intel_cx0_phy_transaction_end(encoder, wakeref);
2117 }
2118
2119 void intel_c20pll_dump_hw_state(struct drm_i915_private *i915,
2120                                 const struct intel_c20pll_state *hw_state)
2121 {
2122         int i;
2123
2124         drm_dbg_kms(&i915->drm, "c20pll_hw_state:\n");
2125         drm_dbg_kms(&i915->drm, "tx[0] = 0x%.4x, tx[1] = 0x%.4x, tx[2] = 0x%.4x\n",
2126                     hw_state->tx[0], hw_state->tx[1], hw_state->tx[2]);
2127         drm_dbg_kms(&i915->drm, "cmn[0] = 0x%.4x, cmn[1] = 0x%.4x, cmn[2] = 0x%.4x, cmn[3] = 0x%.4x\n",
2128                     hw_state->cmn[0], hw_state->cmn[1], hw_state->cmn[2], hw_state->cmn[3]);
2129
2130         if (intel_c20_use_mplla(hw_state->clock)) {
2131                 for (i = 0; i < ARRAY_SIZE(hw_state->mplla); i++)
2132                         drm_dbg_kms(&i915->drm, "mplla[%d] = 0x%.4x\n", i, hw_state->mplla[i]);
2133         } else {
2134                 for (i = 0; i < ARRAY_SIZE(hw_state->mpllb); i++)
2135                         drm_dbg_kms(&i915->drm, "mpllb[%d] = 0x%.4x\n", i, hw_state->mpllb[i]);
2136         }
2137 }
2138
2139 static u8 intel_c20_get_dp_rate(u32 clock)
2140 {
2141         switch (clock) {
2142         case 162000: /* 1.62 Gbps DP1.4 */
2143                 return 0;
2144         case 270000: /* 2.7 Gbps DP1.4 */
2145                 return 1;
2146         case 540000: /* 5.4 Gbps DP 1.4 */
2147                 return 2;
2148         case 810000: /* 8.1 Gbps DP1.4 */
2149                 return 3;
2150         case 216000: /* 2.16 Gbps eDP */
2151                 return 4;
2152         case 243000: /* 2.43 Gbps eDP */
2153                 return 5;
2154         case 324000: /* 3.24 Gbps eDP */
2155                 return 6;
2156         case 432000: /* 4.32 Gbps eDP */
2157                 return 7;
2158         case 312500: /* 10 Gbps DP2.0 */
2159                 return 8;
2160         case 421875: /* 13.5 Gbps DP2.0 */
2161                 return 9;
2162         case 625000: /* 20 Gbps DP2.0*/
2163                 return 10;
2164         case 648000: /* 6.48 Gbps eDP*/
2165                 return 11;
2166         case 675000: /* 6.75 Gbps eDP*/
2167                 return 12;
2168         default:
2169                 MISSING_CASE(clock);
2170                 return 0;
2171         }
2172 }
2173
2174 static u8 intel_c20_get_hdmi_rate(u32 clock)
2175 {
2176         if (clock >= 25175 && clock <= 600000)
2177                 return 0;
2178
2179         switch (clock) {
2180         case 166670: /* 3 Gbps */
2181         case 333330: /* 6 Gbps */
2182         case 666670: /* 12 Gbps */
2183                 return 1;
2184         case 444440: /* 8 Gbps */
2185                 return 2;
2186         case 555560: /* 10 Gbps */
2187                 return 3;
2188         default:
2189                 MISSING_CASE(clock);
2190                 return 0;
2191         }
2192 }
2193
2194 static bool is_dp2(u32 clock)
2195 {
2196         /* DP2.0 clock rates */
2197         if (clock == 312500 || clock == 421875 || clock  == 625000)
2198                 return true;
2199
2200         return false;
2201 }
2202
2203 static bool is_hdmi_frl(u32 clock)
2204 {
2205         switch (clock) {
2206         case 166670: /* 3 Gbps */
2207         case 333330: /* 6 Gbps */
2208         case 444440: /* 8 Gbps */
2209         case 555560: /* 10 Gbps */
2210         case 666670: /* 12 Gbps */
2211                 return true;
2212         default:
2213                 return false;
2214         }
2215 }
2216
2217 static bool intel_c20_protocol_switch_valid(struct intel_encoder *encoder)
2218 {
2219         struct intel_digital_port *intel_dig_port = enc_to_dig_port(encoder);
2220
2221         /* banks should not be cleared for DPALT/USB4/TBT modes */
2222         /* TODO: optimize re-calibration in legacy mode */
2223         return intel_tc_port_in_legacy_mode(intel_dig_port);
2224 }
2225
2226 static int intel_get_c20_custom_width(u32 clock, bool dp)
2227 {
2228         if (dp && is_dp2(clock))
2229                 return 2;
2230         else if (is_hdmi_frl(clock))
2231                 return 1;
2232         else
2233                 return 0;
2234 }
2235
2236 static void intel_c20_pll_program(struct drm_i915_private *i915,
2237                                   const struct intel_crtc_state *crtc_state,
2238                                   struct intel_encoder *encoder)
2239 {
2240         const struct intel_c20pll_state *pll_state = &crtc_state->cx0pll_state.c20;
2241         bool dp = false;
2242         int lane = crtc_state->lane_count > 2 ? INTEL_CX0_BOTH_LANES : INTEL_CX0_LANE0;
2243         bool cntx;
2244         int i;
2245
2246         if (intel_crtc_has_dp_encoder(crtc_state))
2247                 dp = true;
2248
2249         /* 1. Read current context selection */
2250         cntx = intel_cx0_read(i915, encoder->port, INTEL_CX0_LANE0, PHY_C20_VDR_CUSTOM_SERDES_RATE) & BIT(0);
2251
2252         /*
2253          * 2. If there is a protocol switch from HDMI to DP or vice versa, clear
2254          * the lane #0 MPLLB CAL_DONE_BANK DP2.0 10G and 20G rates enable MPLLA.
2255          * Protocol switch is only applicable for MPLLA
2256          */
2257         if (intel_c20_protocol_switch_valid(encoder)) {
2258                 for (i = 0; i < 4; i++)
2259                         intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0, RAWLANEAONX_DIG_TX_MPLLB_CAL_DONE_BANK(i), 0);
2260                 usleep_range(4000, 4100);
2261         }
2262
2263         /* 3. Write SRAM configuration context. If A in use, write configuration to B context */
2264         /* 3.1 Tx configuration */
2265         for (i = 0; i < ARRAY_SIZE(pll_state->tx); i++) {
2266                 if (cntx)
2267                         intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0, PHY_C20_A_TX_CNTX_CFG(i), pll_state->tx[i]);
2268                 else
2269                         intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0, PHY_C20_B_TX_CNTX_CFG(i), pll_state->tx[i]);
2270         }
2271
2272         /* 3.2 common configuration */
2273         for (i = 0; i < ARRAY_SIZE(pll_state->cmn); i++) {
2274                 if (cntx)
2275                         intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0, PHY_C20_A_CMN_CNTX_CFG(i), pll_state->cmn[i]);
2276                 else
2277                         intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0, PHY_C20_B_CMN_CNTX_CFG(i), pll_state->cmn[i]);
2278         }
2279
2280         /* 3.3 mpllb or mplla configuration */
2281         if (intel_c20_use_mplla(pll_state->clock)) {
2282                 for (i = 0; i < ARRAY_SIZE(pll_state->mplla); i++) {
2283                         if (cntx)
2284                                 intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0,
2285                                                      PHY_C20_A_MPLLA_CNTX_CFG(i),
2286                                                      pll_state->mplla[i]);
2287                         else
2288                                 intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0,
2289                                                      PHY_C20_B_MPLLA_CNTX_CFG(i),
2290                                                      pll_state->mplla[i]);
2291                 }
2292         } else {
2293                 for (i = 0; i < ARRAY_SIZE(pll_state->mpllb); i++) {
2294                         if (cntx)
2295                                 intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0,
2296                                                      PHY_C20_A_MPLLB_CNTX_CFG(i),
2297                                                      pll_state->mpllb[i]);
2298                         else
2299                                 intel_c20_sram_write(i915, encoder->port, INTEL_CX0_LANE0,
2300                                                      PHY_C20_B_MPLLB_CNTX_CFG(i),
2301                                                      pll_state->mpllb[i]);
2302                 }
2303         }
2304
2305         /* 4. Program custom width to match the link protocol */
2306         intel_cx0_rmw(i915, encoder->port, lane, PHY_C20_VDR_CUSTOM_WIDTH,
2307                       PHY_C20_CUSTOM_WIDTH_MASK,
2308                       PHY_C20_CUSTOM_WIDTH(intel_get_c20_custom_width(pll_state->clock, dp)),
2309                       MB_WRITE_COMMITTED);
2310
2311         /* 5. For DP or 6. For HDMI */
2312         if (dp) {
2313                 intel_cx0_rmw(i915, encoder->port, lane, PHY_C20_VDR_CUSTOM_SERDES_RATE,
2314                               BIT(6) | PHY_C20_CUSTOM_SERDES_MASK,
2315                               BIT(6) | PHY_C20_CUSTOM_SERDES(intel_c20_get_dp_rate(pll_state->clock)),
2316                               MB_WRITE_COMMITTED);
2317         } else {
2318                 intel_cx0_rmw(i915, encoder->port, lane, PHY_C20_VDR_CUSTOM_SERDES_RATE,
2319                               BIT(7) | PHY_C20_CUSTOM_SERDES_MASK,
2320                               is_hdmi_frl(pll_state->clock) ? BIT(7) : 0,
2321                               MB_WRITE_COMMITTED);
2322
2323                 intel_cx0_write(i915, encoder->port, INTEL_CX0_BOTH_LANES, PHY_C20_VDR_HDMI_RATE,
2324                                 intel_c20_get_hdmi_rate(pll_state->clock),
2325                                 MB_WRITE_COMMITTED);
2326         }
2327
2328         /*
2329          * 7. Write Vendor specific registers to toggle context setting to load
2330          * the updated programming toggle context bit
2331          */
2332         intel_cx0_rmw(i915, encoder->port, lane, PHY_C20_VDR_CUSTOM_SERDES_RATE,
2333                       BIT(0), cntx ? 0 : 1, MB_WRITE_COMMITTED);
2334 }
2335
2336 int intel_c10pll_calc_port_clock(struct intel_encoder *encoder,
2337                                  const struct intel_c10pll_state *pll_state)
2338 {
2339         unsigned int frac_quot = 0, frac_rem = 0, frac_den = 1;
2340         unsigned int multiplier, tx_clk_div, hdmi_div, refclk = 38400;
2341         int tmpclk = 0;
2342
2343         if (pll_state->pll[0] & C10_PLL0_FRACEN) {
2344                 frac_quot = pll_state->pll[12] << 8 | pll_state->pll[11];
2345                 frac_rem =  pll_state->pll[14] << 8 | pll_state->pll[13];
2346                 frac_den =  pll_state->pll[10] << 8 | pll_state->pll[9];
2347         }
2348
2349         multiplier = (REG_FIELD_GET8(C10_PLL3_MULTIPLIERH_MASK, pll_state->pll[3]) << 8 |
2350                       pll_state->pll[2]) / 2 + 16;
2351
2352         tx_clk_div = REG_FIELD_GET8(C10_PLL15_TXCLKDIV_MASK, pll_state->pll[15]);
2353         hdmi_div = REG_FIELD_GET8(C10_PLL15_HDMIDIV_MASK, pll_state->pll[15]);
2354
2355         tmpclk = DIV_ROUND_CLOSEST_ULL(mul_u32_u32(refclk, (multiplier << 16) + frac_quot) +
2356                                      DIV_ROUND_CLOSEST(refclk * frac_rem, frac_den),
2357                                      10 << (tx_clk_div + 16));
2358         tmpclk *= (hdmi_div ? 2 : 1);
2359
2360         return tmpclk;
2361 }
2362
2363 int intel_c20pll_calc_port_clock(struct intel_encoder *encoder,
2364                                  const struct intel_c20pll_state *pll_state)
2365 {
2366         unsigned int frac, frac_en, frac_quot, frac_rem, frac_den;
2367         unsigned int multiplier, refclk = 38400;
2368         unsigned int tx_clk_div;
2369         unsigned int ref_clk_mpllb_div;
2370         unsigned int fb_clk_div4_en;
2371         unsigned int ref, vco;
2372         unsigned int tx_rate_mult;
2373         unsigned int tx_rate = REG_FIELD_GET(C20_PHY_TX_RATE, pll_state->tx[0]);
2374
2375         if (pll_state->tx[0] & C20_PHY_USE_MPLLB) {
2376                 tx_rate_mult = 1;
2377                 frac_en = REG_FIELD_GET(C20_MPLLB_FRACEN, pll_state->mpllb[6]);
2378                 frac_quot = pll_state->mpllb[8];
2379                 frac_rem =  pll_state->mpllb[9];
2380                 frac_den =  pll_state->mpllb[7];
2381                 multiplier = REG_FIELD_GET(C20_MULTIPLIER_MASK, pll_state->mpllb[0]);
2382                 tx_clk_div = REG_FIELD_GET(C20_MPLLB_TX_CLK_DIV_MASK, pll_state->mpllb[0]);
2383                 ref_clk_mpllb_div = REG_FIELD_GET(C20_REF_CLK_MPLLB_DIV_MASK, pll_state->mpllb[6]);
2384                 fb_clk_div4_en = 0;
2385         } else {
2386                 tx_rate_mult = 2;
2387                 frac_en = REG_FIELD_GET(C20_MPLLA_FRACEN, pll_state->mplla[6]);
2388                 frac_quot = pll_state->mplla[8];
2389                 frac_rem =  pll_state->mplla[9];
2390                 frac_den =  pll_state->mplla[7];
2391                 multiplier = REG_FIELD_GET(C20_MULTIPLIER_MASK, pll_state->mplla[0]);
2392                 tx_clk_div = REG_FIELD_GET(C20_MPLLA_TX_CLK_DIV_MASK, pll_state->mplla[1]);
2393                 ref_clk_mpllb_div = REG_FIELD_GET(C20_REF_CLK_MPLLB_DIV_MASK, pll_state->mplla[6]);
2394                 fb_clk_div4_en = REG_FIELD_GET(C20_FB_CLK_DIV4_EN, pll_state->mplla[0]);
2395         }
2396
2397         if (frac_en)
2398                 frac = frac_quot + DIV_ROUND_CLOSEST(frac_rem, frac_den);
2399         else
2400                 frac = 0;
2401
2402         ref = DIV_ROUND_CLOSEST(refclk * (1 << (1 + fb_clk_div4_en)), 1 << ref_clk_mpllb_div);
2403         vco = DIV_ROUND_CLOSEST_ULL(mul_u32_u32(ref, (multiplier << (17 - 2)) + frac) >> 17, 10);
2404
2405         return vco << tx_rate_mult >> tx_clk_div >> tx_rate;
2406 }
2407
2408 static void intel_program_port_clock_ctl(struct intel_encoder *encoder,
2409                                          const struct intel_crtc_state *crtc_state,
2410                                          bool lane_reversal)
2411 {
2412         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2413         u32 val = 0;
2414
2415         intel_de_rmw(i915, XELPDP_PORT_BUF_CTL1(encoder->port), XELPDP_PORT_REVERSAL,
2416                      lane_reversal ? XELPDP_PORT_REVERSAL : 0);
2417
2418         if (lane_reversal)
2419                 val |= XELPDP_LANE1_PHY_CLOCK_SELECT;
2420
2421         val |= XELPDP_FORWARD_CLOCK_UNGATE;
2422
2423         if (is_hdmi_frl(crtc_state->port_clock))
2424                 val |= XELPDP_DDI_CLOCK_SELECT(XELPDP_DDI_CLOCK_SELECT_DIV18CLK);
2425         else
2426                 val |= XELPDP_DDI_CLOCK_SELECT(XELPDP_DDI_CLOCK_SELECT_MAXPCLK);
2427
2428         /* TODO: HDMI FRL */
2429         /* DP2.0 10G and 20G rates enable MPLLA*/
2430         if (crtc_state->port_clock == 1000000 || crtc_state->port_clock == 2000000)
2431                 val |= crtc_state->cx0pll_state.ssc_enabled ? XELPDP_SSC_ENABLE_PLLA : 0;
2432         else
2433                 val |= crtc_state->cx0pll_state.ssc_enabled ? XELPDP_SSC_ENABLE_PLLB : 0;
2434
2435         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2436                      XELPDP_LANE1_PHY_CLOCK_SELECT | XELPDP_FORWARD_CLOCK_UNGATE |
2437                      XELPDP_DDI_CLOCK_SELECT_MASK | XELPDP_SSC_ENABLE_PLLA |
2438                      XELPDP_SSC_ENABLE_PLLB, val);
2439 }
2440
2441 static u32 intel_cx0_get_powerdown_update(u8 lane_mask)
2442 {
2443         u32 val = 0;
2444         int lane = 0;
2445
2446         for_each_cx0_lane_in_mask(lane_mask, lane)
2447                 val |= XELPDP_LANE_POWERDOWN_UPDATE(lane);
2448
2449         return val;
2450 }
2451
2452 static u32 intel_cx0_get_powerdown_state(u8 lane_mask, u8 state)
2453 {
2454         u32 val = 0;
2455         int lane = 0;
2456
2457         for_each_cx0_lane_in_mask(lane_mask, lane)
2458                 val |= XELPDP_LANE_POWERDOWN_NEW_STATE(lane, state);
2459
2460         return val;
2461 }
2462
2463 static void intel_cx0_powerdown_change_sequence(struct drm_i915_private *i915,
2464                                                 enum port port,
2465                                                 u8 lane_mask, u8 state)
2466 {
2467         enum phy phy = intel_port_to_phy(i915, port);
2468         int lane;
2469
2470         intel_de_rmw(i915, XELPDP_PORT_BUF_CTL2(port),
2471                      intel_cx0_get_powerdown_state(INTEL_CX0_BOTH_LANES, XELPDP_LANE_POWERDOWN_NEW_STATE_MASK),
2472                      intel_cx0_get_powerdown_state(lane_mask, state));
2473
2474         /* Wait for pending transactions.*/
2475         for_each_cx0_lane_in_mask(lane_mask, lane)
2476                 if (intel_de_wait_for_clear(i915, XELPDP_PORT_M2P_MSGBUS_CTL(port, lane),
2477                                             XELPDP_PORT_M2P_TRANSACTION_PENDING,
2478                                             XELPDP_MSGBUS_TIMEOUT_SLOW)) {
2479                         drm_dbg_kms(&i915->drm,
2480                                     "PHY %c Timeout waiting for previous transaction to complete. Reset the bus.\n",
2481                                     phy_name(phy));
2482                         intel_cx0_bus_reset(i915, port, lane);
2483                 }
2484
2485         intel_de_rmw(i915, XELPDP_PORT_BUF_CTL2(port),
2486                      intel_cx0_get_powerdown_update(INTEL_CX0_BOTH_LANES),
2487                      intel_cx0_get_powerdown_update(lane_mask));
2488
2489         /* Update Timeout Value */
2490         if (__intel_de_wait_for_register(i915, XELPDP_PORT_BUF_CTL2(port),
2491                                          intel_cx0_get_powerdown_update(lane_mask), 0,
2492                                          XELPDP_PORT_POWERDOWN_UPDATE_TIMEOUT_US, 0, NULL))
2493                 drm_warn(&i915->drm, "PHY %c failed to bring out of Lane reset after %dus.\n",
2494                          phy_name(phy), XELPDP_PORT_RESET_START_TIMEOUT_US);
2495 }
2496
2497 static void intel_cx0_setup_powerdown(struct drm_i915_private *i915, enum port port)
2498 {
2499         intel_de_rmw(i915, XELPDP_PORT_BUF_CTL2(port),
2500                      XELPDP_POWER_STATE_READY_MASK,
2501                      XELPDP_POWER_STATE_READY(CX0_P2_STATE_READY));
2502         intel_de_rmw(i915, XELPDP_PORT_BUF_CTL3(port),
2503                      XELPDP_POWER_STATE_ACTIVE_MASK |
2504                      XELPDP_PLL_LANE_STAGGERING_DELAY_MASK,
2505                      XELPDP_POWER_STATE_ACTIVE(CX0_P0_STATE_ACTIVE) |
2506                      XELPDP_PLL_LANE_STAGGERING_DELAY(0));
2507 }
2508
2509 static u32 intel_cx0_get_pclk_refclk_request(u8 lane_mask)
2510 {
2511         u32 val = 0;
2512         int lane = 0;
2513
2514         for_each_cx0_lane_in_mask(lane_mask, lane)
2515                 val |= XELPDP_LANE_PCLK_REFCLK_REQUEST(lane);
2516
2517         return val;
2518 }
2519
2520 static u32 intel_cx0_get_pclk_refclk_ack(u8 lane_mask)
2521 {
2522         u32 val = 0;
2523         int lane = 0;
2524
2525         for_each_cx0_lane_in_mask(lane_mask, lane)
2526                 val |= XELPDP_LANE_PCLK_REFCLK_ACK(lane);
2527
2528         return val;
2529 }
2530
2531 static void intel_cx0_phy_lane_reset(struct drm_i915_private *i915,
2532                                      struct intel_encoder *encoder,
2533                                      bool lane_reversal)
2534 {
2535         enum port port = encoder->port;
2536         enum phy phy = intel_port_to_phy(i915, port);
2537         bool both_lanes =  intel_tc_port_fia_max_lane_count(enc_to_dig_port(encoder)) > 2;
2538         u8 lane_mask = lane_reversal ? INTEL_CX0_LANE1 :
2539                                   INTEL_CX0_LANE0;
2540         u32 lane_pipe_reset = both_lanes ?
2541                               XELPDP_LANE_PIPE_RESET(0) |
2542                               XELPDP_LANE_PIPE_RESET(1) :
2543                               XELPDP_LANE_PIPE_RESET(0);
2544         u32 lane_phy_current_status = both_lanes ?
2545                                       XELPDP_LANE_PHY_CURRENT_STATUS(0) |
2546                                       XELPDP_LANE_PHY_CURRENT_STATUS(1) :
2547                                       XELPDP_LANE_PHY_CURRENT_STATUS(0);
2548
2549         if (__intel_de_wait_for_register(i915, XELPDP_PORT_BUF_CTL1(port),
2550                                          XELPDP_PORT_BUF_SOC_PHY_READY,
2551                                          XELPDP_PORT_BUF_SOC_PHY_READY,
2552                                          XELPDP_PORT_BUF_SOC_READY_TIMEOUT_US, 0, NULL))
2553                 drm_warn(&i915->drm, "PHY %c failed to bring out of SOC reset after %dus.\n",
2554                          phy_name(phy), XELPDP_PORT_BUF_SOC_READY_TIMEOUT_US);
2555
2556         intel_de_rmw(i915, XELPDP_PORT_BUF_CTL2(port),
2557                      XELPDP_LANE_PIPE_RESET(0) | XELPDP_LANE_PIPE_RESET(1),
2558                      lane_pipe_reset);
2559
2560         if (__intel_de_wait_for_register(i915, XELPDP_PORT_BUF_CTL2(port),
2561                                          lane_phy_current_status, lane_phy_current_status,
2562                                          XELPDP_PORT_RESET_START_TIMEOUT_US, 0, NULL))
2563                 drm_warn(&i915->drm, "PHY %c failed to bring out of Lane reset after %dus.\n",
2564                          phy_name(phy), XELPDP_PORT_RESET_START_TIMEOUT_US);
2565
2566         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(port),
2567                      intel_cx0_get_pclk_refclk_request(both_lanes ?
2568                                                        INTEL_CX0_BOTH_LANES :
2569                                                        INTEL_CX0_LANE0),
2570                      intel_cx0_get_pclk_refclk_request(lane_mask));
2571
2572         if (__intel_de_wait_for_register(i915, XELPDP_PORT_CLOCK_CTL(port),
2573                                          intel_cx0_get_pclk_refclk_ack(both_lanes ?
2574                                                                        INTEL_CX0_BOTH_LANES :
2575                                                                        INTEL_CX0_LANE0),
2576                                          intel_cx0_get_pclk_refclk_ack(lane_mask),
2577                                          XELPDP_REFCLK_ENABLE_TIMEOUT_US, 0, NULL))
2578                 drm_warn(&i915->drm, "PHY %c failed to request refclk after %dus.\n",
2579                          phy_name(phy), XELPDP_REFCLK_ENABLE_TIMEOUT_US);
2580
2581         intel_cx0_powerdown_change_sequence(i915, port, INTEL_CX0_BOTH_LANES,
2582                                             CX0_P2_STATE_RESET);
2583         intel_cx0_setup_powerdown(i915, port);
2584
2585         intel_de_rmw(i915, XELPDP_PORT_BUF_CTL2(port), lane_pipe_reset, 0);
2586
2587         if (intel_de_wait_for_clear(i915, XELPDP_PORT_BUF_CTL2(port), lane_phy_current_status,
2588                                     XELPDP_PORT_RESET_END_TIMEOUT))
2589                 drm_warn(&i915->drm, "PHY %c failed to bring out of Lane reset after %dms.\n",
2590                          phy_name(phy), XELPDP_PORT_RESET_END_TIMEOUT);
2591 }
2592
2593 static void intel_cx0_program_phy_lane(struct drm_i915_private *i915,
2594                                        struct intel_encoder *encoder, int lane_count,
2595                                        bool lane_reversal)
2596 {
2597         u8 l0t1, l0t2, l1t1, l1t2;
2598         bool dp_alt_mode = intel_tc_port_in_dp_alt_mode(enc_to_dig_port(encoder));
2599         enum port port = encoder->port;
2600
2601         if (intel_is_c10phy(i915, intel_port_to_phy(i915, port)))
2602                 intel_cx0_rmw(i915, port, INTEL_CX0_BOTH_LANES,
2603                               PHY_C10_VDR_CONTROL(1), 0,
2604                               C10_VDR_CTRL_MSGBUS_ACCESS,
2605                               MB_WRITE_COMMITTED);
2606
2607         /* TODO: DP-alt MFD case where only one PHY lane should be programmed. */
2608         l0t1 = intel_cx0_read(i915, port, INTEL_CX0_LANE0, PHY_CX0_TX_CONTROL(1, 2));
2609         l0t2 = intel_cx0_read(i915, port, INTEL_CX0_LANE0, PHY_CX0_TX_CONTROL(2, 2));
2610         l1t1 = intel_cx0_read(i915, port, INTEL_CX0_LANE1, PHY_CX0_TX_CONTROL(1, 2));
2611         l1t2 = intel_cx0_read(i915, port, INTEL_CX0_LANE1, PHY_CX0_TX_CONTROL(2, 2));
2612
2613         l0t1 |= CONTROL2_DISABLE_SINGLE_TX;
2614         l0t2 |= CONTROL2_DISABLE_SINGLE_TX;
2615         l1t1 |= CONTROL2_DISABLE_SINGLE_TX;
2616         l1t2 |= CONTROL2_DISABLE_SINGLE_TX;
2617
2618         if (lane_reversal) {
2619                 switch (lane_count) {
2620                 case 4:
2621                         l0t1 &= ~CONTROL2_DISABLE_SINGLE_TX;
2622                         fallthrough;
2623                 case 3:
2624                         l0t2 &= ~CONTROL2_DISABLE_SINGLE_TX;
2625                         fallthrough;
2626                 case 2:
2627                         l1t1 &= ~CONTROL2_DISABLE_SINGLE_TX;
2628                         fallthrough;
2629                 case 1:
2630                         l1t2 &= ~CONTROL2_DISABLE_SINGLE_TX;
2631                         break;
2632                 default:
2633                         MISSING_CASE(lane_count);
2634                 }
2635         } else {
2636                 switch (lane_count) {
2637                 case 4:
2638                         l1t2 &= ~CONTROL2_DISABLE_SINGLE_TX;
2639                         fallthrough;
2640                 case 3:
2641                         l1t1 &= ~CONTROL2_DISABLE_SINGLE_TX;
2642                         fallthrough;
2643                 case 2:
2644                         l0t2 &= ~CONTROL2_DISABLE_SINGLE_TX;
2645                         l0t1 &= ~CONTROL2_DISABLE_SINGLE_TX;
2646                         break;
2647                 case 1:
2648                         if (dp_alt_mode)
2649                                 l0t2 &= ~CONTROL2_DISABLE_SINGLE_TX;
2650                         else
2651                                 l0t1 &= ~CONTROL2_DISABLE_SINGLE_TX;
2652                         break;
2653                 default:
2654                         MISSING_CASE(lane_count);
2655                 }
2656         }
2657
2658         /* disable MLs */
2659         intel_cx0_write(i915, port, INTEL_CX0_LANE0, PHY_CX0_TX_CONTROL(1, 2),
2660                         l0t1, MB_WRITE_COMMITTED);
2661         intel_cx0_write(i915, port, INTEL_CX0_LANE0, PHY_CX0_TX_CONTROL(2, 2),
2662                         l0t2, MB_WRITE_COMMITTED);
2663         intel_cx0_write(i915, port, INTEL_CX0_LANE1, PHY_CX0_TX_CONTROL(1, 2),
2664                         l1t1, MB_WRITE_COMMITTED);
2665         intel_cx0_write(i915, port, INTEL_CX0_LANE1, PHY_CX0_TX_CONTROL(2, 2),
2666                         l1t2, MB_WRITE_COMMITTED);
2667
2668         if (intel_is_c10phy(i915, intel_port_to_phy(i915, port)))
2669                 intel_cx0_rmw(i915, port, INTEL_CX0_BOTH_LANES,
2670                               PHY_C10_VDR_CONTROL(1), 0,
2671                               C10_VDR_CTRL_UPDATE_CFG,
2672                               MB_WRITE_COMMITTED);
2673 }
2674
2675 static u32 intel_cx0_get_pclk_pll_request(u8 lane_mask)
2676 {
2677         u32 val = 0;
2678         int lane = 0;
2679
2680         for_each_cx0_lane_in_mask(lane_mask, lane)
2681                 val |= XELPDP_LANE_PCLK_PLL_REQUEST(lane);
2682
2683         return val;
2684 }
2685
2686 static u32 intel_cx0_get_pclk_pll_ack(u8 lane_mask)
2687 {
2688         u32 val = 0;
2689         int lane = 0;
2690
2691         for_each_cx0_lane_in_mask(lane_mask, lane)
2692                 val |= XELPDP_LANE_PCLK_PLL_ACK(lane);
2693
2694         return val;
2695 }
2696
2697 static void intel_cx0pll_enable(struct intel_encoder *encoder,
2698                                 const struct intel_crtc_state *crtc_state)
2699 {
2700         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2701         enum phy phy = intel_port_to_phy(i915, encoder->port);
2702         struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2703         bool lane_reversal = dig_port->saved_port_bits & DDI_BUF_PORT_REVERSAL;
2704         u8 maxpclk_lane = lane_reversal ? INTEL_CX0_LANE1 :
2705                                           INTEL_CX0_LANE0;
2706         intel_wakeref_t wakeref = intel_cx0_phy_transaction_begin(encoder);
2707
2708         /*
2709          * 1. Program PORT_CLOCK_CTL REGISTER to configure
2710          * clock muxes, gating and SSC
2711          */
2712         intel_program_port_clock_ctl(encoder, crtc_state, lane_reversal);
2713
2714         /* 2. Bring PHY out of reset. */
2715         intel_cx0_phy_lane_reset(i915, encoder, lane_reversal);
2716
2717         /*
2718          * 3. Change Phy power state to Ready.
2719          * TODO: For DP alt mode use only one lane.
2720          */
2721         intel_cx0_powerdown_change_sequence(i915, encoder->port, INTEL_CX0_BOTH_LANES,
2722                                             CX0_P2_STATE_READY);
2723
2724         /* 4. Program PHY internal PLL internal registers. */
2725         if (intel_is_c10phy(i915, phy))
2726                 intel_c10_pll_program(i915, crtc_state, encoder);
2727         else
2728                 intel_c20_pll_program(i915, crtc_state, encoder);
2729
2730         /*
2731          * 5. Program the enabled and disabled owned PHY lane
2732          * transmitters over message bus
2733          */
2734         intel_cx0_program_phy_lane(i915, encoder, crtc_state->lane_count, lane_reversal);
2735
2736         /*
2737          * 6. Follow the Display Voltage Frequency Switching - Sequence
2738          * Before Frequency Change. We handle this step in bxt_set_cdclk().
2739          */
2740
2741         /*
2742          * 7. Program DDI_CLK_VALFREQ to match intended DDI
2743          * clock frequency.
2744          */
2745         intel_de_write(i915, DDI_CLK_VALFREQ(encoder->port),
2746                        crtc_state->port_clock);
2747
2748         /*
2749          * 8. Set PORT_CLOCK_CTL register PCLK PLL Request
2750          * LN<Lane for maxPCLK> to "1" to enable PLL.
2751          */
2752         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2753                      intel_cx0_get_pclk_pll_request(INTEL_CX0_BOTH_LANES),
2754                      intel_cx0_get_pclk_pll_request(maxpclk_lane));
2755
2756         /* 9. Poll on PORT_CLOCK_CTL PCLK PLL Ack LN<Lane for maxPCLK> == "1". */
2757         if (__intel_de_wait_for_register(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2758                                          intel_cx0_get_pclk_pll_ack(INTEL_CX0_BOTH_LANES),
2759                                          intel_cx0_get_pclk_pll_ack(maxpclk_lane),
2760                                          XELPDP_PCLK_PLL_ENABLE_TIMEOUT_US, 0, NULL))
2761                 drm_warn(&i915->drm, "Port %c PLL not locked after %dus.\n",
2762                          phy_name(phy), XELPDP_PCLK_PLL_ENABLE_TIMEOUT_US);
2763
2764         /*
2765          * 10. Follow the Display Voltage Frequency Switching Sequence After
2766          * Frequency Change. We handle this step in bxt_set_cdclk().
2767          */
2768
2769         /* TODO: enable TBT-ALT mode */
2770         intel_cx0_phy_transaction_end(encoder, wakeref);
2771 }
2772
2773 int intel_mtl_tbt_calc_port_clock(struct intel_encoder *encoder)
2774 {
2775         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2776         u32 clock;
2777         u32 val = intel_de_read(i915, XELPDP_PORT_CLOCK_CTL(encoder->port));
2778
2779         clock = REG_FIELD_GET(XELPDP_DDI_CLOCK_SELECT_MASK, val);
2780
2781         drm_WARN_ON(&i915->drm, !(val & XELPDP_FORWARD_CLOCK_UNGATE));
2782         drm_WARN_ON(&i915->drm, !(val & XELPDP_TBT_CLOCK_REQUEST));
2783         drm_WARN_ON(&i915->drm, !(val & XELPDP_TBT_CLOCK_ACK));
2784
2785         switch (clock) {
2786         case XELPDP_DDI_CLOCK_SELECT_TBT_162:
2787                 return 162000;
2788         case XELPDP_DDI_CLOCK_SELECT_TBT_270:
2789                 return 270000;
2790         case XELPDP_DDI_CLOCK_SELECT_TBT_540:
2791                 return 540000;
2792         case XELPDP_DDI_CLOCK_SELECT_TBT_810:
2793                 return 810000;
2794         default:
2795                 MISSING_CASE(clock);
2796                 return 162000;
2797         }
2798 }
2799
2800 static int intel_mtl_tbt_clock_select(struct drm_i915_private *i915, int clock)
2801 {
2802         switch (clock) {
2803         case 162000:
2804                 return XELPDP_DDI_CLOCK_SELECT_TBT_162;
2805         case 270000:
2806                 return XELPDP_DDI_CLOCK_SELECT_TBT_270;
2807         case 540000:
2808                 return XELPDP_DDI_CLOCK_SELECT_TBT_540;
2809         case 810000:
2810                 return XELPDP_DDI_CLOCK_SELECT_TBT_810;
2811         default:
2812                 MISSING_CASE(clock);
2813                 return XELPDP_DDI_CLOCK_SELECT_TBT_162;
2814         }
2815 }
2816
2817 static void intel_mtl_tbt_pll_enable(struct intel_encoder *encoder,
2818                                      const struct intel_crtc_state *crtc_state)
2819 {
2820         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2821         enum phy phy = intel_port_to_phy(i915, encoder->port);
2822         u32 val = 0;
2823
2824         /*
2825          * 1. Program PORT_CLOCK_CTL REGISTER to configure
2826          * clock muxes, gating and SSC
2827          */
2828         val |= XELPDP_DDI_CLOCK_SELECT(intel_mtl_tbt_clock_select(i915, crtc_state->port_clock));
2829         val |= XELPDP_FORWARD_CLOCK_UNGATE;
2830         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2831                      XELPDP_DDI_CLOCK_SELECT_MASK | XELPDP_FORWARD_CLOCK_UNGATE, val);
2832
2833         /* 2. Read back PORT_CLOCK_CTL REGISTER */
2834         val = intel_de_read(i915, XELPDP_PORT_CLOCK_CTL(encoder->port));
2835
2836         /*
2837          * 3. Follow the Display Voltage Frequency Switching - Sequence
2838          * Before Frequency Change. We handle this step in bxt_set_cdclk().
2839          */
2840
2841         /*
2842          * 4. Set PORT_CLOCK_CTL register TBT CLOCK Request to "1" to enable PLL.
2843          */
2844         val |= XELPDP_TBT_CLOCK_REQUEST;
2845         intel_de_write(i915, XELPDP_PORT_CLOCK_CTL(encoder->port), val);
2846
2847         /* 5. Poll on PORT_CLOCK_CTL TBT CLOCK Ack == "1". */
2848         if (__intel_de_wait_for_register(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2849                                          XELPDP_TBT_CLOCK_ACK,
2850                                          XELPDP_TBT_CLOCK_ACK,
2851                                          100, 0, NULL))
2852                 drm_warn(&i915->drm, "[ENCODER:%d:%s][%c] PHY PLL not locked after 100us.\n",
2853                          encoder->base.base.id, encoder->base.name, phy_name(phy));
2854
2855         /*
2856          * 6. Follow the Display Voltage Frequency Switching Sequence After
2857          * Frequency Change. We handle this step in bxt_set_cdclk().
2858          */
2859
2860         /*
2861          * 7. Program DDI_CLK_VALFREQ to match intended DDI
2862          * clock frequency.
2863          */
2864         intel_de_write(i915, DDI_CLK_VALFREQ(encoder->port),
2865                        crtc_state->port_clock);
2866 }
2867
2868 void intel_mtl_pll_enable(struct intel_encoder *encoder,
2869                           const struct intel_crtc_state *crtc_state)
2870 {
2871         struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2872
2873         if (intel_tc_port_in_tbt_alt_mode(dig_port))
2874                 intel_mtl_tbt_pll_enable(encoder, crtc_state);
2875         else
2876                 intel_cx0pll_enable(encoder, crtc_state);
2877 }
2878
2879 static void intel_cx0pll_disable(struct intel_encoder *encoder)
2880 {
2881         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2882         enum phy phy = intel_port_to_phy(i915, encoder->port);
2883         bool is_c10 = intel_is_c10phy(i915, phy);
2884         intel_wakeref_t wakeref = intel_cx0_phy_transaction_begin(encoder);
2885
2886         /* 1. Change owned PHY lane power to Disable state. */
2887         intel_cx0_powerdown_change_sequence(i915, encoder->port, INTEL_CX0_BOTH_LANES,
2888                                             is_c10 ? CX0_P2PG_STATE_DISABLE :
2889                                             CX0_P4PG_STATE_DISABLE);
2890
2891         /*
2892          * 2. Follow the Display Voltage Frequency Switching Sequence Before
2893          * Frequency Change. We handle this step in bxt_set_cdclk().
2894          */
2895
2896         /*
2897          * 3. Set PORT_CLOCK_CTL register PCLK PLL Request LN<Lane for maxPCLK>
2898          * to "0" to disable PLL.
2899          */
2900         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2901                      intel_cx0_get_pclk_pll_request(INTEL_CX0_BOTH_LANES) |
2902                      intel_cx0_get_pclk_refclk_request(INTEL_CX0_BOTH_LANES), 0);
2903
2904         /* 4. Program DDI_CLK_VALFREQ to 0. */
2905         intel_de_write(i915, DDI_CLK_VALFREQ(encoder->port), 0);
2906
2907         /*
2908          * 5. Poll on PORT_CLOCK_CTL PCLK PLL Ack LN<Lane for maxPCLK**> == "0".
2909          */
2910         if (__intel_de_wait_for_register(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2911                                          intel_cx0_get_pclk_pll_ack(INTEL_CX0_BOTH_LANES) |
2912                                          intel_cx0_get_pclk_refclk_ack(INTEL_CX0_BOTH_LANES), 0,
2913                                          XELPDP_PCLK_PLL_DISABLE_TIMEOUT_US, 0, NULL))
2914                 drm_warn(&i915->drm, "Port %c PLL not unlocked after %dus.\n",
2915                          phy_name(phy), XELPDP_PCLK_PLL_DISABLE_TIMEOUT_US);
2916
2917         /*
2918          * 6. Follow the Display Voltage Frequency Switching Sequence After
2919          * Frequency Change. We handle this step in bxt_set_cdclk().
2920          */
2921
2922         /* 7. Program PORT_CLOCK_CTL register to disable and gate clocks. */
2923         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2924                      XELPDP_DDI_CLOCK_SELECT_MASK, 0);
2925         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2926                      XELPDP_FORWARD_CLOCK_UNGATE, 0);
2927
2928         intel_cx0_phy_transaction_end(encoder, wakeref);
2929 }
2930
2931 static void intel_mtl_tbt_pll_disable(struct intel_encoder *encoder)
2932 {
2933         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2934         enum phy phy = intel_port_to_phy(i915, encoder->port);
2935
2936         /*
2937          * 1. Follow the Display Voltage Frequency Switching Sequence Before
2938          * Frequency Change. We handle this step in bxt_set_cdclk().
2939          */
2940
2941         /*
2942          * 2. Set PORT_CLOCK_CTL register TBT CLOCK Request to "0" to disable PLL.
2943          */
2944         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2945                      XELPDP_TBT_CLOCK_REQUEST, 0);
2946
2947         /* 3. Poll on PORT_CLOCK_CTL TBT CLOCK Ack == "0". */
2948         if (__intel_de_wait_for_register(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2949                                          XELPDP_TBT_CLOCK_ACK, 0, 10, 0, NULL))
2950                 drm_warn(&i915->drm, "[ENCODER:%d:%s][%c] PHY PLL not unlocked after 10us.\n",
2951                          encoder->base.base.id, encoder->base.name, phy_name(phy));
2952
2953         /*
2954          * 4. Follow the Display Voltage Frequency Switching Sequence After
2955          * Frequency Change. We handle this step in bxt_set_cdclk().
2956          */
2957
2958         /*
2959          * 5. Program PORT CLOCK CTRL register to disable and gate clocks
2960          */
2961         intel_de_rmw(i915, XELPDP_PORT_CLOCK_CTL(encoder->port),
2962                      XELPDP_DDI_CLOCK_SELECT_MASK |
2963                      XELPDP_FORWARD_CLOCK_UNGATE, 0);
2964
2965         /* 6. Program DDI_CLK_VALFREQ to 0. */
2966         intel_de_write(i915, DDI_CLK_VALFREQ(encoder->port), 0);
2967 }
2968
2969 void intel_mtl_pll_disable(struct intel_encoder *encoder)
2970 {
2971         struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2972
2973         if (intel_tc_port_in_tbt_alt_mode(dig_port))
2974                 intel_mtl_tbt_pll_disable(encoder);
2975         else
2976                 intel_cx0pll_disable(encoder);
2977 }
2978
2979 enum icl_port_dpll_id
2980 intel_mtl_port_pll_type(struct intel_encoder *encoder,
2981                         const struct intel_crtc_state *crtc_state)
2982 {
2983         struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2984         /*
2985          * TODO: Determine the PLL type from the SW state, once MTL PLL
2986          * handling is done via the standard shared DPLL framework.
2987          */
2988         u32 val = intel_de_read(i915, XELPDP_PORT_CLOCK_CTL(encoder->port));
2989         u32 clock = REG_FIELD_GET(XELPDP_DDI_CLOCK_SELECT_MASK, val);
2990
2991         if (clock == XELPDP_DDI_CLOCK_SELECT_MAXPCLK ||
2992             clock == XELPDP_DDI_CLOCK_SELECT_DIV18CLK)
2993                 return ICL_PORT_DPLL_MG_PHY;
2994         else
2995                 return ICL_PORT_DPLL_DEFAULT;
2996 }
2997
2998 void intel_c10pll_state_verify(struct intel_atomic_state *state,
2999                                struct intel_crtc_state *new_crtc_state)
3000 {
3001         struct drm_i915_private *i915 = to_i915(state->base.dev);
3002         struct intel_c10pll_state mpllb_hw_state = { 0 };
3003         struct intel_c10pll_state *mpllb_sw_state = &new_crtc_state->cx0pll_state.c10;
3004         struct intel_crtc *crtc = to_intel_crtc(new_crtc_state->uapi.crtc);
3005         struct intel_encoder *encoder;
3006         enum phy phy;
3007         int i;
3008
3009         if (DISPLAY_VER(i915) < 14)
3010                 return;
3011
3012         if (!new_crtc_state->hw.active)
3013                 return;
3014
3015         /* intel_get_crtc_new_encoder() only works for modeset/fastset commits */
3016         if (!intel_crtc_needs_modeset(new_crtc_state) &&
3017             !intel_crtc_needs_fastset(new_crtc_state))
3018                 return;
3019
3020         encoder = intel_get_crtc_new_encoder(state, new_crtc_state);
3021         phy = intel_port_to_phy(i915, encoder->port);
3022
3023         if (!intel_is_c10phy(i915, phy))
3024                 return;
3025
3026         intel_c10pll_readout_hw_state(encoder, &mpllb_hw_state);
3027
3028         for (i = 0; i < ARRAY_SIZE(mpllb_sw_state->pll); i++) {
3029                 u8 expected = mpllb_sw_state->pll[i];
3030
3031                 I915_STATE_WARN(i915, mpllb_hw_state.pll[i] != expected,
3032                                 "[CRTC:%d:%s] mismatch in C10MPLLB: Register[%d] (expected 0x%02x, found 0x%02x)",
3033                                 crtc->base.base.id, crtc->base.name, i,
3034                                 expected, mpllb_hw_state.pll[i]);
3035         }
3036
3037         I915_STATE_WARN(i915, mpllb_hw_state.tx != mpllb_sw_state->tx,
3038                         "[CRTC:%d:%s] mismatch in C10MPLLB: Register TX0 (expected 0x%02x, found 0x%02x)",
3039                         crtc->base.base.id, crtc->base.name,
3040                         mpllb_sw_state->tx, mpllb_hw_state.tx);
3041
3042         I915_STATE_WARN(i915, mpllb_hw_state.cmn != mpllb_sw_state->cmn,
3043                         "[CRTC:%d:%s] mismatch in C10MPLLB: Register CMN0 (expected 0x%02x, found 0x%02x)",
3044                         crtc->base.base.id, crtc->base.name,
3045                         mpllb_sw_state->cmn, mpllb_hw_state.cmn);
3046 }