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