* [PATCH v2 0/3] Fix Cx0 Suspend Resume issue
@ 2026-01-14 3:42 Suraj Kandpal
2026-01-14 3:42 ` [PATCH v2 1/3] drm/i915/cx0: Split PLL enabling/disabling in two parts Suraj Kandpal
` (6 more replies)
0 siblings, 7 replies; 11+ messages in thread
From: Suraj Kandpal @ 2026-01-14 3:42 UTC (permalink / raw)
To: intel-xe, intel-gfx; +Cc: ankit.k.nautiyal, Suraj Kandpal
CX0 PHY currently has two issues which cause a hang when we try
to suspend resume machine with a delay of 15mins and 1+ hour.
This happens due to two reasons:
1) We do not follow the Enablement sequence where we need to
enable our clock after PPS Enablement cycle
2) We do not make sure response ready and error bit are cleared
in P2M_MSGBUS_STATUS before writing the transaction pending bit.
This series aims to solve this.
Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com>
Mika Kahola (1):
drm/i915/cx0: Split PLL enabling/disabling in two parts
Suraj Kandpal (2):
drm/i915/cx0: Clear response ready & error bit
drm/i915/cx0: Rename intel_clear_response_ready flag
drivers/gpu/drm/i915/display/intel_cx0_phy.c | 134 +++++++++++-------
drivers/gpu/drm/i915/display/intel_cx0_phy.h | 4 +-
drivers/gpu/drm/i915/display/intel_dpll_mgr.c | 7 +-
drivers/gpu/drm/i915/display/intel_lt_phy.c | 2 +-
4 files changed, 92 insertions(+), 55 deletions(-)
--
2.34.1
^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH v2 1/3] drm/i915/cx0: Split PLL enabling/disabling in two parts
2026-01-14 3:42 [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Suraj Kandpal
@ 2026-01-14 3:42 ` Suraj Kandpal
2026-01-14 15:12 ` Imre Deak
2026-01-14 3:42 ` [PATCH v2 2/3] drm/i915/cx0: Clear response ready & error bit Suraj Kandpal
` (5 subsequent siblings)
6 siblings, 1 reply; 11+ messages in thread
From: Suraj Kandpal @ 2026-01-14 3:42 UTC (permalink / raw)
To: intel-xe, intel-gfx
Cc: ankit.k.nautiyal, Mika Kahola, Suraj Kandpal, Michał Grzelak
From: Mika Kahola <mika.kahola@intel.com>
Split PLL enabling/disabling in two parts - one for pll setting
pll dividers and second one to enable/disable pll clock. PLL
clock enabling/disbling happens via encoder->enable_clock/disable_clock
function hook.
PLL state verification happens now earlier than the clock is enabled
which causes a drm warn to be thrown. Silence this warning by
allowing this check for only earlier platforms than MeteorLake.
While at it also add the necessary argument to cx0_enable_clock
so that we can move step 12 of the enable sequence.
v2:
- Move state verification to enable_clock() function for
MTL+ platforms
- Squash patch 1 & 2 (Gustavo)
- Use correct Bspec references (Gustavo)
- Fix build error (Michal)
Bspec: 65448, 68849
Signed-off-by: Mika Kahola <mika.kahola@intel.com>
Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com>
Reviewed-by: Michał Grzelak <michal.grzelak@intel.com>
---
drivers/gpu/drm/i915/display/intel_cx0_phy.c | 120 +++++++++++-------
drivers/gpu/drm/i915/display/intel_dpll_mgr.c | 7 +-
2 files changed, 80 insertions(+), 47 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_cx0_phy.c b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
index 7288065d2461..3418a3ed28fd 100644
--- a/drivers/gpu/drm/i915/display/intel_cx0_phy.c
+++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
@@ -3225,11 +3225,8 @@ static void intel_cx0pll_enable(struct intel_encoder *encoder,
{
int port_clock = pll_state->use_c10 ? pll_state->c10.clock : pll_state->c20.clock;
struct intel_display *display = to_intel_display(encoder);
- enum phy phy = intel_encoder_to_phy(encoder);
struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
bool lane_reversal = dig_port->lane_reversal;
- u8 maxpclk_lane = lane_reversal ? INTEL_CX0_LANE1 :
- INTEL_CX0_LANE0;
struct ref_tracker *wakeref = intel_cx0_phy_transaction_begin(encoder);
/*
@@ -3284,42 +3281,6 @@ static void intel_cx0pll_enable(struct intel_encoder *encoder,
*/
intel_de_write(display, DDI_CLK_VALFREQ(encoder->port), port_clock);
- /*
- * 9. Set PORT_CLOCK_CTL register PCLK PLL Request
- * LN<Lane for maxPCLK> to "1" to enable PLL.
- */
- intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
- intel_cx0_get_pclk_pll_request(INTEL_CX0_BOTH_LANES),
- intel_cx0_get_pclk_pll_request(maxpclk_lane));
-
- /* 10. Poll on PORT_CLOCK_CTL PCLK PLL Ack LN<Lane for maxPCLK> == "1". */
- if (intel_de_wait_us(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
- intel_cx0_get_pclk_pll_ack(INTEL_CX0_BOTH_LANES),
- intel_cx0_get_pclk_pll_ack(maxpclk_lane),
- XELPDP_PCLK_PLL_ENABLE_TIMEOUT_US, NULL))
- drm_warn(display->drm, "Port %c PLL not locked\n",
- phy_name(phy));
-
- /*
- * 11. Follow the Display Voltage Frequency Switching Sequence After
- * Frequency Change. We handle this step in bxt_set_cdclk().
- */
-
- /*
- * 12. Toggle powerdown if HDMI is enabled on C10 PHY.
- *
- * Wa_13013502646:
- * Fixes: HDMI lane to lane skew violations on C10 display PHYs.
- * Workaround: Toggle powerdown value by setting first to P0 and then to P2, for both
- * PHY lanes.
- */
- if (!cx0pll_state_is_dp(pll_state) && pll_state->use_c10) {
- intel_cx0_powerdown_change_sequence(encoder, INTEL_CX0_BOTH_LANES,
- XELPDP_P0_STATE_ACTIVE);
- intel_cx0_powerdown_change_sequence(encoder, INTEL_CX0_BOTH_LANES,
- XELPDP_P2_STATE_READY);
- }
-
intel_cx0_phy_transaction_end(encoder, wakeref);
}
@@ -3403,6 +3364,56 @@ static int intel_mtl_tbt_clock_select(struct intel_display *display,
}
}
+static void intel_cx0pll_enable_clock(struct intel_encoder *encoder,
+ const struct intel_cx0pll_state *pll_state)
+{
+ struct intel_display *display = to_intel_display(encoder);
+ enum phy phy = intel_encoder_to_phy(encoder);
+ struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
+ bool lane_reversal = dig_port->lane_reversal;
+ u8 maxpclk_lane = lane_reversal ? INTEL_CX0_LANE1 :
+ INTEL_CX0_LANE0;
+ struct ref_tracker *wakeref = intel_cx0_phy_transaction_begin(encoder);
+
+ /*
+ * 9. Set PORT_CLOCK_CTL register PCLK PLL Request
+ * LN<Lane for maxPCLK> to "1" to enable PLL.
+ */
+ intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
+ intel_cx0_get_pclk_pll_request(INTEL_CX0_BOTH_LANES),
+ intel_cx0_get_pclk_pll_request(maxpclk_lane));
+
+ /* 10. Poll on PORT_CLOCK_CTL PCLK PLL Ack LN<Lane for maxPCLK> == "1". */
+ if (intel_de_wait_us(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
+ intel_cx0_get_pclk_pll_ack(INTEL_CX0_BOTH_LANES),
+ intel_cx0_get_pclk_pll_ack(maxpclk_lane),
+ XELPDP_PCLK_PLL_ENABLE_TIMEOUT_US, NULL))
+ drm_warn(display->drm, "Port %c PLL not locked\n",
+ phy_name(phy));
+
+ /*
+ * 11. Follow the Display Voltage Frequency Switching Sequence After
+ * Frequency Change. We handle this step in bxt_set_cdclk().
+ */
+
+ /*
+ * 12. Toggle powerdown if HDMI is enabled on C10 PHY.
+ *
+ * Wa_13013502646:
+ * Fixes: HDMI lane to lane skew violations on C10 display PHYs.
+ * Workaround: Toggle powerdown value by setting first to P0 and then to P2, for both
+ * PHY lanes.
+ */
+ if (!cx0pll_state_is_dp(pll_state) && pll_state->use_c10) {
+ intel_cx0_powerdown_change_sequence(encoder, INTEL_CX0_BOTH_LANES,
+ XELPDP_P0_STATE_ACTIVE);
+ intel_cx0_powerdown_change_sequence(encoder, INTEL_CX0_BOTH_LANES,
+ XELPDP_P2_STATE_READY);
+ }
+
+ intel_cx0_phy_transaction_end(encoder, wakeref);
+}
+
void intel_mtl_tbt_pll_enable_clock(struct intel_encoder *encoder, int port_clock)
{
struct intel_display *display = to_intel_display(encoder);
@@ -3468,10 +3479,16 @@ void intel_mtl_pll_enable(struct intel_encoder *encoder,
void intel_mtl_pll_enable_clock(struct intel_encoder *encoder,
const struct intel_crtc_state *crtc_state)
{
+ struct intel_display *display = to_intel_display(encoder);
+ struct intel_dpll *pll = crtc_state->intel_dpll;
struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
if (intel_tc_port_in_tbt_alt_mode(dig_port))
intel_mtl_tbt_pll_enable_clock(encoder, crtc_state->port_clock);
+ else
+ intel_cx0pll_enable_clock(encoder, &crtc_state->dpll_hw_state.cx0pll);
+
+ assert_dpll_enabled(display, pll);
}
/*
@@ -3567,12 +3584,6 @@ static void intel_cx0pll_disable(struct intel_encoder *encoder)
* Frequency Change. We handle this step in bxt_set_cdclk().
*/
- /* 7. Program PORT_CLOCK_CTL register to disable and gate clocks. */
- intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
- XELPDP_DDI_CLOCK_SELECT_MASK(display), 0);
- intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
- XELPDP_FORWARD_CLOCK_UNGATE, 0);
-
intel_cx0_phy_transaction_end(encoder, wakeref);
}
@@ -3586,6 +3597,20 @@ static bool intel_cx0_pll_is_enabled(struct intel_encoder *encoder)
intel_cx0_get_pclk_pll_request(lane);
}
+static void intel_cx0pll_disable_clock(struct intel_encoder *encoder)
+{
+ struct intel_display *display = to_intel_display(encoder);
+ struct ref_tracker *wakeref = intel_cx0_phy_transaction_begin(encoder);
+
+ /* 7. Program PORT_CLOCK_CTL register to disable and gate clocks. */
+ intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
+ XELPDP_DDI_CLOCK_SELECT_MASK(display), 0);
+ intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
+ XELPDP_FORWARD_CLOCK_UNGATE, 0);
+
+ intel_cx0_phy_transaction_end(encoder, wakeref);
+}
+
void intel_mtl_tbt_pll_disable_clock(struct intel_encoder *encoder)
{
struct intel_display *display = to_intel_display(encoder);
@@ -3635,6 +3660,9 @@ void intel_mtl_pll_disable_clock(struct intel_encoder *encoder)
if (intel_tc_port_in_tbt_alt_mode(dig_port))
intel_mtl_tbt_pll_disable_clock(encoder);
+ else
+ intel_cx0pll_disable_clock(encoder);
+
}
enum icl_port_dpll_id
@@ -3783,6 +3811,8 @@ void intel_cx0_pll_power_save_wa(struct intel_display *display)
encoder->base.base.id, encoder->base.name);
intel_cx0pll_enable(encoder, &pll_state);
+ intel_cx0pll_enable_clock(encoder, &pll_state);
intel_cx0pll_disable(encoder);
+ intel_cx0pll_disable_clock(encoder);
}
}
diff --git a/drivers/gpu/drm/i915/display/intel_dpll_mgr.c b/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
index 9aa84a430f09..040c97d81302 100644
--- a/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
+++ b/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
@@ -298,7 +298,8 @@ void intel_dpll_enable(const struct intel_crtc_state *crtc_state)
if (old_mask) {
drm_WARN_ON(display->drm, !pll->on);
- assert_dpll_enabled(display, pll);
+ if (DISPLAY_VER(display) < 14)
+ assert_dpll_enabled(display, pll);
goto out;
}
drm_WARN_ON(display->drm, pll->on);
@@ -342,7 +343,9 @@ void intel_dpll_disable(const struct intel_crtc_state *crtc_state)
pll->info->name, pll->active_mask, pll->on,
crtc->base.base.id, crtc->base.name);
- assert_dpll_enabled(display, pll);
+ if (DISPLAY_VER(display) < 14)
+ assert_dpll_enabled(display, pll);
+
drm_WARN_ON(display->drm, !pll->on);
pll->active_mask &= ~pipe_mask;
--
2.34.1
^ permalink raw reply related [flat|nested] 11+ messages in thread
* [PATCH v2 2/3] drm/i915/cx0: Clear response ready & error bit
2026-01-14 3:42 [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Suraj Kandpal
2026-01-14 3:42 ` [PATCH v2 1/3] drm/i915/cx0: Split PLL enabling/disabling in two parts Suraj Kandpal
@ 2026-01-14 3:42 ` Suraj Kandpal
2026-01-14 3:42 ` [PATCH v2 3/3] drm/i915/cx0: Rename intel_clear_response_ready flag Suraj Kandpal
` (4 subsequent siblings)
6 siblings, 0 replies; 11+ messages in thread
From: Suraj Kandpal @ 2026-01-14 3:42 UTC (permalink / raw)
To: intel-xe, intel-gfx
Cc: ankit.k.nautiyal, Suraj Kandpal, Gustavo Sousa,
Michał Grzelak
Clear the response ready and error bit of PORT_P2M_MESSAGE_BUS_STATUS
before writing the transaction pending bit of
PORT_M2P_MSGBUS_CTL as that is a hard requirement. If not done
we find that the PHY hangs since it ends up in a weird state if left
idle for more than 1 hour.
Bspec: 65101
Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com>
Reviewed-by: Gustavo Sousa <gustavo.sousa@intel.com>
Reviewed-by: Michał Grzelak <michal.grzelak@intel.com>
---
drivers/gpu/drm/i915/display/intel_cx0_phy.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/drivers/gpu/drm/i915/display/intel_cx0_phy.c b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
index 3418a3ed28fd..00c7fa9040ee 100644
--- a/drivers/gpu/drm/i915/display/intel_cx0_phy.c
+++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
@@ -222,6 +222,8 @@ static int __intel_cx0_read_once(struct intel_encoder *encoder,
return -ETIMEDOUT;
}
+ intel_clear_response_ready_flag(encoder, lane);
+
intel_de_write(display, XELPDP_PORT_M2P_MSGBUS_CTL(display, port, lane),
XELPDP_PORT_M2P_TRANSACTION_PENDING |
XELPDP_PORT_M2P_COMMAND_READ |
@@ -293,6 +295,8 @@ static int __intel_cx0_write_once(struct intel_encoder *encoder,
return -ETIMEDOUT;
}
+ intel_clear_response_ready_flag(encoder, lane);
+
intel_de_write(display, XELPDP_PORT_M2P_MSGBUS_CTL(display, port, lane),
XELPDP_PORT_M2P_TRANSACTION_PENDING |
(committed ? XELPDP_PORT_M2P_COMMAND_WRITE_COMMITTED :
--
2.34.1
^ permalink raw reply related [flat|nested] 11+ messages in thread
* [PATCH v2 3/3] drm/i915/cx0: Rename intel_clear_response_ready flag
2026-01-14 3:42 [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Suraj Kandpal
2026-01-14 3:42 ` [PATCH v2 1/3] drm/i915/cx0: Split PLL enabling/disabling in two parts Suraj Kandpal
2026-01-14 3:42 ` [PATCH v2 2/3] drm/i915/cx0: Clear response ready & error bit Suraj Kandpal
@ 2026-01-14 3:42 ` Suraj Kandpal
2026-01-14 6:03 ` Garg, Nemesa
2026-01-14 4:35 ` ✓ CI.KUnit: success for Fix Cx0 Suspend Resume issue (rev2) Patchwork
` (3 subsequent siblings)
6 siblings, 1 reply; 11+ messages in thread
From: Suraj Kandpal @ 2026-01-14 3:42 UTC (permalink / raw)
To: intel-xe, intel-gfx; +Cc: ankit.k.nautiyal, Suraj Kandpal
Rename the non static intel_clear_response_ready_flag to
intel_cx0_clear_response_ready_flag so that we follow the
naming standards of non static function.
Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com>
---
drivers/gpu/drm/i915/display/intel_cx0_phy.c | 14 +++++++-------
drivers/gpu/drm/i915/display/intel_cx0_phy.h | 4 ++--
drivers/gpu/drm/i915/display/intel_lt_phy.c | 2 +-
3 files changed, 10 insertions(+), 10 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_cx0_phy.c b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
index 00c7fa9040ee..716b5108b4c4 100644
--- a/drivers/gpu/drm/i915/display/intel_cx0_phy.c
+++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
@@ -127,8 +127,8 @@ static void intel_cx0_phy_transaction_end(struct intel_encoder *encoder, struct
intel_display_power_put(display, POWER_DOMAIN_DC_OFF, wakeref);
}
-void intel_clear_response_ready_flag(struct intel_encoder *encoder,
- int lane)
+void intel_cx0_clear_response_ready_flag(struct intel_encoder *encoder,
+ int lane)
{
struct intel_display *display = to_intel_display(encoder);
@@ -155,7 +155,7 @@ void intel_cx0_bus_reset(struct intel_encoder *encoder, int lane)
return;
}
- intel_clear_response_ready_flag(encoder, lane);
+ intel_cx0_clear_response_ready_flag(encoder, lane);
}
int intel_cx0_wait_for_ack(struct intel_encoder *encoder,
@@ -222,7 +222,7 @@ static int __intel_cx0_read_once(struct intel_encoder *encoder,
return -ETIMEDOUT;
}
- intel_clear_response_ready_flag(encoder, lane);
+ intel_cx0_clear_response_ready_flag(encoder, lane);
intel_de_write(display, XELPDP_PORT_M2P_MSGBUS_CTL(display, port, lane),
XELPDP_PORT_M2P_TRANSACTION_PENDING |
@@ -233,7 +233,7 @@ static int __intel_cx0_read_once(struct intel_encoder *encoder,
if (ack < 0)
return ack;
- intel_clear_response_ready_flag(encoder, lane);
+ intel_cx0_clear_response_ready_flag(encoder, lane);
/*
* FIXME: Workaround to let HW to settle
@@ -295,7 +295,7 @@ static int __intel_cx0_write_once(struct intel_encoder *encoder,
return -ETIMEDOUT;
}
- intel_clear_response_ready_flag(encoder, lane);
+ intel_cx0_clear_response_ready_flag(encoder, lane);
intel_de_write(display, XELPDP_PORT_M2P_MSGBUS_CTL(display, port, lane),
XELPDP_PORT_M2P_TRANSACTION_PENDING |
@@ -325,7 +325,7 @@ static int __intel_cx0_write_once(struct intel_encoder *encoder,
return -EINVAL;
}
- intel_clear_response_ready_flag(encoder, lane);
+ intel_cx0_clear_response_ready_flag(encoder, lane);
/*
* FIXME: Workaround to let HW to settle
diff --git a/drivers/gpu/drm/i915/display/intel_cx0_phy.h b/drivers/gpu/drm/i915/display/intel_cx0_phy.h
index ae98ac23ea22..87d3bdaca3ec 100644
--- a/drivers/gpu/drm/i915/display/intel_cx0_phy.h
+++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.h
@@ -25,8 +25,8 @@ struct intel_dpll_hw_state;
struct intel_encoder;
struct intel_hdmi;
-void intel_clear_response_ready_flag(struct intel_encoder *encoder,
- int lane);
+void intel_cx0_clear_response_ready_flag(struct intel_encoder *encoder,
+ int lane);
bool intel_encoder_is_c10phy(struct intel_encoder *encoder);
void intel_mtl_pll_enable(struct intel_encoder *encoder,
struct intel_dpll *pll,
diff --git a/drivers/gpu/drm/i915/display/intel_lt_phy.c b/drivers/gpu/drm/i915/display/intel_lt_phy.c
index 6cdae03ee172..e174ca011d50 100644
--- a/drivers/gpu/drm/i915/display/intel_lt_phy.c
+++ b/drivers/gpu/drm/i915/display/intel_lt_phy.c
@@ -1106,7 +1106,7 @@ static int __intel_lt_phy_p2p_write_once(struct intel_encoder *encoder,
* This is the time PHY takes to settle down after programming the PHY.
*/
udelay(150);
- intel_clear_response_ready_flag(encoder, lane);
+ intel_cx0_clear_response_ready_flag(encoder, lane);
intel_lt_phy_clear_status_p2p(encoder, lane);
return 0;
--
2.34.1
^ permalink raw reply related [flat|nested] 11+ messages in thread
* ✓ CI.KUnit: success for Fix Cx0 Suspend Resume issue (rev2)
2026-01-14 3:42 [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Suraj Kandpal
` (2 preceding siblings ...)
2026-01-14 3:42 ` [PATCH v2 3/3] drm/i915/cx0: Rename intel_clear_response_ready flag Suraj Kandpal
@ 2026-01-14 4:35 ` Patchwork
2026-01-14 5:08 ` ✗ Xe.CI.BAT: failure " Patchwork
` (2 subsequent siblings)
6 siblings, 0 replies; 11+ messages in thread
From: Patchwork @ 2026-01-14 4:35 UTC (permalink / raw)
To: Suraj Kandpal; +Cc: intel-xe
== Series Details ==
Series: Fix Cx0 Suspend Resume issue (rev2)
URL : https://patchwork.freedesktop.org/series/159539/
State : success
== Summary ==
+ trap cleanup EXIT
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/xe/.kunitconfig
[04:34:14] Configuring KUnit Kernel ...
Generating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[04:34:19] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=48
[04:34:50] Starting KUnit Kernel (1/1)...
[04:34:50] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[04:34:50] ================== guc_buf (11 subtests) ===================
[04:34:50] [PASSED] test_smallest
[04:34:50] [PASSED] test_largest
[04:34:50] [PASSED] test_granular
[04:34:50] [PASSED] test_unique
[04:34:50] [PASSED] test_overlap
[04:34:50] [PASSED] test_reusable
[04:34:50] [PASSED] test_too_big
[04:34:50] [PASSED] test_flush
[04:34:50] [PASSED] test_lookup
[04:34:50] [PASSED] test_data
[04:34:50] [PASSED] test_class
[04:34:50] ===================== [PASSED] guc_buf =====================
[04:34:50] =================== guc_dbm (7 subtests) ===================
[04:34:50] [PASSED] test_empty
[04:34:50] [PASSED] test_default
[04:34:50] ======================== test_size ========================
[04:34:50] [PASSED] 4
[04:34:50] [PASSED] 8
[04:34:50] [PASSED] 32
[04:34:50] [PASSED] 256
[04:34:50] ==================== [PASSED] test_size ====================
[04:34:50] ======================= test_reuse ========================
[04:34:50] [PASSED] 4
[04:34:50] [PASSED] 8
[04:34:50] [PASSED] 32
[04:34:50] [PASSED] 256
[04:34:50] =================== [PASSED] test_reuse ====================
[04:34:50] =================== test_range_overlap ====================
[04:34:50] [PASSED] 4
[04:34:50] [PASSED] 8
[04:34:50] [PASSED] 32
[04:34:50] [PASSED] 256
[04:34:50] =============== [PASSED] test_range_overlap ================
[04:34:50] =================== test_range_compact ====================
[04:34:50] [PASSED] 4
[04:34:50] [PASSED] 8
[04:34:50] [PASSED] 32
[04:34:50] [PASSED] 256
[04:34:50] =============== [PASSED] test_range_compact ================
[04:34:50] ==================== test_range_spare =====================
[04:34:50] [PASSED] 4
[04:34:50] [PASSED] 8
[04:34:50] [PASSED] 32
[04:34:50] [PASSED] 256
[04:34:50] ================ [PASSED] test_range_spare =================
[04:34:50] ===================== [PASSED] guc_dbm =====================
[04:34:50] =================== guc_idm (6 subtests) ===================
[04:34:50] [PASSED] bad_init
[04:34:50] [PASSED] no_init
[04:34:50] [PASSED] init_fini
[04:34:50] [PASSED] check_used
[04:34:51] [PASSED] check_quota
[04:34:51] [PASSED] check_all
[04:34:51] ===================== [PASSED] guc_idm =====================
[04:34:51] ================== no_relay (3 subtests) ===================
[04:34:51] [PASSED] xe_drops_guc2pf_if_not_ready
[04:34:51] [PASSED] xe_drops_guc2vf_if_not_ready
[04:34:51] [PASSED] xe_rejects_send_if_not_ready
[04:34:51] ==================== [PASSED] no_relay =====================
[04:34:51] ================== pf_relay (14 subtests) ==================
[04:34:51] [PASSED] pf_rejects_guc2pf_too_short
[04:34:51] [PASSED] pf_rejects_guc2pf_too_long
[04:34:51] [PASSED] pf_rejects_guc2pf_no_payload
[04:34:51] [PASSED] pf_fails_no_payload
[04:34:51] [PASSED] pf_fails_bad_origin
[04:34:51] [PASSED] pf_fails_bad_type
[04:34:51] [PASSED] pf_txn_reports_error
[04:34:51] [PASSED] pf_txn_sends_pf2guc
[04:34:51] [PASSED] pf_sends_pf2guc
[04:34:51] [SKIPPED] pf_loopback_nop
[04:34:51] [SKIPPED] pf_loopback_echo
[04:34:51] [SKIPPED] pf_loopback_fail
[04:34:51] [SKIPPED] pf_loopback_busy
[04:34:51] [SKIPPED] pf_loopback_retry
[04:34:51] ==================== [PASSED] pf_relay =====================
[04:34:51] ================== vf_relay (3 subtests) ===================
[04:34:51] [PASSED] vf_rejects_guc2vf_too_short
[04:34:51] [PASSED] vf_rejects_guc2vf_too_long
[04:34:51] [PASSED] vf_rejects_guc2vf_no_payload
[04:34:51] ==================== [PASSED] vf_relay =====================
[04:34:51] ================ pf_gt_config (6 subtests) =================
[04:34:51] [PASSED] fair_contexts_1vf
[04:34:51] [PASSED] fair_doorbells_1vf
[04:34:51] [PASSED] fair_ggtt_1vf
[04:34:51] ====================== fair_contexts ======================
[04:34:51] [PASSED] 1 VF
[04:34:51] [PASSED] 2 VFs
[04:34:51] [PASSED] 3 VFs
[04:34:51] [PASSED] 4 VFs
[04:34:51] [PASSED] 5 VFs
[04:34:51] [PASSED] 6 VFs
[04:34:51] [PASSED] 7 VFs
[04:34:51] [PASSED] 8 VFs
[04:34:51] [PASSED] 9 VFs
[04:34:51] [PASSED] 10 VFs
[04:34:51] [PASSED] 11 VFs
[04:34:51] [PASSED] 12 VFs
[04:34:51] [PASSED] 13 VFs
[04:34:51] [PASSED] 14 VFs
[04:34:51] [PASSED] 15 VFs
[04:34:51] [PASSED] 16 VFs
[04:34:51] [PASSED] 17 VFs
[04:34:51] [PASSED] 18 VFs
[04:34:51] [PASSED] 19 VFs
[04:34:51] [PASSED] 20 VFs
[04:34:51] [PASSED] 21 VFs
[04:34:51] [PASSED] 22 VFs
[04:34:51] [PASSED] 23 VFs
[04:34:51] [PASSED] 24 VFs
[04:34:51] [PASSED] 25 VFs
[04:34:51] [PASSED] 26 VFs
[04:34:51] [PASSED] 27 VFs
[04:34:51] [PASSED] 28 VFs
[04:34:51] [PASSED] 29 VFs
[04:34:51] [PASSED] 30 VFs
[04:34:51] [PASSED] 31 VFs
[04:34:51] [PASSED] 32 VFs
[04:34:51] [PASSED] 33 VFs
[04:34:51] [PASSED] 34 VFs
[04:34:51] [PASSED] 35 VFs
[04:34:51] [PASSED] 36 VFs
[04:34:51] [PASSED] 37 VFs
[04:34:51] [PASSED] 38 VFs
[04:34:51] [PASSED] 39 VFs
[04:34:51] [PASSED] 40 VFs
[04:34:51] [PASSED] 41 VFs
[04:34:51] [PASSED] 42 VFs
[04:34:51] [PASSED] 43 VFs
[04:34:51] [PASSED] 44 VFs
[04:34:51] [PASSED] 45 VFs
[04:34:51] [PASSED] 46 VFs
[04:34:51] [PASSED] 47 VFs
[04:34:51] [PASSED] 48 VFs
[04:34:51] [PASSED] 49 VFs
[04:34:51] [PASSED] 50 VFs
[04:34:51] [PASSED] 51 VFs
[04:34:51] [PASSED] 52 VFs
[04:34:51] [PASSED] 53 VFs
[04:34:51] [PASSED] 54 VFs
[04:34:51] [PASSED] 55 VFs
[04:34:51] [PASSED] 56 VFs
[04:34:51] [PASSED] 57 VFs
[04:34:51] [PASSED] 58 VFs
[04:34:51] [PASSED] 59 VFs
[04:34:51] [PASSED] 60 VFs
[04:34:51] [PASSED] 61 VFs
[04:34:51] [PASSED] 62 VFs
[04:34:51] [PASSED] 63 VFs
[04:34:51] ================== [PASSED] fair_contexts ==================
[04:34:51] ===================== fair_doorbells ======================
[04:34:51] [PASSED] 1 VF
[04:34:51] [PASSED] 2 VFs
[04:34:51] [PASSED] 3 VFs
[04:34:51] [PASSED] 4 VFs
[04:34:51] [PASSED] 5 VFs
[04:34:51] [PASSED] 6 VFs
[04:34:51] [PASSED] 7 VFs
[04:34:51] [PASSED] 8 VFs
[04:34:51] [PASSED] 9 VFs
[04:34:51] [PASSED] 10 VFs
[04:34:51] [PASSED] 11 VFs
[04:34:51] [PASSED] 12 VFs
[04:34:51] [PASSED] 13 VFs
[04:34:51] [PASSED] 14 VFs
[04:34:51] [PASSED] 15 VFs
[04:34:51] [PASSED] 16 VFs
[04:34:51] [PASSED] 17 VFs
[04:34:51] [PASSED] 18 VFs
[04:34:51] [PASSED] 19 VFs
[04:34:51] [PASSED] 20 VFs
[04:34:51] [PASSED] 21 VFs
[04:34:51] [PASSED] 22 VFs
[04:34:51] [PASSED] 23 VFs
[04:34:51] [PASSED] 24 VFs
[04:34:51] [PASSED] 25 VFs
[04:34:51] [PASSED] 26 VFs
[04:34:51] [PASSED] 27 VFs
[04:34:51] [PASSED] 28 VFs
[04:34:51] [PASSED] 29 VFs
[04:34:51] [PASSED] 30 VFs
[04:34:51] [PASSED] 31 VFs
[04:34:51] [PASSED] 32 VFs
[04:34:51] [PASSED] 33 VFs
[04:34:51] [PASSED] 34 VFs
[04:34:51] [PASSED] 35 VFs
[04:34:51] [PASSED] 36 VFs
[04:34:51] [PASSED] 37 VFs
[04:34:51] [PASSED] 38 VFs
[04:34:51] [PASSED] 39 VFs
[04:34:51] [PASSED] 40 VFs
[04:34:51] [PASSED] 41 VFs
[04:34:51] [PASSED] 42 VFs
[04:34:51] [PASSED] 43 VFs
[04:34:51] [PASSED] 44 VFs
[04:34:51] [PASSED] 45 VFs
[04:34:51] [PASSED] 46 VFs
[04:34:51] [PASSED] 47 VFs
[04:34:51] [PASSED] 48 VFs
[04:34:51] [PASSED] 49 VFs
[04:34:51] [PASSED] 50 VFs
[04:34:51] [PASSED] 51 VFs
[04:34:51] [PASSED] 52 VFs
[04:34:51] [PASSED] 53 VFs
[04:34:51] [PASSED] 54 VFs
[04:34:51] [PASSED] 55 VFs
[04:34:51] [PASSED] 56 VFs
[04:34:51] [PASSED] 57 VFs
[04:34:51] [PASSED] 58 VFs
[04:34:51] [PASSED] 59 VFs
[04:34:51] [PASSED] 60 VFs
[04:34:51] [PASSED] 61 VFs
[04:34:51] [PASSED] 62 VFs
[04:34:51] [PASSED] 63 VFs
[04:34:51] ================= [PASSED] fair_doorbells ==================
[04:34:51] ======================== fair_ggtt ========================
[04:34:51] [PASSED] 1 VF
[04:34:51] [PASSED] 2 VFs
[04:34:51] [PASSED] 3 VFs
[04:34:51] [PASSED] 4 VFs
[04:34:51] [PASSED] 5 VFs
[04:34:51] [PASSED] 6 VFs
[04:34:51] [PASSED] 7 VFs
[04:34:51] [PASSED] 8 VFs
[04:34:51] [PASSED] 9 VFs
[04:34:51] [PASSED] 10 VFs
[04:34:51] [PASSED] 11 VFs
[04:34:51] [PASSED] 12 VFs
[04:34:51] [PASSED] 13 VFs
[04:34:51] [PASSED] 14 VFs
[04:34:51] [PASSED] 15 VFs
[04:34:51] [PASSED] 16 VFs
[04:34:51] [PASSED] 17 VFs
[04:34:51] [PASSED] 18 VFs
[04:34:51] [PASSED] 19 VFs
[04:34:51] [PASSED] 20 VFs
[04:34:51] [PASSED] 21 VFs
[04:34:51] [PASSED] 22 VFs
[04:34:51] [PASSED] 23 VFs
[04:34:51] [PASSED] 24 VFs
[04:34:51] [PASSED] 25 VFs
[04:34:51] [PASSED] 26 VFs
[04:34:51] [PASSED] 27 VFs
[04:34:51] [PASSED] 28 VFs
[04:34:51] [PASSED] 29 VFs
[04:34:51] [PASSED] 30 VFs
[04:34:51] [PASSED] 31 VFs
[04:34:51] [PASSED] 32 VFs
[04:34:51] [PASSED] 33 VFs
[04:34:51] [PASSED] 34 VFs
[04:34:51] [PASSED] 35 VFs
[04:34:51] [PASSED] 36 VFs
[04:34:51] [PASSED] 37 VFs
[04:34:51] [PASSED] 38 VFs
[04:34:51] [PASSED] 39 VFs
[04:34:51] [PASSED] 40 VFs
[04:34:51] [PASSED] 41 VFs
[04:34:51] [PASSED] 42 VFs
[04:34:51] [PASSED] 43 VFs
[04:34:51] [PASSED] 44 VFs
[04:34:51] [PASSED] 45 VFs
[04:34:51] [PASSED] 46 VFs
[04:34:51] [PASSED] 47 VFs
[04:34:51] [PASSED] 48 VFs
[04:34:51] [PASSED] 49 VFs
[04:34:51] [PASSED] 50 VFs
[04:34:51] [PASSED] 51 VFs
[04:34:51] [PASSED] 52 VFs
[04:34:51] [PASSED] 53 VFs
[04:34:51] [PASSED] 54 VFs
[04:34:51] [PASSED] 55 VFs
[04:34:51] [PASSED] 56 VFs
[04:34:51] [PASSED] 57 VFs
[04:34:51] [PASSED] 58 VFs
[04:34:51] [PASSED] 59 VFs
[04:34:51] [PASSED] 60 VFs
[04:34:51] [PASSED] 61 VFs
[04:34:51] [PASSED] 62 VFs
[04:34:51] [PASSED] 63 VFs
[04:34:51] ==================== [PASSED] fair_ggtt ====================
[04:34:51] ================== [PASSED] pf_gt_config ===================
[04:34:51] ===================== lmtt (1 subtest) =====================
[04:34:51] ======================== test_ops =========================
[04:34:51] [PASSED] 2-level
[04:34:51] [PASSED] multi-level
[04:34:51] ==================== [PASSED] test_ops =====================
[04:34:51] ====================== [PASSED] lmtt =======================
[04:34:51] ================= pf_service (11 subtests) =================
[04:34:51] [PASSED] pf_negotiate_any
[04:34:51] [PASSED] pf_negotiate_base_match
[04:34:51] [PASSED] pf_negotiate_base_newer
[04:34:51] [PASSED] pf_negotiate_base_next
[04:34:51] [SKIPPED] pf_negotiate_base_older
[04:34:51] [PASSED] pf_negotiate_base_prev
[04:34:51] [PASSED] pf_negotiate_latest_match
[04:34:51] [PASSED] pf_negotiate_latest_newer
[04:34:51] [PASSED] pf_negotiate_latest_next
[04:34:51] [SKIPPED] pf_negotiate_latest_older
[04:34:51] [SKIPPED] pf_negotiate_latest_prev
[04:34:51] =================== [PASSED] pf_service ====================
[04:34:51] ================= xe_guc_g2g (2 subtests) ==================
[04:34:51] ============== xe_live_guc_g2g_kunit_default ==============
[04:34:51] ========= [SKIPPED] xe_live_guc_g2g_kunit_default ==========
[04:34:51] ============== xe_live_guc_g2g_kunit_allmem ===============
[04:34:51] ========== [SKIPPED] xe_live_guc_g2g_kunit_allmem ==========
[04:34:51] =================== [SKIPPED] xe_guc_g2g ===================
[04:34:51] =================== xe_mocs (2 subtests) ===================
[04:34:51] ================ xe_live_mocs_kernel_kunit ================
[04:34:51] =========== [SKIPPED] xe_live_mocs_kernel_kunit ============
[04:34:51] ================ xe_live_mocs_reset_kunit =================
[04:34:51] ============ [SKIPPED] xe_live_mocs_reset_kunit ============
[04:34:51] ==================== [SKIPPED] xe_mocs =====================
[04:34:51] ================= xe_migrate (2 subtests) ==================
[04:34:51] ================= xe_migrate_sanity_kunit =================
[04:34:51] ============ [SKIPPED] xe_migrate_sanity_kunit =============
[04:34:51] ================== xe_validate_ccs_kunit ==================
[04:34:51] ============= [SKIPPED] xe_validate_ccs_kunit ==============
[04:34:51] =================== [SKIPPED] xe_migrate ===================
[04:34:51] ================== xe_dma_buf (1 subtest) ==================
[04:34:51] ==================== xe_dma_buf_kunit =====================
[04:34:51] ================ [SKIPPED] xe_dma_buf_kunit ================
[04:34:51] =================== [SKIPPED] xe_dma_buf ===================
[04:34:51] ================= xe_bo_shrink (1 subtest) =================
[04:34:51] =================== xe_bo_shrink_kunit ====================
[04:34:51] =============== [SKIPPED] xe_bo_shrink_kunit ===============
[04:34:51] ================== [SKIPPED] xe_bo_shrink ==================
[04:34:51] ==================== xe_bo (2 subtests) ====================
[04:34:51] ================== xe_ccs_migrate_kunit ===================
[04:34:51] ============== [SKIPPED] xe_ccs_migrate_kunit ==============
[04:34:51] ==================== xe_bo_evict_kunit ====================
[04:34:51] =============== [SKIPPED] xe_bo_evict_kunit ================
[04:34:51] ===================== [SKIPPED] xe_bo ======================
[04:34:51] ==================== args (13 subtests) ====================
[04:34:51] [PASSED] count_args_test
[04:34:51] [PASSED] call_args_example
[04:34:51] [PASSED] call_args_test
[04:34:51] [PASSED] drop_first_arg_example
[04:34:51] [PASSED] drop_first_arg_test
[04:34:51] [PASSED] first_arg_example
[04:34:51] [PASSED] first_arg_test
[04:34:51] [PASSED] last_arg_example
[04:34:51] [PASSED] last_arg_test
[04:34:51] [PASSED] pick_arg_example
[04:34:51] [PASSED] if_args_example
[04:34:51] [PASSED] if_args_test
[04:34:51] [PASSED] sep_comma_example
[04:34:51] ====================== [PASSED] args =======================
[04:34:51] =================== xe_pci (3 subtests) ====================
[04:34:51] ==================== check_graphics_ip ====================
[04:34:51] [PASSED] 12.00 Xe_LP
[04:34:51] [PASSED] 12.10 Xe_LP+
[04:34:51] [PASSED] 12.55 Xe_HPG
[04:34:51] [PASSED] 12.60 Xe_HPC
[04:34:51] [PASSED] 12.70 Xe_LPG
[04:34:51] [PASSED] 12.71 Xe_LPG
[04:34:51] [PASSED] 12.74 Xe_LPG+
[04:34:51] [PASSED] 20.01 Xe2_HPG
[04:34:51] [PASSED] 20.02 Xe2_HPG
[04:34:51] [PASSED] 20.04 Xe2_LPG
[04:34:51] [PASSED] 30.00 Xe3_LPG
[04:34:51] [PASSED] 30.01 Xe3_LPG
[04:34:51] [PASSED] 30.03 Xe3_LPG
[04:34:51] [PASSED] 30.04 Xe3_LPG
[04:34:51] [PASSED] 30.05 Xe3_LPG
[04:34:51] [PASSED] 35.11 Xe3p_XPC
[04:34:51] ================ [PASSED] check_graphics_ip ================
[04:34:51] ===================== check_media_ip ======================
[04:34:51] [PASSED] 12.00 Xe_M
[04:34:51] [PASSED] 12.55 Xe_HPM
[04:34:51] [PASSED] 13.00 Xe_LPM+
[04:34:51] [PASSED] 13.01 Xe2_HPM
[04:34:51] [PASSED] 20.00 Xe2_LPM
[04:34:51] [PASSED] 30.00 Xe3_LPM
[04:34:51] [PASSED] 30.02 Xe3_LPM
[04:34:51] [PASSED] 35.00 Xe3p_LPM
[04:34:51] [PASSED] 35.03 Xe3p_HPM
[04:34:51] ================= [PASSED] check_media_ip ==================
[04:34:51] =================== check_platform_desc ===================
[04:34:51] [PASSED] 0x9A60 (TIGERLAKE)
[04:34:51] [PASSED] 0x9A68 (TIGERLAKE)
[04:34:51] [PASSED] 0x9A70 (TIGERLAKE)
[04:34:51] [PASSED] 0x9A40 (TIGERLAKE)
[04:34:51] [PASSED] 0x9A49 (TIGERLAKE)
[04:34:51] [PASSED] 0x9A59 (TIGERLAKE)
[04:34:51] [PASSED] 0x9A78 (TIGERLAKE)
[04:34:51] [PASSED] 0x9AC0 (TIGERLAKE)
[04:34:51] [PASSED] 0x9AC9 (TIGERLAKE)
[04:34:51] [PASSED] 0x9AD9 (TIGERLAKE)
[04:34:51] [PASSED] 0x9AF8 (TIGERLAKE)
[04:34:51] [PASSED] 0x4C80 (ROCKETLAKE)
[04:34:51] [PASSED] 0x4C8A (ROCKETLAKE)
[04:34:51] [PASSED] 0x4C8B (ROCKETLAKE)
[04:34:51] [PASSED] 0x4C8C (ROCKETLAKE)
[04:34:51] [PASSED] 0x4C90 (ROCKETLAKE)
[04:34:51] [PASSED] 0x4C9A (ROCKETLAKE)
[04:34:51] [PASSED] 0x4680 (ALDERLAKE_S)
[04:34:51] [PASSED] 0x4682 (ALDERLAKE_S)
[04:34:51] [PASSED] 0x4688 (ALDERLAKE_S)
[04:34:51] [PASSED] 0x468A (ALDERLAKE_S)
[04:34:51] [PASSED] 0x468B (ALDERLAKE_S)
[04:34:51] [PASSED] 0x4690 (ALDERLAKE_S)
[04:34:51] [PASSED] 0x4692 (ALDERLAKE_S)
[04:34:51] [PASSED] 0x4693 (ALDERLAKE_S)
[04:34:51] [PASSED] 0x46A0 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46A1 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46A2 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46A3 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46A6 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46A8 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46AA (ALDERLAKE_P)
[04:34:51] [PASSED] 0x462A (ALDERLAKE_P)
[04:34:51] [PASSED] 0x4626 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x4628 (ALDERLAKE_P)
stty: 'standard input': Inappropriate ioctl for device
[04:34:51] [PASSED] 0x46B0 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46B1 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46B2 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46B3 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46C0 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46C1 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46C2 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46C3 (ALDERLAKE_P)
[04:34:51] [PASSED] 0x46D0 (ALDERLAKE_N)
[04:34:51] [PASSED] 0x46D1 (ALDERLAKE_N)
[04:34:51] [PASSED] 0x46D2 (ALDERLAKE_N)
[04:34:51] [PASSED] 0x46D3 (ALDERLAKE_N)
[04:34:51] [PASSED] 0x46D4 (ALDERLAKE_N)
[04:34:51] [PASSED] 0xA721 (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA7A1 (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA7A9 (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA7AC (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA7AD (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA720 (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA7A0 (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA7A8 (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA7AA (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA7AB (ALDERLAKE_P)
[04:34:51] [PASSED] 0xA780 (ALDERLAKE_S)
[04:34:51] [PASSED] 0xA781 (ALDERLAKE_S)
[04:34:51] [PASSED] 0xA782 (ALDERLAKE_S)
[04:34:51] [PASSED] 0xA783 (ALDERLAKE_S)
[04:34:51] [PASSED] 0xA788 (ALDERLAKE_S)
[04:34:51] [PASSED] 0xA789 (ALDERLAKE_S)
[04:34:51] [PASSED] 0xA78A (ALDERLAKE_S)
[04:34:51] [PASSED] 0xA78B (ALDERLAKE_S)
[04:34:51] [PASSED] 0x4905 (DG1)
[04:34:51] [PASSED] 0x4906 (DG1)
[04:34:51] [PASSED] 0x4907 (DG1)
[04:34:51] [PASSED] 0x4908 (DG1)
[04:34:51] [PASSED] 0x4909 (DG1)
[04:34:51] [PASSED] 0x56C0 (DG2)
[04:34:51] [PASSED] 0x56C2 (DG2)
[04:34:51] [PASSED] 0x56C1 (DG2)
[04:34:51] [PASSED] 0x7D51 (METEORLAKE)
[04:34:51] [PASSED] 0x7DD1 (METEORLAKE)
[04:34:51] [PASSED] 0x7D41 (METEORLAKE)
[04:34:51] [PASSED] 0x7D67 (METEORLAKE)
[04:34:51] [PASSED] 0xB640 (METEORLAKE)
[04:34:51] [PASSED] 0x56A0 (DG2)
[04:34:51] [PASSED] 0x56A1 (DG2)
[04:34:51] [PASSED] 0x56A2 (DG2)
[04:34:51] [PASSED] 0x56BE (DG2)
[04:34:51] [PASSED] 0x56BF (DG2)
[04:34:51] [PASSED] 0x5690 (DG2)
[04:34:51] [PASSED] 0x5691 (DG2)
[04:34:51] [PASSED] 0x5692 (DG2)
[04:34:51] [PASSED] 0x56A5 (DG2)
[04:34:51] [PASSED] 0x56A6 (DG2)
[04:34:51] [PASSED] 0x56B0 (DG2)
[04:34:51] [PASSED] 0x56B1 (DG2)
[04:34:51] [PASSED] 0x56BA (DG2)
[04:34:51] [PASSED] 0x56BB (DG2)
[04:34:51] [PASSED] 0x56BC (DG2)
[04:34:51] [PASSED] 0x56BD (DG2)
[04:34:51] [PASSED] 0x5693 (DG2)
[04:34:51] [PASSED] 0x5694 (DG2)
[04:34:51] [PASSED] 0x5695 (DG2)
[04:34:51] [PASSED] 0x56A3 (DG2)
[04:34:51] [PASSED] 0x56A4 (DG2)
[04:34:51] [PASSED] 0x56B2 (DG2)
[04:34:51] [PASSED] 0x56B3 (DG2)
[04:34:51] [PASSED] 0x5696 (DG2)
[04:34:51] [PASSED] 0x5697 (DG2)
[04:34:51] [PASSED] 0xB69 (PVC)
[04:34:51] [PASSED] 0xB6E (PVC)
[04:34:51] [PASSED] 0xBD4 (PVC)
[04:34:51] [PASSED] 0xBD5 (PVC)
[04:34:51] [PASSED] 0xBD6 (PVC)
[04:34:51] [PASSED] 0xBD7 (PVC)
[04:34:51] [PASSED] 0xBD8 (PVC)
[04:34:51] [PASSED] 0xBD9 (PVC)
[04:34:51] [PASSED] 0xBDA (PVC)
[04:34:51] [PASSED] 0xBDB (PVC)
[04:34:51] [PASSED] 0xBE0 (PVC)
[04:34:51] [PASSED] 0xBE1 (PVC)
[04:34:51] [PASSED] 0xBE5 (PVC)
[04:34:51] [PASSED] 0x7D40 (METEORLAKE)
[04:34:51] [PASSED] 0x7D45 (METEORLAKE)
[04:34:51] [PASSED] 0x7D55 (METEORLAKE)
[04:34:51] [PASSED] 0x7D60 (METEORLAKE)
[04:34:51] [PASSED] 0x7DD5 (METEORLAKE)
[04:34:51] [PASSED] 0x6420 (LUNARLAKE)
[04:34:51] [PASSED] 0x64A0 (LUNARLAKE)
[04:34:51] [PASSED] 0x64B0 (LUNARLAKE)
[04:34:51] [PASSED] 0xE202 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE209 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE20B (BATTLEMAGE)
[04:34:51] [PASSED] 0xE20C (BATTLEMAGE)
[04:34:51] [PASSED] 0xE20D (BATTLEMAGE)
[04:34:51] [PASSED] 0xE210 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE211 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE212 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE216 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE220 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE221 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE222 (BATTLEMAGE)
[04:34:51] [PASSED] 0xE223 (BATTLEMAGE)
[04:34:51] [PASSED] 0xB080 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB081 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB082 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB083 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB084 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB085 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB086 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB087 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB08F (PANTHERLAKE)
[04:34:51] [PASSED] 0xB090 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB0A0 (PANTHERLAKE)
[04:34:51] [PASSED] 0xB0B0 (PANTHERLAKE)
[04:34:51] [PASSED] 0xFD80 (PANTHERLAKE)
[04:34:51] [PASSED] 0xFD81 (PANTHERLAKE)
[04:34:51] [PASSED] 0xD740 (NOVALAKE_S)
[04:34:51] [PASSED] 0xD741 (NOVALAKE_S)
[04:34:51] [PASSED] 0xD742 (NOVALAKE_S)
[04:34:51] [PASSED] 0xD743 (NOVALAKE_S)
[04:34:51] [PASSED] 0xD744 (NOVALAKE_S)
[04:34:51] [PASSED] 0xD745 (NOVALAKE_S)
[04:34:51] [PASSED] 0x674C (CRESCENTISLAND)
[04:34:51] =============== [PASSED] check_platform_desc ===============
[04:34:51] ===================== [PASSED] xe_pci ======================
[04:34:51] =================== xe_rtp (2 subtests) ====================
[04:34:51] =============== xe_rtp_process_to_sr_tests ================
[04:34:51] [PASSED] coalesce-same-reg
[04:34:51] [PASSED] no-match-no-add
[04:34:51] [PASSED] match-or
[04:34:51] [PASSED] match-or-xfail
[04:34:51] [PASSED] no-match-no-add-multiple-rules
[04:34:51] [PASSED] two-regs-two-entries
[04:34:51] [PASSED] clr-one-set-other
[04:34:51] [PASSED] set-field
[04:34:51] [PASSED] conflict-duplicate
[04:34:51] [PASSED] conflict-not-disjoint
[04:34:51] [PASSED] conflict-reg-type
[04:34:51] =========== [PASSED] xe_rtp_process_to_sr_tests ============
[04:34:51] ================== xe_rtp_process_tests ===================
[04:34:51] [PASSED] active1
[04:34:51] [PASSED] active2
[04:34:51] [PASSED] active-inactive
[04:34:51] [PASSED] inactive-active
[04:34:51] [PASSED] inactive-1st_or_active-inactive
[04:34:51] [PASSED] inactive-2nd_or_active-inactive
[04:34:51] [PASSED] inactive-last_or_active-inactive
[04:34:51] [PASSED] inactive-no_or_active-inactive
[04:34:51] ============== [PASSED] xe_rtp_process_tests ===============
[04:34:51] ===================== [PASSED] xe_rtp ======================
[04:34:51] ==================== xe_wa (1 subtest) =====================
[04:34:51] ======================== xe_wa_gt =========================
[04:34:51] [PASSED] TIGERLAKE B0
[04:34:51] [PASSED] DG1 A0
[04:34:51] [PASSED] DG1 B0
[04:34:51] [PASSED] ALDERLAKE_S A0
[04:34:51] [PASSED] ALDERLAKE_S B0
[04:34:51] [PASSED] ALDERLAKE_S C0
[04:34:51] [PASSED] ALDERLAKE_S D0
[04:34:51] [PASSED] ALDERLAKE_P A0
[04:34:51] [PASSED] ALDERLAKE_P B0
[04:34:51] [PASSED] ALDERLAKE_P C0
[04:34:51] [PASSED] ALDERLAKE_S RPLS D0
[04:34:51] [PASSED] ALDERLAKE_P RPLU E0
[04:34:51] [PASSED] DG2 G10 C0
[04:34:51] [PASSED] DG2 G11 B1
[04:34:51] [PASSED] DG2 G12 A1
[04:34:51] [PASSED] METEORLAKE 12.70(Xe_LPG) A0 13.00(Xe_LPM+) A0
[04:34:51] [PASSED] METEORLAKE 12.71(Xe_LPG) A0 13.00(Xe_LPM+) A0
[04:34:51] [PASSED] METEORLAKE 12.74(Xe_LPG+) A0 13.00(Xe_LPM+) A0
[04:34:51] [PASSED] LUNARLAKE 20.04(Xe2_LPG) A0 20.00(Xe2_LPM) A0
[04:34:51] [PASSED] LUNARLAKE 20.04(Xe2_LPG) B0 20.00(Xe2_LPM) A0
[04:34:51] [PASSED] BATTLEMAGE 20.01(Xe2_HPG) A0 13.01(Xe2_HPM) A1
[04:34:51] [PASSED] PANTHERLAKE 30.00(Xe3_LPG) A0 30.00(Xe3_LPM) A0
[04:34:51] ==================== [PASSED] xe_wa_gt =====================
[04:34:51] ====================== [PASSED] xe_wa ======================
[04:34:51] ============================================================
[04:34:51] Testing complete. Ran 512 tests: passed: 494, skipped: 18
[04:34:51] Elapsed time: 36.369s total, 4.162s configuring, 31.691s building, 0.464s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/tests/.kunitconfig
[04:34:51] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[04:34:53] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=48
[04:35:18] Starting KUnit Kernel (1/1)...
[04:35:18] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[04:35:18] ============ drm_test_pick_cmdline (2 subtests) ============
[04:35:18] [PASSED] drm_test_pick_cmdline_res_1920_1080_60
[04:35:18] =============== drm_test_pick_cmdline_named ===============
[04:35:18] [PASSED] NTSC
[04:35:18] [PASSED] NTSC-J
[04:35:18] [PASSED] PAL
[04:35:18] [PASSED] PAL-M
[04:35:18] =========== [PASSED] drm_test_pick_cmdline_named ===========
[04:35:18] ============== [PASSED] drm_test_pick_cmdline ==============
[04:35:18] == drm_test_atomic_get_connector_for_encoder (1 subtest) ===
[04:35:18] [PASSED] drm_test_drm_atomic_get_connector_for_encoder
[04:35:18] ==== [PASSED] drm_test_atomic_get_connector_for_encoder ====
[04:35:18] =========== drm_validate_clone_mode (2 subtests) ===========
[04:35:18] ============== drm_test_check_in_clone_mode ===============
[04:35:18] [PASSED] in_clone_mode
[04:35:18] [PASSED] not_in_clone_mode
[04:35:18] ========== [PASSED] drm_test_check_in_clone_mode ===========
[04:35:18] =============== drm_test_check_valid_clones ===============
[04:35:18] [PASSED] not_in_clone_mode
[04:35:18] [PASSED] valid_clone
[04:35:18] [PASSED] invalid_clone
[04:35:18] =========== [PASSED] drm_test_check_valid_clones ===========
[04:35:18] ============= [PASSED] drm_validate_clone_mode =============
[04:35:18] ============= drm_validate_modeset (1 subtest) =============
[04:35:18] [PASSED] drm_test_check_connector_changed_modeset
[04:35:18] ============== [PASSED] drm_validate_modeset ===============
[04:35:18] ====== drm_test_bridge_get_current_state (2 subtests) ======
[04:35:18] [PASSED] drm_test_drm_bridge_get_current_state_atomic
[04:35:18] [PASSED] drm_test_drm_bridge_get_current_state_legacy
[04:35:18] ======== [PASSED] drm_test_bridge_get_current_state ========
[04:35:18] ====== drm_test_bridge_helper_reset_crtc (3 subtests) ======
[04:35:18] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic
[04:35:18] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic_disabled
[04:35:18] [PASSED] drm_test_drm_bridge_helper_reset_crtc_legacy
[04:35:18] ======== [PASSED] drm_test_bridge_helper_reset_crtc ========
[04:35:18] ============== drm_bridge_alloc (2 subtests) ===============
[04:35:18] [PASSED] drm_test_drm_bridge_alloc_basic
[04:35:18] [PASSED] drm_test_drm_bridge_alloc_get_put
[04:35:18] ================ [PASSED] drm_bridge_alloc =================
[04:35:18] ================== drm_buddy (8 subtests) ==================
[04:35:18] [PASSED] drm_test_buddy_alloc_limit
[04:35:18] [PASSED] drm_test_buddy_alloc_optimistic
[04:35:18] [PASSED] drm_test_buddy_alloc_pessimistic
[04:35:18] [PASSED] drm_test_buddy_alloc_pathological
[04:35:18] [PASSED] drm_test_buddy_alloc_contiguous
[04:35:18] [PASSED] drm_test_buddy_alloc_clear
[04:35:18] [PASSED] drm_test_buddy_alloc_range_bias
[04:35:18] [PASSED] drm_test_buddy_fragmentation_performance
[04:35:18] ==================== [PASSED] drm_buddy ====================
[04:35:18] ============= drm_cmdline_parser (40 subtests) =============
[04:35:18] [PASSED] drm_test_cmdline_force_d_only
[04:35:18] [PASSED] drm_test_cmdline_force_D_only_dvi
[04:35:18] [PASSED] drm_test_cmdline_force_D_only_hdmi
[04:35:18] [PASSED] drm_test_cmdline_force_D_only_not_digital
[04:35:18] [PASSED] drm_test_cmdline_force_e_only
[04:35:18] [PASSED] drm_test_cmdline_res
[04:35:18] [PASSED] drm_test_cmdline_res_vesa
[04:35:18] [PASSED] drm_test_cmdline_res_vesa_rblank
[04:35:18] [PASSED] drm_test_cmdline_res_rblank
[04:35:18] [PASSED] drm_test_cmdline_res_bpp
[04:35:18] [PASSED] drm_test_cmdline_res_refresh
[04:35:18] [PASSED] drm_test_cmdline_res_bpp_refresh
[04:35:18] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced
[04:35:18] [PASSED] drm_test_cmdline_res_bpp_refresh_margins
[04:35:18] [PASSED] drm_test_cmdline_res_bpp_refresh_force_off
[04:35:18] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on
[04:35:18] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_analog
[04:35:18] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_digital
[04:35:18] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced_margins_force_on
[04:35:18] [PASSED] drm_test_cmdline_res_margins_force_on
[04:35:18] [PASSED] drm_test_cmdline_res_vesa_margins
[04:35:18] [PASSED] drm_test_cmdline_name
[04:35:18] [PASSED] drm_test_cmdline_name_bpp
[04:35:18] [PASSED] drm_test_cmdline_name_option
[04:35:18] [PASSED] drm_test_cmdline_name_bpp_option
[04:35:18] [PASSED] drm_test_cmdline_rotate_0
[04:35:18] [PASSED] drm_test_cmdline_rotate_90
[04:35:18] [PASSED] drm_test_cmdline_rotate_180
[04:35:18] [PASSED] drm_test_cmdline_rotate_270
[04:35:18] [PASSED] drm_test_cmdline_hmirror
[04:35:18] [PASSED] drm_test_cmdline_vmirror
[04:35:18] [PASSED] drm_test_cmdline_margin_options
[04:35:18] [PASSED] drm_test_cmdline_multiple_options
[04:35:18] [PASSED] drm_test_cmdline_bpp_extra_and_option
[04:35:18] [PASSED] drm_test_cmdline_extra_and_option
[04:35:18] [PASSED] drm_test_cmdline_freestanding_options
[04:35:18] [PASSED] drm_test_cmdline_freestanding_force_e_and_options
[04:35:18] [PASSED] drm_test_cmdline_panel_orientation
[04:35:18] ================ drm_test_cmdline_invalid =================
[04:35:18] [PASSED] margin_only
[04:35:18] [PASSED] interlace_only
[04:35:18] [PASSED] res_missing_x
[04:35:18] [PASSED] res_missing_y
[04:35:18] [PASSED] res_bad_y
[04:35:18] [PASSED] res_missing_y_bpp
[04:35:18] [PASSED] res_bad_bpp
[04:35:18] [PASSED] res_bad_refresh
[04:35:18] [PASSED] res_bpp_refresh_force_on_off
[04:35:18] [PASSED] res_invalid_mode
[04:35:18] [PASSED] res_bpp_wrong_place_mode
[04:35:18] [PASSED] name_bpp_refresh
[04:35:18] [PASSED] name_refresh
[04:35:18] [PASSED] name_refresh_wrong_mode
[04:35:18] [PASSED] name_refresh_invalid_mode
[04:35:18] [PASSED] rotate_multiple
[04:35:18] [PASSED] rotate_invalid_val
[04:35:18] [PASSED] rotate_truncated
[04:35:18] [PASSED] invalid_option
[04:35:18] [PASSED] invalid_tv_option
[04:35:18] [PASSED] truncated_tv_option
[04:35:18] ============ [PASSED] drm_test_cmdline_invalid =============
[04:35:18] =============== drm_test_cmdline_tv_options ===============
[04:35:18] [PASSED] NTSC
[04:35:18] [PASSED] NTSC_443
[04:35:18] [PASSED] NTSC_J
[04:35:18] [PASSED] PAL
[04:35:18] [PASSED] PAL_M
[04:35:18] [PASSED] PAL_N
[04:35:18] [PASSED] SECAM
[04:35:18] [PASSED] MONO_525
[04:35:18] [PASSED] MONO_625
[04:35:18] =========== [PASSED] drm_test_cmdline_tv_options ===========
[04:35:18] =============== [PASSED] drm_cmdline_parser ================
[04:35:18] ========== drmm_connector_hdmi_init (20 subtests) ==========
[04:35:18] [PASSED] drm_test_connector_hdmi_init_valid
[04:35:18] [PASSED] drm_test_connector_hdmi_init_bpc_8
[04:35:18] [PASSED] drm_test_connector_hdmi_init_bpc_10
[04:35:18] [PASSED] drm_test_connector_hdmi_init_bpc_12
[04:35:18] [PASSED] drm_test_connector_hdmi_init_bpc_invalid
[04:35:18] [PASSED] drm_test_connector_hdmi_init_bpc_null
[04:35:18] [PASSED] drm_test_connector_hdmi_init_formats_empty
[04:35:18] [PASSED] drm_test_connector_hdmi_init_formats_no_rgb
[04:35:18] === drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[04:35:18] [PASSED] supported_formats=0x9 yuv420_allowed=1
[04:35:18] [PASSED] supported_formats=0x9 yuv420_allowed=0
[04:35:18] [PASSED] supported_formats=0x3 yuv420_allowed=1
[04:35:18] [PASSED] supported_formats=0x3 yuv420_allowed=0
[04:35:18] === [PASSED] drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[04:35:18] [PASSED] drm_test_connector_hdmi_init_null_ddc
[04:35:18] [PASSED] drm_test_connector_hdmi_init_null_product
[04:35:18] [PASSED] drm_test_connector_hdmi_init_null_vendor
[04:35:18] [PASSED] drm_test_connector_hdmi_init_product_length_exact
[04:35:18] [PASSED] drm_test_connector_hdmi_init_product_length_too_long
[04:35:18] [PASSED] drm_test_connector_hdmi_init_product_valid
[04:35:18] [PASSED] drm_test_connector_hdmi_init_vendor_length_exact
[04:35:18] [PASSED] drm_test_connector_hdmi_init_vendor_length_too_long
[04:35:18] [PASSED] drm_test_connector_hdmi_init_vendor_valid
[04:35:18] ========= drm_test_connector_hdmi_init_type_valid =========
[04:35:18] [PASSED] HDMI-A
[04:35:18] [PASSED] HDMI-B
[04:35:18] ===== [PASSED] drm_test_connector_hdmi_init_type_valid =====
[04:35:18] ======== drm_test_connector_hdmi_init_type_invalid ========
[04:35:18] [PASSED] Unknown
[04:35:18] [PASSED] VGA
[04:35:18] [PASSED] DVI-I
[04:35:18] [PASSED] DVI-D
[04:35:18] [PASSED] DVI-A
[04:35:18] [PASSED] Composite
[04:35:18] [PASSED] SVIDEO
[04:35:18] [PASSED] LVDS
[04:35:18] [PASSED] Component
[04:35:18] [PASSED] DIN
[04:35:18] [PASSED] DP
[04:35:18] [PASSED] TV
[04:35:18] [PASSED] eDP
[04:35:18] [PASSED] Virtual
[04:35:18] [PASSED] DSI
[04:35:18] [PASSED] DPI
[04:35:18] [PASSED] Writeback
[04:35:18] [PASSED] SPI
[04:35:18] [PASSED] USB
[04:35:18] ==== [PASSED] drm_test_connector_hdmi_init_type_invalid ====
[04:35:18] ============ [PASSED] drmm_connector_hdmi_init =============
[04:35:18] ============= drmm_connector_init (3 subtests) =============
[04:35:18] [PASSED] drm_test_drmm_connector_init
[04:35:18] [PASSED] drm_test_drmm_connector_init_null_ddc
[04:35:18] ========= drm_test_drmm_connector_init_type_valid =========
[04:35:18] [PASSED] Unknown
[04:35:18] [PASSED] VGA
[04:35:18] [PASSED] DVI-I
[04:35:18] [PASSED] DVI-D
[04:35:18] [PASSED] DVI-A
[04:35:18] [PASSED] Composite
[04:35:18] [PASSED] SVIDEO
[04:35:18] [PASSED] LVDS
[04:35:18] [PASSED] Component
[04:35:18] [PASSED] DIN
[04:35:18] [PASSED] DP
[04:35:18] [PASSED] HDMI-A
[04:35:18] [PASSED] HDMI-B
[04:35:18] [PASSED] TV
[04:35:18] [PASSED] eDP
[04:35:18] [PASSED] Virtual
[04:35:18] [PASSED] DSI
[04:35:18] [PASSED] DPI
[04:35:18] [PASSED] Writeback
[04:35:18] [PASSED] SPI
[04:35:18] [PASSED] USB
[04:35:18] ===== [PASSED] drm_test_drmm_connector_init_type_valid =====
[04:35:18] =============== [PASSED] drmm_connector_init ===============
[04:35:18] ========= drm_connector_dynamic_init (6 subtests) ==========
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_init
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_init_null_ddc
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_init_not_added
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_init_properties
[04:35:18] ===== drm_test_drm_connector_dynamic_init_type_valid ======
[04:35:18] [PASSED] Unknown
[04:35:18] [PASSED] VGA
[04:35:18] [PASSED] DVI-I
[04:35:18] [PASSED] DVI-D
[04:35:18] [PASSED] DVI-A
[04:35:18] [PASSED] Composite
[04:35:18] [PASSED] SVIDEO
[04:35:18] [PASSED] LVDS
[04:35:18] [PASSED] Component
[04:35:18] [PASSED] DIN
[04:35:18] [PASSED] DP
[04:35:18] [PASSED] HDMI-A
[04:35:18] [PASSED] HDMI-B
[04:35:18] [PASSED] TV
[04:35:18] [PASSED] eDP
[04:35:18] [PASSED] Virtual
[04:35:18] [PASSED] DSI
[04:35:18] [PASSED] DPI
[04:35:18] [PASSED] Writeback
[04:35:18] [PASSED] SPI
[04:35:18] [PASSED] USB
[04:35:18] = [PASSED] drm_test_drm_connector_dynamic_init_type_valid ==
[04:35:18] ======== drm_test_drm_connector_dynamic_init_name =========
[04:35:18] [PASSED] Unknown
[04:35:18] [PASSED] VGA
[04:35:18] [PASSED] DVI-I
[04:35:18] [PASSED] DVI-D
[04:35:18] [PASSED] DVI-A
[04:35:18] [PASSED] Composite
[04:35:18] [PASSED] SVIDEO
[04:35:18] [PASSED] LVDS
[04:35:18] [PASSED] Component
[04:35:18] [PASSED] DIN
[04:35:18] [PASSED] DP
[04:35:18] [PASSED] HDMI-A
[04:35:18] [PASSED] HDMI-B
[04:35:18] [PASSED] TV
[04:35:18] [PASSED] eDP
[04:35:18] [PASSED] Virtual
[04:35:18] [PASSED] DSI
[04:35:18] [PASSED] DPI
[04:35:18] [PASSED] Writeback
[04:35:18] [PASSED] SPI
[04:35:18] [PASSED] USB
[04:35:18] ==== [PASSED] drm_test_drm_connector_dynamic_init_name =====
[04:35:18] =========== [PASSED] drm_connector_dynamic_init ============
[04:35:18] ==== drm_connector_dynamic_register_early (4 subtests) =====
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_early_on_list
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_early_defer
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_early_no_init
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_early_no_mode_object
[04:35:18] ====== [PASSED] drm_connector_dynamic_register_early =======
[04:35:18] ======= drm_connector_dynamic_register (7 subtests) ========
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_on_list
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_no_defer
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_no_init
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_mode_object
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_sysfs
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_sysfs_name
[04:35:18] [PASSED] drm_test_drm_connector_dynamic_register_debugfs
[04:35:18] ========= [PASSED] drm_connector_dynamic_register ==========
[04:35:18] = drm_connector_attach_broadcast_rgb_property (2 subtests) =
[04:35:18] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property
[04:35:18] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property_hdmi_connector
[04:35:18] === [PASSED] drm_connector_attach_broadcast_rgb_property ===
[04:35:18] ========== drm_get_tv_mode_from_name (2 subtests) ==========
[04:35:18] ========== drm_test_get_tv_mode_from_name_valid ===========
[04:35:18] [PASSED] NTSC
[04:35:18] [PASSED] NTSC-443
[04:35:18] [PASSED] NTSC-J
[04:35:18] [PASSED] PAL
[04:35:18] [PASSED] PAL-M
[04:35:18] [PASSED] PAL-N
[04:35:18] [PASSED] SECAM
[04:35:18] [PASSED] Mono
[04:35:18] ====== [PASSED] drm_test_get_tv_mode_from_name_valid =======
[04:35:18] [PASSED] drm_test_get_tv_mode_from_name_truncated
[04:35:18] ============ [PASSED] drm_get_tv_mode_from_name ============
[04:35:18] = drm_test_connector_hdmi_compute_mode_clock (12 subtests) =
[04:35:18] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb
[04:35:18] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc
[04:35:18] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc_vic_1
[04:35:18] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc
[04:35:18] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc_vic_1
[04:35:18] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_double
[04:35:18] = drm_test_connector_hdmi_compute_mode_clock_yuv420_valid =
[04:35:18] [PASSED] VIC 96
[04:35:18] [PASSED] VIC 97
[04:35:18] [PASSED] VIC 101
[04:35:18] [PASSED] VIC 102
[04:35:18] [PASSED] VIC 106
[04:35:18] [PASSED] VIC 107
[04:35:18] === [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_valid ===
[04:35:18] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_10_bpc
[04:35:18] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_12_bpc
[04:35:18] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_8_bpc
[04:35:18] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_10_bpc
[04:35:18] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_12_bpc
[04:35:18] === [PASSED] drm_test_connector_hdmi_compute_mode_clock ====
[04:35:18] == drm_hdmi_connector_get_broadcast_rgb_name (2 subtests) ==
[04:35:18] === drm_test_drm_hdmi_connector_get_broadcast_rgb_name ====
[04:35:18] [PASSED] Automatic
[04:35:18] [PASSED] Full
[04:35:18] [PASSED] Limited 16:235
[04:35:18] === [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name ===
[04:35:18] [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name_invalid
[04:35:18] ==== [PASSED] drm_hdmi_connector_get_broadcast_rgb_name ====
[04:35:18] == drm_hdmi_connector_get_output_format_name (2 subtests) ==
[04:35:18] === drm_test_drm_hdmi_connector_get_output_format_name ====
[04:35:18] [PASSED] RGB
[04:35:18] [PASSED] YUV 4:2:0
[04:35:18] [PASSED] YUV 4:2:2
[04:35:18] [PASSED] YUV 4:4:4
[04:35:18] === [PASSED] drm_test_drm_hdmi_connector_get_output_format_name ===
[04:35:18] [PASSED] drm_test_drm_hdmi_connector_get_output_format_name_invalid
[04:35:18] ==== [PASSED] drm_hdmi_connector_get_output_format_name ====
[04:35:18] ============= drm_damage_helper (21 subtests) ==============
[04:35:18] [PASSED] drm_test_damage_iter_no_damage
[04:35:18] [PASSED] drm_test_damage_iter_no_damage_fractional_src
[04:35:18] [PASSED] drm_test_damage_iter_no_damage_src_moved
[04:35:18] [PASSED] drm_test_damage_iter_no_damage_fractional_src_moved
[04:35:18] [PASSED] drm_test_damage_iter_no_damage_not_visible
[04:35:18] [PASSED] drm_test_damage_iter_no_damage_no_crtc
[04:35:18] [PASSED] drm_test_damage_iter_no_damage_no_fb
[04:35:18] [PASSED] drm_test_damage_iter_simple_damage
[04:35:18] [PASSED] drm_test_damage_iter_single_damage
[04:35:18] [PASSED] drm_test_damage_iter_single_damage_intersect_src
[04:35:18] [PASSED] drm_test_damage_iter_single_damage_outside_src
[04:35:18] [PASSED] drm_test_damage_iter_single_damage_fractional_src
[04:35:18] [PASSED] drm_test_damage_iter_single_damage_intersect_fractional_src
[04:35:18] [PASSED] drm_test_damage_iter_single_damage_outside_fractional_src
[04:35:18] [PASSED] drm_test_damage_iter_single_damage_src_moved
[04:35:18] [PASSED] drm_test_damage_iter_single_damage_fractional_src_moved
[04:35:18] [PASSED] drm_test_damage_iter_damage
[04:35:18] [PASSED] drm_test_damage_iter_damage_one_intersect
[04:35:18] [PASSED] drm_test_damage_iter_damage_one_outside
[04:35:18] [PASSED] drm_test_damage_iter_damage_src_moved
[04:35:18] [PASSED] drm_test_damage_iter_damage_not_visible
[04:35:18] ================ [PASSED] drm_damage_helper ================
[04:35:18] ============== drm_dp_mst_helper (3 subtests) ==============
[04:35:18] ============== drm_test_dp_mst_calc_pbn_mode ==============
[04:35:18] [PASSED] Clock 154000 BPP 30 DSC disabled
[04:35:18] [PASSED] Clock 234000 BPP 30 DSC disabled
[04:35:18] [PASSED] Clock 297000 BPP 24 DSC disabled
[04:35:18] [PASSED] Clock 332880 BPP 24 DSC enabled
[04:35:18] [PASSED] Clock 324540 BPP 24 DSC enabled
[04:35:18] ========== [PASSED] drm_test_dp_mst_calc_pbn_mode ==========
[04:35:18] ============== drm_test_dp_mst_calc_pbn_div ===============
[04:35:18] [PASSED] Link rate 2000000 lane count 4
[04:35:18] [PASSED] Link rate 2000000 lane count 2
[04:35:18] [PASSED] Link rate 2000000 lane count 1
[04:35:18] [PASSED] Link rate 1350000 lane count 4
[04:35:18] [PASSED] Link rate 1350000 lane count 2
[04:35:18] [PASSED] Link rate 1350000 lane count 1
[04:35:18] [PASSED] Link rate 1000000 lane count 4
[04:35:18] [PASSED] Link rate 1000000 lane count 2
[04:35:18] [PASSED] Link rate 1000000 lane count 1
[04:35:18] [PASSED] Link rate 810000 lane count 4
[04:35:18] [PASSED] Link rate 810000 lane count 2
[04:35:18] [PASSED] Link rate 810000 lane count 1
[04:35:18] [PASSED] Link rate 540000 lane count 4
[04:35:18] [PASSED] Link rate 540000 lane count 2
[04:35:18] [PASSED] Link rate 540000 lane count 1
[04:35:18] [PASSED] Link rate 270000 lane count 4
[04:35:18] [PASSED] Link rate 270000 lane count 2
[04:35:18] [PASSED] Link rate 270000 lane count 1
[04:35:18] [PASSED] Link rate 162000 lane count 4
[04:35:18] [PASSED] Link rate 162000 lane count 2
[04:35:18] [PASSED] Link rate 162000 lane count 1
[04:35:18] ========== [PASSED] drm_test_dp_mst_calc_pbn_div ===========
[04:35:18] ========= drm_test_dp_mst_sideband_msg_req_decode =========
[04:35:18] [PASSED] DP_ENUM_PATH_RESOURCES with port number
[04:35:18] [PASSED] DP_POWER_UP_PHY with port number
[04:35:18] [PASSED] DP_POWER_DOWN_PHY with port number
[04:35:18] [PASSED] DP_ALLOCATE_PAYLOAD with SDP stream sinks
[04:35:18] [PASSED] DP_ALLOCATE_PAYLOAD with port number
[04:35:18] [PASSED] DP_ALLOCATE_PAYLOAD with VCPI
[04:35:18] [PASSED] DP_ALLOCATE_PAYLOAD with PBN
[04:35:18] [PASSED] DP_QUERY_PAYLOAD with port number
[04:35:18] [PASSED] DP_QUERY_PAYLOAD with VCPI
[04:35:18] [PASSED] DP_REMOTE_DPCD_READ with port number
[04:35:18] [PASSED] DP_REMOTE_DPCD_READ with DPCD address
[04:35:18] [PASSED] DP_REMOTE_DPCD_READ with max number of bytes
[04:35:18] [PASSED] DP_REMOTE_DPCD_WRITE with port number
[04:35:18] [PASSED] DP_REMOTE_DPCD_WRITE with DPCD address
[04:35:18] [PASSED] DP_REMOTE_DPCD_WRITE with data array
[04:35:18] [PASSED] DP_REMOTE_I2C_READ with port number
[04:35:18] [PASSED] DP_REMOTE_I2C_READ with I2C device ID
[04:35:18] [PASSED] DP_REMOTE_I2C_READ with transactions array
[04:35:18] [PASSED] DP_REMOTE_I2C_WRITE with port number
[04:35:18] [PASSED] DP_REMOTE_I2C_WRITE with I2C device ID
[04:35:18] [PASSED] DP_REMOTE_I2C_WRITE with data array
[04:35:18] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream ID
[04:35:18] [PASSED] DP_QUERY_STREAM_ENC_STATUS with client ID
[04:35:18] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream event
[04:35:18] [PASSED] DP_QUERY_STREAM_ENC_STATUS with valid stream event
[04:35:18] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream behavior
[04:35:18] [PASSED] DP_QUERY_STREAM_ENC_STATUS with a valid stream behavior
[04:35:18] ===== [PASSED] drm_test_dp_mst_sideband_msg_req_decode =====
[04:35:18] ================ [PASSED] drm_dp_mst_helper ================
[04:35:18] ================== drm_exec (7 subtests) ===================
[04:35:18] [PASSED] sanitycheck
[04:35:18] [PASSED] test_lock
[04:35:18] [PASSED] test_lock_unlock
[04:35:18] [PASSED] test_duplicates
[04:35:18] [PASSED] test_prepare
[04:35:18] [PASSED] test_prepare_array
[04:35:18] [PASSED] test_multiple_loops
[04:35:18] ==================== [PASSED] drm_exec =====================
[04:35:18] =========== drm_format_helper_test (17 subtests) ===========
[04:35:18] ============== drm_test_fb_xrgb8888_to_gray8 ==============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ========== [PASSED] drm_test_fb_xrgb8888_to_gray8 ==========
[04:35:18] ============= drm_test_fb_xrgb8888_to_rgb332 ==============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb332 ==========
[04:35:18] ============= drm_test_fb_xrgb8888_to_rgb565 ==============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb565 ==========
[04:35:18] ============ drm_test_fb_xrgb8888_to_xrgb1555 =============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ======== [PASSED] drm_test_fb_xrgb8888_to_xrgb1555 =========
[04:35:18] ============ drm_test_fb_xrgb8888_to_argb1555 =============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ======== [PASSED] drm_test_fb_xrgb8888_to_argb1555 =========
[04:35:18] ============ drm_test_fb_xrgb8888_to_rgba5551 =============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ======== [PASSED] drm_test_fb_xrgb8888_to_rgba5551 =========
[04:35:18] ============= drm_test_fb_xrgb8888_to_rgb888 ==============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb888 ==========
[04:35:18] ============= drm_test_fb_xrgb8888_to_bgr888 ==============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ========= [PASSED] drm_test_fb_xrgb8888_to_bgr888 ==========
[04:35:18] ============ drm_test_fb_xrgb8888_to_argb8888 =============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ======== [PASSED] drm_test_fb_xrgb8888_to_argb8888 =========
[04:35:18] =========== drm_test_fb_xrgb8888_to_xrgb2101010 ===========
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ======= [PASSED] drm_test_fb_xrgb8888_to_xrgb2101010 =======
[04:35:18] =========== drm_test_fb_xrgb8888_to_argb2101010 ===========
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ======= [PASSED] drm_test_fb_xrgb8888_to_argb2101010 =======
[04:35:18] ============== drm_test_fb_xrgb8888_to_mono ===============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ========== [PASSED] drm_test_fb_xrgb8888_to_mono ===========
[04:35:18] ==================== drm_test_fb_swab =====================
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ================ [PASSED] drm_test_fb_swab =================
[04:35:18] ============ drm_test_fb_xrgb8888_to_xbgr8888 =============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ======== [PASSED] drm_test_fb_xrgb8888_to_xbgr8888 =========
[04:35:18] ============ drm_test_fb_xrgb8888_to_abgr8888 =============
[04:35:18] [PASSED] single_pixel_source_buffer
[04:35:18] [PASSED] single_pixel_clip_rectangle
[04:35:18] [PASSED] well_known_colors
[04:35:18] [PASSED] destination_pitch
[04:35:18] ======== [PASSED] drm_test_fb_xrgb8888_to_abgr8888 =========
[04:35:18] ================= drm_test_fb_clip_offset =================
[04:35:18] [PASSED] pass through
[04:35:18] [PASSED] horizontal offset
[04:35:18] [PASSED] vertical offset
[04:35:18] [PASSED] horizontal and vertical offset
[04:35:18] [PASSED] horizontal offset (custom pitch)
[04:35:18] [PASSED] vertical offset (custom pitch)
[04:35:18] [PASSED] horizontal and vertical offset (custom pitch)
[04:35:18] ============= [PASSED] drm_test_fb_clip_offset =============
[04:35:18] =================== drm_test_fb_memcpy ====================
[04:35:18] [PASSED] single_pixel_source_buffer: XR24 little-endian (0x34325258)
[04:35:18] [PASSED] single_pixel_source_buffer: XRA8 little-endian (0x38415258)
[04:35:18] [PASSED] single_pixel_source_buffer: YU24 little-endian (0x34325559)
[04:35:18] [PASSED] single_pixel_clip_rectangle: XB24 little-endian (0x34324258)
[04:35:18] [PASSED] single_pixel_clip_rectangle: XRA8 little-endian (0x38415258)
[04:35:18] [PASSED] single_pixel_clip_rectangle: YU24 little-endian (0x34325559)
[04:35:18] [PASSED] well_known_colors: XB24 little-endian (0x34324258)
[04:35:18] [PASSED] well_known_colors: XRA8 little-endian (0x38415258)
[04:35:18] [PASSED] well_known_colors: YU24 little-endian (0x34325559)
[04:35:18] [PASSED] destination_pitch: XB24 little-endian (0x34324258)
[04:35:18] [PASSED] destination_pitch: XRA8 little-endian (0x38415258)
[04:35:18] [PASSED] destination_pitch: YU24 little-endian (0x34325559)
[04:35:18] =============== [PASSED] drm_test_fb_memcpy ================
[04:35:18] ============= [PASSED] drm_format_helper_test ==============
[04:35:18] ================= drm_format (18 subtests) =================
[04:35:18] [PASSED] drm_test_format_block_width_invalid
[04:35:18] [PASSED] drm_test_format_block_width_one_plane
[04:35:18] [PASSED] drm_test_format_block_width_two_plane
[04:35:18] [PASSED] drm_test_format_block_width_three_plane
[04:35:18] [PASSED] drm_test_format_block_width_tiled
[04:35:18] [PASSED] drm_test_format_block_height_invalid
[04:35:18] [PASSED] drm_test_format_block_height_one_plane
[04:35:18] [PASSED] drm_test_format_block_height_two_plane
[04:35:18] [PASSED] drm_test_format_block_height_three_plane
[04:35:18] [PASSED] drm_test_format_block_height_tiled
[04:35:18] [PASSED] drm_test_format_min_pitch_invalid
[04:35:18] [PASSED] drm_test_format_min_pitch_one_plane_8bpp
[04:35:18] [PASSED] drm_test_format_min_pitch_one_plane_16bpp
[04:35:18] [PASSED] drm_test_format_min_pitch_one_plane_24bpp
[04:35:18] [PASSED] drm_test_format_min_pitch_one_plane_32bpp
[04:35:18] [PASSED] drm_test_format_min_pitch_two_plane
[04:35:18] [PASSED] drm_test_format_min_pitch_three_plane_8bpp
[04:35:18] [PASSED] drm_test_format_min_pitch_tiled
[04:35:18] =================== [PASSED] drm_format ====================
[04:35:18] ============== drm_framebuffer (10 subtests) ===============
[04:35:18] ========== drm_test_framebuffer_check_src_coords ==========
[04:35:18] [PASSED] Success: source fits into fb
[04:35:18] [PASSED] Fail: overflowing fb with x-axis coordinate
[04:35:18] [PASSED] Fail: overflowing fb with y-axis coordinate
[04:35:18] [PASSED] Fail: overflowing fb with source width
[04:35:18] [PASSED] Fail: overflowing fb with source height
[04:35:18] ====== [PASSED] drm_test_framebuffer_check_src_coords ======
[04:35:18] [PASSED] drm_test_framebuffer_cleanup
[04:35:18] =============== drm_test_framebuffer_create ===============
[04:35:18] [PASSED] ABGR8888 normal sizes
[04:35:18] [PASSED] ABGR8888 max sizes
[04:35:18] [PASSED] ABGR8888 pitch greater than min required
[04:35:18] [PASSED] ABGR8888 pitch less than min required
[04:35:18] [PASSED] ABGR8888 Invalid width
[04:35:18] [PASSED] ABGR8888 Invalid buffer handle
[04:35:18] [PASSED] No pixel format
[04:35:18] [PASSED] ABGR8888 Width 0
[04:35:18] [PASSED] ABGR8888 Height 0
[04:35:18] [PASSED] ABGR8888 Out of bound height * pitch combination
[04:35:18] [PASSED] ABGR8888 Large buffer offset
[04:35:18] [PASSED] ABGR8888 Buffer offset for inexistent plane
[04:35:18] [PASSED] ABGR8888 Invalid flag
[04:35:18] [PASSED] ABGR8888 Set DRM_MODE_FB_MODIFIERS without modifiers
[04:35:18] [PASSED] ABGR8888 Valid buffer modifier
[04:35:18] [PASSED] ABGR8888 Invalid buffer modifier(DRM_FORMAT_MOD_SAMSUNG_64_32_TILE)
[04:35:18] [PASSED] ABGR8888 Extra pitches without DRM_MODE_FB_MODIFIERS
[04:35:18] [PASSED] ABGR8888 Extra pitches with DRM_MODE_FB_MODIFIERS
[04:35:18] [PASSED] NV12 Normal sizes
[04:35:18] [PASSED] NV12 Max sizes
[04:35:18] [PASSED] NV12 Invalid pitch
[04:35:18] [PASSED] NV12 Invalid modifier/missing DRM_MODE_FB_MODIFIERS flag
[04:35:18] [PASSED] NV12 different modifier per-plane
[04:35:18] [PASSED] NV12 with DRM_FORMAT_MOD_SAMSUNG_64_32_TILE
[04:35:18] [PASSED] NV12 Valid modifiers without DRM_MODE_FB_MODIFIERS
[04:35:18] [PASSED] NV12 Modifier for inexistent plane
[04:35:18] [PASSED] NV12 Handle for inexistent plane
[04:35:18] [PASSED] NV12 Handle for inexistent plane without DRM_MODE_FB_MODIFIERS
[04:35:18] [PASSED] YVU420 DRM_MODE_FB_MODIFIERS set without modifier
[04:35:18] [PASSED] YVU420 Normal sizes
[04:35:18] [PASSED] YVU420 Max sizes
[04:35:18] [PASSED] YVU420 Invalid pitch
[04:35:18] [PASSED] YVU420 Different pitches
[04:35:18] [PASSED] YVU420 Different buffer offsets/pitches
[04:35:18] [PASSED] YVU420 Modifier set just for plane 0, without DRM_MODE_FB_MODIFIERS
[04:35:18] [PASSED] YVU420 Modifier set just for planes 0, 1, without DRM_MODE_FB_MODIFIERS
[04:35:18] [PASSED] YVU420 Modifier set just for plane 0, 1, with DRM_MODE_FB_MODIFIERS
[04:35:18] [PASSED] YVU420 Valid modifier
[04:35:18] [PASSED] YVU420 Different modifiers per plane
[04:35:18] [PASSED] YVU420 Modifier for inexistent plane
[04:35:18] [PASSED] YUV420_10BIT Invalid modifier(DRM_FORMAT_MOD_LINEAR)
[04:35:18] [PASSED] X0L2 Normal sizes
[04:35:18] [PASSED] X0L2 Max sizes
[04:35:18] [PASSED] X0L2 Invalid pitch
[04:35:18] [PASSED] X0L2 Pitch greater than minimum required
[04:35:18] [PASSED] X0L2 Handle for inexistent plane
[04:35:18] [PASSED] X0L2 Offset for inexistent plane, without DRM_MODE_FB_MODIFIERS set
[04:35:18] [PASSED] X0L2 Modifier without DRM_MODE_FB_MODIFIERS set
[04:35:18] [PASSED] X0L2 Valid modifier
[04:35:18] [PASSED] X0L2 Modifier for inexistent plane
[04:35:18] =========== [PASSED] drm_test_framebuffer_create ===========
[04:35:18] [PASSED] drm_test_framebuffer_free
[04:35:18] [PASSED] drm_test_framebuffer_init
[04:35:18] [PASSED] drm_test_framebuffer_init_bad_format
[04:35:18] [PASSED] drm_test_framebuffer_init_dev_mismatch
[04:35:18] [PASSED] drm_test_framebuffer_lookup
[04:35:18] [PASSED] drm_test_framebuffer_lookup_inexistent
[04:35:18] [PASSED] drm_test_framebuffer_modifiers_not_supported
[04:35:18] ================= [PASSED] drm_framebuffer =================
[04:35:18] ================ drm_gem_shmem (8 subtests) ================
[04:35:18] [PASSED] drm_gem_shmem_test_obj_create
[04:35:18] [PASSED] drm_gem_shmem_test_obj_create_private
[04:35:18] [PASSED] drm_gem_shmem_test_pin_pages
[04:35:18] [PASSED] drm_gem_shmem_test_vmap
[04:35:18] [PASSED] drm_gem_shmem_test_get_sg_table
[04:35:18] [PASSED] drm_gem_shmem_test_get_pages_sgt
[04:35:18] [PASSED] drm_gem_shmem_test_madvise
[04:35:18] [PASSED] drm_gem_shmem_test_purge
[04:35:18] ================== [PASSED] drm_gem_shmem ==================
[04:35:18] === drm_atomic_helper_connector_hdmi_check (27 subtests) ===
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode_vic_1
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode_vic_1
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode_vic_1
[04:35:18] ====== drm_test_check_broadcast_rgb_cea_mode_yuv420 =======
[04:35:18] [PASSED] Automatic
[04:35:18] [PASSED] Full
[04:35:18] [PASSED] Limited 16:235
[04:35:18] == [PASSED] drm_test_check_broadcast_rgb_cea_mode_yuv420 ===
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_changed
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_not_changed
[04:35:18] [PASSED] drm_test_check_disable_connector
[04:35:18] [PASSED] drm_test_check_hdmi_funcs_reject_rate
[04:35:18] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_rgb
[04:35:18] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_yuv420
[04:35:18] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv422
[04:35:18] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv420
[04:35:18] [PASSED] drm_test_check_driver_unsupported_fallback_yuv420
[04:35:18] [PASSED] drm_test_check_output_bpc_crtc_mode_changed
[04:35:18] [PASSED] drm_test_check_output_bpc_crtc_mode_not_changed
[04:35:18] [PASSED] drm_test_check_output_bpc_dvi
[04:35:18] [PASSED] drm_test_check_output_bpc_format_vic_1
[04:35:18] [PASSED] drm_test_check_output_bpc_format_display_8bpc_only
[04:35:18] [PASSED] drm_test_check_output_bpc_format_display_rgb_only
[04:35:18] [PASSED] drm_test_check_output_bpc_format_driver_8bpc_only
[04:35:18] [PASSED] drm_test_check_output_bpc_format_driver_rgb_only
[04:35:18] [PASSED] drm_test_check_tmds_char_rate_rgb_8bpc
[04:35:18] [PASSED] drm_test_check_tmds_char_rate_rgb_10bpc
[04:35:18] [PASSED] drm_test_check_tmds_char_rate_rgb_12bpc
[04:35:18] ===== [PASSED] drm_atomic_helper_connector_hdmi_check ======
[04:35:18] === drm_atomic_helper_connector_hdmi_reset (6 subtests) ====
[04:35:18] [PASSED] drm_test_check_broadcast_rgb_value
[04:35:18] [PASSED] drm_test_check_bpc_8_value
[04:35:18] [PASSED] drm_test_check_bpc_10_value
[04:35:18] [PASSED] drm_test_check_bpc_12_value
[04:35:18] [PASSED] drm_test_check_format_value
[04:35:18] [PASSED] drm_test_check_tmds_char_value
[04:35:18] ===== [PASSED] drm_atomic_helper_connector_hdmi_reset ======
[04:35:18] = drm_atomic_helper_connector_hdmi_mode_valid (4 subtests) =
[04:35:18] [PASSED] drm_test_check_mode_valid
[04:35:18] [PASSED] drm_test_check_mode_valid_reject
[04:35:18] [PASSED] drm_test_check_mode_valid_reject_rate
[04:35:18] [PASSED] drm_test_check_mode_valid_reject_max_clock
[04:35:18] === [PASSED] drm_atomic_helper_connector_hdmi_mode_valid ===
[04:35:18] ================= drm_managed (2 subtests) =================
[04:35:18] [PASSED] drm_test_managed_release_action
[04:35:18] [PASSED] drm_test_managed_run_action
[04:35:18] =================== [PASSED] drm_managed ===================
[04:35:18] =================== drm_mm (6 subtests) ====================
[04:35:18] [PASSED] drm_test_mm_init
[04:35:18] [PASSED] drm_test_mm_debug
[04:35:18] [PASSED] drm_test_mm_align32
[04:35:18] [PASSED] drm_test_mm_align64
[04:35:18] [PASSED] drm_test_mm_lowest
[04:35:18] [PASSED] drm_test_mm_highest
[04:35:18] ===================== [PASSED] drm_mm ======================
[04:35:18] ============= drm_modes_analog_tv (5 subtests) =============
[04:35:18] [PASSED] drm_test_modes_analog_tv_mono_576i
[04:35:18] [PASSED] drm_test_modes_analog_tv_ntsc_480i
[04:35:18] [PASSED] drm_test_modes_analog_tv_ntsc_480i_inlined
[04:35:18] [PASSED] drm_test_modes_analog_tv_pal_576i
[04:35:18] [PASSED] drm_test_modes_analog_tv_pal_576i_inlined
[04:35:18] =============== [PASSED] drm_modes_analog_tv ===============
[04:35:18] ============== drm_plane_helper (2 subtests) ===============
[04:35:18] =============== drm_test_check_plane_state ================
[04:35:18] [PASSED] clipping_simple
[04:35:18] [PASSED] clipping_rotate_reflect
[04:35:18] [PASSED] positioning_simple
[04:35:18] [PASSED] upscaling
[04:35:18] [PASSED] downscaling
[04:35:18] [PASSED] rounding1
[04:35:18] [PASSED] rounding2
[04:35:18] [PASSED] rounding3
[04:35:18] [PASSED] rounding4
[04:35:18] =========== [PASSED] drm_test_check_plane_state ============
[04:35:18] =========== drm_test_check_invalid_plane_state ============
[04:35:18] [PASSED] positioning_invalid
[04:35:18] [PASSED] upscaling_invalid
[04:35:18] [PASSED] downscaling_invalid
[04:35:18] ======= [PASSED] drm_test_check_invalid_plane_state ========
[04:35:18] ================ [PASSED] drm_plane_helper =================
[04:35:18] ====== drm_connector_helper_tv_get_modes (1 subtest) =======
[04:35:18] ====== drm_test_connector_helper_tv_get_modes_check =======
[04:35:18] [PASSED] None
[04:35:18] [PASSED] PAL
[04:35:18] [PASSED] NTSC
[04:35:18] [PASSED] Both, NTSC Default
[04:35:18] [PASSED] Both, PAL Default
[04:35:18] [PASSED] Both, NTSC Default, with PAL on command-line
[04:35:18] [PASSED] Both, PAL Default, with NTSC on command-line
[04:35:18] == [PASSED] drm_test_connector_helper_tv_get_modes_check ===
[04:35:18] ======== [PASSED] drm_connector_helper_tv_get_modes ========
[04:35:18] ================== drm_rect (9 subtests) ===================
[04:35:18] [PASSED] drm_test_rect_clip_scaled_div_by_zero
[04:35:18] [PASSED] drm_test_rect_clip_scaled_not_clipped
[04:35:18] [PASSED] drm_test_rect_clip_scaled_clipped
[04:35:18] [PASSED] drm_test_rect_clip_scaled_signed_vs_unsigned
[04:35:18] ================= drm_test_rect_intersect =================
[04:35:18] [PASSED] top-left x bottom-right: 2x2+1+1 x 2x2+0+0
[04:35:18] [PASSED] top-right x bottom-left: 2x2+0+0 x 2x2+1-1
[04:35:18] [PASSED] bottom-left x top-right: 2x2+1-1 x 2x2+0+0
[04:35:18] [PASSED] bottom-right x top-left: 2x2+0+0 x 2x2+1+1
[04:35:18] [PASSED] right x left: 2x1+0+0 x 3x1+1+0
[04:35:18] [PASSED] left x right: 3x1+1+0 x 2x1+0+0
[04:35:18] [PASSED] up x bottom: 1x2+0+0 x 1x3+0-1
[04:35:18] [PASSED] bottom x up: 1x3+0-1 x 1x2+0+0
[04:35:18] [PASSED] touching corner: 1x1+0+0 x 2x2+1+1
[04:35:18] [PASSED] touching side: 1x1+0+0 x 1x1+1+0
[04:35:18] [PASSED] equal rects: 2x2+0+0 x 2x2+0+0
[04:35:18] [PASSED] inside another: 2x2+0+0 x 1x1+1+1
[04:35:18] [PASSED] far away: 1x1+0+0 x 1x1+3+6
[04:35:18] [PASSED] points intersecting: 0x0+5+10 x 0x0+5+10
[04:35:18] [PASSED] points not intersecting: 0x0+0+0 x 0x0+5+10
[04:35:18] ============= [PASSED] drm_test_rect_intersect =============
[04:35:18] ================ drm_test_rect_calc_hscale ================
[04:35:18] [PASSED] normal use
[04:35:18] [PASSED] out of max range
[04:35:18] [PASSED] out of min range
[04:35:18] [PASSED] zero dst
[04:35:18] [PASSED] negative src
[04:35:18] [PASSED] negative dst
[04:35:18] ============ [PASSED] drm_test_rect_calc_hscale ============
[04:35:18] ================ drm_test_rect_calc_vscale ================
[04:35:18] [PASSED] normal use
stty: 'standard input': Inappropriate ioctl for device
[04:35:18] [PASSED] out of max range
[04:35:18] [PASSED] out of min range
[04:35:18] [PASSED] zero dst
[04:35:18] [PASSED] negative src
[04:35:18] [PASSED] negative dst
[04:35:18] ============ [PASSED] drm_test_rect_calc_vscale ============
[04:35:18] ================== drm_test_rect_rotate ===================
[04:35:18] [PASSED] reflect-x
[04:35:18] [PASSED] reflect-y
[04:35:18] [PASSED] rotate-0
[04:35:18] [PASSED] rotate-90
[04:35:18] [PASSED] rotate-180
[04:35:18] [PASSED] rotate-270
[04:35:18] ============== [PASSED] drm_test_rect_rotate ===============
[04:35:18] ================ drm_test_rect_rotate_inv =================
[04:35:18] [PASSED] reflect-x
[04:35:18] [PASSED] reflect-y
[04:35:18] [PASSED] rotate-0
[04:35:18] [PASSED] rotate-90
[04:35:18] [PASSED] rotate-180
[04:35:18] [PASSED] rotate-270
[04:35:18] ============ [PASSED] drm_test_rect_rotate_inv =============
[04:35:18] ==================== [PASSED] drm_rect =====================
[04:35:18] ============ drm_sysfb_modeset_test (1 subtest) ============
[04:35:18] ============ drm_test_sysfb_build_fourcc_list =============
[04:35:18] [PASSED] no native formats
[04:35:18] [PASSED] XRGB8888 as native format
[04:35:18] [PASSED] remove duplicates
[04:35:18] [PASSED] convert alpha formats
[04:35:18] [PASSED] random formats
[04:35:18] ======== [PASSED] drm_test_sysfb_build_fourcc_list =========
[04:35:18] ============= [PASSED] drm_sysfb_modeset_test ==============
[04:35:18] ================== drm_fixp (2 subtests) ===================
[04:35:18] [PASSED] drm_test_int2fixp
[04:35:18] [PASSED] drm_test_sm2fixp
[04:35:18] ==================== [PASSED] drm_fixp =====================
[04:35:18] ============================================================
[04:35:18] Testing complete. Ran 624 tests: passed: 624
[04:35:18] Elapsed time: 27.354s total, 1.682s configuring, 25.254s building, 0.374s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/ttm/tests/.kunitconfig
[04:35:18] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[04:35:20] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=48
[04:35:29] Starting KUnit Kernel (1/1)...
[04:35:29] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[04:35:30] ================= ttm_device (5 subtests) ==================
[04:35:30] [PASSED] ttm_device_init_basic
[04:35:30] [PASSED] ttm_device_init_multiple
[04:35:30] [PASSED] ttm_device_fini_basic
[04:35:30] [PASSED] ttm_device_init_no_vma_man
[04:35:30] ================== ttm_device_init_pools ==================
[04:35:30] [PASSED] No DMA allocations, no DMA32 required
[04:35:30] [PASSED] DMA allocations, DMA32 required
[04:35:30] [PASSED] No DMA allocations, DMA32 required
[04:35:30] [PASSED] DMA allocations, no DMA32 required
[04:35:30] ============== [PASSED] ttm_device_init_pools ==============
[04:35:30] =================== [PASSED] ttm_device ====================
[04:35:30] ================== ttm_pool (8 subtests) ===================
[04:35:30] ================== ttm_pool_alloc_basic ===================
[04:35:30] [PASSED] One page
[04:35:30] [PASSED] More than one page
[04:35:30] [PASSED] Above the allocation limit
[04:35:30] [PASSED] One page, with coherent DMA mappings enabled
[04:35:30] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[04:35:30] ============== [PASSED] ttm_pool_alloc_basic ===============
[04:35:30] ============== ttm_pool_alloc_basic_dma_addr ==============
[04:35:30] [PASSED] One page
[04:35:30] [PASSED] More than one page
[04:35:30] [PASSED] Above the allocation limit
[04:35:30] [PASSED] One page, with coherent DMA mappings enabled
[04:35:30] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[04:35:30] ========== [PASSED] ttm_pool_alloc_basic_dma_addr ==========
[04:35:30] [PASSED] ttm_pool_alloc_order_caching_match
[04:35:30] [PASSED] ttm_pool_alloc_caching_mismatch
[04:35:30] [PASSED] ttm_pool_alloc_order_mismatch
[04:35:30] [PASSED] ttm_pool_free_dma_alloc
[04:35:30] [PASSED] ttm_pool_free_no_dma_alloc
[04:35:30] [PASSED] ttm_pool_fini_basic
[04:35:30] ==================== [PASSED] ttm_pool =====================
[04:35:30] ================ ttm_resource (8 subtests) =================
[04:35:30] ================= ttm_resource_init_basic =================
[04:35:30] [PASSED] Init resource in TTM_PL_SYSTEM
[04:35:30] [PASSED] Init resource in TTM_PL_VRAM
[04:35:30] [PASSED] Init resource in a private placement
[04:35:30] [PASSED] Init resource in TTM_PL_SYSTEM, set placement flags
[04:35:30] ============= [PASSED] ttm_resource_init_basic =============
[04:35:30] [PASSED] ttm_resource_init_pinned
[04:35:30] [PASSED] ttm_resource_fini_basic
[04:35:30] [PASSED] ttm_resource_manager_init_basic
[04:35:30] [PASSED] ttm_resource_manager_usage_basic
[04:35:30] [PASSED] ttm_resource_manager_set_used_basic
[04:35:30] [PASSED] ttm_sys_man_alloc_basic
[04:35:30] [PASSED] ttm_sys_man_free_basic
[04:35:30] ================== [PASSED] ttm_resource ===================
[04:35:30] =================== ttm_tt (15 subtests) ===================
[04:35:30] ==================== ttm_tt_init_basic ====================
[04:35:30] [PASSED] Page-aligned size
[04:35:30] [PASSED] Extra pages requested
[04:35:30] ================ [PASSED] ttm_tt_init_basic ================
[04:35:30] [PASSED] ttm_tt_init_misaligned
[04:35:30] [PASSED] ttm_tt_fini_basic
[04:35:30] [PASSED] ttm_tt_fini_sg
[04:35:30] [PASSED] ttm_tt_fini_shmem
[04:35:30] [PASSED] ttm_tt_create_basic
[04:35:30] [PASSED] ttm_tt_create_invalid_bo_type
[04:35:30] [PASSED] ttm_tt_create_ttm_exists
[04:35:30] [PASSED] ttm_tt_create_failed
[04:35:30] [PASSED] ttm_tt_destroy_basic
[04:35:30] [PASSED] ttm_tt_populate_null_ttm
[04:35:30] [PASSED] ttm_tt_populate_populated_ttm
[04:35:30] [PASSED] ttm_tt_unpopulate_basic
[04:35:30] [PASSED] ttm_tt_unpopulate_empty_ttm
[04:35:30] [PASSED] ttm_tt_swapin_basic
[04:35:30] ===================== [PASSED] ttm_tt ======================
[04:35:30] =================== ttm_bo (14 subtests) ===================
[04:35:30] =========== ttm_bo_reserve_optimistic_no_ticket ===========
[04:35:30] [PASSED] Cannot be interrupted and sleeps
[04:35:30] [PASSED] Cannot be interrupted, locks straight away
[04:35:30] [PASSED] Can be interrupted, sleeps
[04:35:30] ======= [PASSED] ttm_bo_reserve_optimistic_no_ticket =======
[04:35:30] [PASSED] ttm_bo_reserve_locked_no_sleep
[04:35:30] [PASSED] ttm_bo_reserve_no_wait_ticket
[04:35:30] [PASSED] ttm_bo_reserve_double_resv
[04:35:30] [PASSED] ttm_bo_reserve_interrupted
[04:35:30] [PASSED] ttm_bo_reserve_deadlock
[04:35:30] [PASSED] ttm_bo_unreserve_basic
[04:35:30] [PASSED] ttm_bo_unreserve_pinned
[04:35:30] [PASSED] ttm_bo_unreserve_bulk
[04:35:30] [PASSED] ttm_bo_fini_basic
[04:35:30] [PASSED] ttm_bo_fini_shared_resv
[04:35:30] [PASSED] ttm_bo_pin_basic
[04:35:30] [PASSED] ttm_bo_pin_unpin_resource
[04:35:30] [PASSED] ttm_bo_multiple_pin_one_unpin
[04:35:30] ===================== [PASSED] ttm_bo ======================
[04:35:30] ============== ttm_bo_validate (21 subtests) ===============
[04:35:30] ============== ttm_bo_init_reserved_sys_man ===============
[04:35:30] [PASSED] Buffer object for userspace
[04:35:30] [PASSED] Kernel buffer object
[04:35:30] [PASSED] Shared buffer object
[04:35:30] ========== [PASSED] ttm_bo_init_reserved_sys_man ===========
[04:35:30] ============== ttm_bo_init_reserved_mock_man ==============
[04:35:30] [PASSED] Buffer object for userspace
[04:35:30] [PASSED] Kernel buffer object
[04:35:30] [PASSED] Shared buffer object
[04:35:30] ========== [PASSED] ttm_bo_init_reserved_mock_man ==========
[04:35:30] [PASSED] ttm_bo_init_reserved_resv
[04:35:30] ================== ttm_bo_validate_basic ==================
[04:35:30] [PASSED] Buffer object for userspace
[04:35:30] [PASSED] Kernel buffer object
[04:35:30] [PASSED] Shared buffer object
[04:35:30] ============== [PASSED] ttm_bo_validate_basic ==============
[04:35:30] [PASSED] ttm_bo_validate_invalid_placement
[04:35:30] ============= ttm_bo_validate_same_placement ==============
[04:35:30] [PASSED] System manager
[04:35:30] [PASSED] VRAM manager
[04:35:30] ========= [PASSED] ttm_bo_validate_same_placement ==========
[04:35:30] [PASSED] ttm_bo_validate_failed_alloc
[04:35:30] [PASSED] ttm_bo_validate_pinned
[04:35:30] [PASSED] ttm_bo_validate_busy_placement
[04:35:30] ================ ttm_bo_validate_multihop =================
[04:35:30] [PASSED] Buffer object for userspace
[04:35:30] [PASSED] Kernel buffer object
[04:35:30] [PASSED] Shared buffer object
[04:35:30] ============ [PASSED] ttm_bo_validate_multihop =============
[04:35:30] ========== ttm_bo_validate_no_placement_signaled ==========
[04:35:30] [PASSED] Buffer object in system domain, no page vector
[04:35:30] [PASSED] Buffer object in system domain with an existing page vector
[04:35:30] ====== [PASSED] ttm_bo_validate_no_placement_signaled ======
[04:35:30] ======== ttm_bo_validate_no_placement_not_signaled ========
[04:35:30] [PASSED] Buffer object for userspace
[04:35:30] [PASSED] Kernel buffer object
[04:35:30] [PASSED] Shared buffer object
[04:35:30] ==== [PASSED] ttm_bo_validate_no_placement_not_signaled ====
[04:35:30] [PASSED] ttm_bo_validate_move_fence_signaled
[04:35:30] ========= ttm_bo_validate_move_fence_not_signaled =========
[04:35:30] [PASSED] Waits for GPU
[04:35:30] [PASSED] Tries to lock straight away
[04:35:30] ===== [PASSED] ttm_bo_validate_move_fence_not_signaled =====
[04:35:30] [PASSED] ttm_bo_validate_happy_evict
[04:35:30] [PASSED] ttm_bo_validate_all_pinned_evict
[04:35:30] [PASSED] ttm_bo_validate_allowed_only_evict
[04:35:30] [PASSED] ttm_bo_validate_deleted_evict
[04:35:30] [PASSED] ttm_bo_validate_busy_domain_evict
[04:35:30] [PASSED] ttm_bo_validate_evict_gutting
[04:35:30] [PASSED] ttm_bo_validate_recrusive_evict
stty: 'standard input': Inappropriate ioctl for device
[04:35:30] ================= [PASSED] ttm_bo_validate =================
[04:35:30] ============================================================
[04:35:30] Testing complete. Ran 101 tests: passed: 101
[04:35:30] Elapsed time: 11.401s total, 1.663s configuring, 9.471s building, 0.229s running
+ cleanup
++ stat -c %u:%g /kernel
+ chown -R 1003:1003 /kernel
^ permalink raw reply [flat|nested] 11+ messages in thread
* ✗ Xe.CI.BAT: failure for Fix Cx0 Suspend Resume issue (rev2)
2026-01-14 3:42 [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Suraj Kandpal
` (3 preceding siblings ...)
2026-01-14 4:35 ` ✓ CI.KUnit: success for Fix Cx0 Suspend Resume issue (rev2) Patchwork
@ 2026-01-14 5:08 ` Patchwork
2026-01-14 11:50 ` ✗ Xe.CI.Full: " Patchwork
2026-01-14 15:10 ` [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Rodrigo Vivi
6 siblings, 0 replies; 11+ messages in thread
From: Patchwork @ 2026-01-14 5:08 UTC (permalink / raw)
To: Kandpal, Suraj; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 4177 bytes --]
== Series Details ==
Series: Fix Cx0 Suspend Resume issue (rev2)
URL : https://patchwork.freedesktop.org/series/159539/
State : failure
== Summary ==
CI Bug Log - changes from xe-4380-1580579412915ac76344699e53124b580060302d_BAT -> xe-pw-159539v2_BAT
====================================================
Summary
-------
**FAILURE**
Serious unknown changes coming with xe-pw-159539v2_BAT absolutely need to be
verified manually.
If you think the reported changes have nothing to do with the changes
introduced in xe-pw-159539v2_BAT, please notify your bug team (I915-ci-infra@lists.freedesktop.org) to allow them
to document this new failure mode, which will reduce false positives in CI.
Participating hosts (12 -> 12)
------------------------------
No changes in participating hosts
Possible new issues
-------------------
Here are the unknown changes that may have been introduced in xe-pw-159539v2_BAT:
### IGT changes ###
#### Possible regressions ####
* igt@kms_cursor_legacy@basic-flip-after-cursor-varying-size:
- bat-lnl-1: [PASS][1] -> [DMESG-WARN][2] +57 other tests dmesg-warn
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/bat-lnl-1/igt@kms_cursor_legacy@basic-flip-after-cursor-varying-size.html
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/bat-lnl-1/igt@kms_cursor_legacy@basic-flip-after-cursor-varying-size.html
* igt@kms_force_connector_basic@force-connector-state:
- bat-bmg-2: [PASS][3] -> [DMESG-WARN][4] +1 other test dmesg-warn
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/bat-bmg-2/igt@kms_force_connector_basic@force-connector-state.html
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/bat-bmg-2/igt@kms_force_connector_basic@force-connector-state.html
* igt@kms_hdmi_inject@inject-audio:
- bat-ptl-1: [PASS][5] -> [DMESG-WARN][6] +1 other test dmesg-warn
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/bat-ptl-1/igt@kms_hdmi_inject@inject-audio.html
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/bat-ptl-1/igt@kms_hdmi_inject@inject-audio.html
* igt@kms_pipe_crc_basic@hang-read-crc@pipe-c-edp-1:
- bat-ptl-2: [PASS][7] -> [DMESG-WARN][8] +72 other tests dmesg-warn
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/bat-ptl-2/igt@kms_pipe_crc_basic@hang-read-crc@pipe-c-edp-1.html
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/bat-ptl-2/igt@kms_pipe_crc_basic@hang-read-crc@pipe-c-edp-1.html
* igt@kms_pipe_crc_basic@nonblocking-crc@pipe-d-hdmi-a-3:
- bat-bmg-1: [PASS][9] -> [DMESG-WARN][10] +64 other tests dmesg-warn
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/bat-bmg-1/igt@kms_pipe_crc_basic@nonblocking-crc@pipe-d-hdmi-a-3.html
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/bat-bmg-1/igt@kms_pipe_crc_basic@nonblocking-crc@pipe-d-hdmi-a-3.html
Known issues
------------
Here are the changes found in xe-pw-159539v2_BAT that come from known issues:
### IGT changes ###
#### Possible fixes ####
* igt@xe_waitfence@engine:
- bat-dg2-oem2: [FAIL][11] ([Intel XE#6519]) -> [PASS][12]
[11]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/bat-dg2-oem2/igt@xe_waitfence@engine.html
[12]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/bat-dg2-oem2/igt@xe_waitfence@engine.html
[Intel XE#6519]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6519
Build changes
-------------
* Linux: xe-4380-1580579412915ac76344699e53124b580060302d -> xe-pw-159539v2
IGT_8699: 0b67ab25f2eb58b296872c8c34474b79353727d5 @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
xe-4380-1580579412915ac76344699e53124b580060302d: 1580579412915ac76344699e53124b580060302d
xe-pw-159539v2: 159539v2
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/index.html
[-- Attachment #2: Type: text/html, Size: 4914 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* RE: [PATCH v2 3/3] drm/i915/cx0: Rename intel_clear_response_ready flag
2026-01-14 3:42 ` [PATCH v2 3/3] drm/i915/cx0: Rename intel_clear_response_ready flag Suraj Kandpal
@ 2026-01-14 6:03 ` Garg, Nemesa
0 siblings, 0 replies; 11+ messages in thread
From: Garg, Nemesa @ 2026-01-14 6:03 UTC (permalink / raw)
To: Kandpal, Suraj, intel-xe@lists.freedesktop.org,
intel-gfx@lists.freedesktop.org
Cc: Nautiyal, Ankit K, Kandpal, Suraj
> -----Original Message-----
> From: Intel-gfx <intel-gfx-bounces@lists.freedesktop.org> On Behalf Of Suraj
> Kandpal
> Sent: Wednesday, January 14, 2026 9:13 AM
> To: intel-xe@lists.freedesktop.org; intel-gfx@lists.freedesktop.org
> Cc: Nautiyal, Ankit K <ankit.k.nautiyal@intel.com>; Kandpal, Suraj
> <suraj.kandpal@intel.com>
> Subject: [PATCH v2 3/3] drm/i915/cx0: Rename intel_clear_response_ready
> flag
>
> Rename the non static intel_clear_response_ready_flag to
> intel_cx0_clear_response_ready_flag so that we follow the naming standards
> of non static function.
>
> Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_cx0_phy.c | 14 +++++++-------
> drivers/gpu/drm/i915/display/intel_cx0_phy.h | 4 ++--
> drivers/gpu/drm/i915/display/intel_lt_phy.c | 2 +-
> 3 files changed, 10 insertions(+), 10 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> index 00c7fa9040ee..716b5108b4c4 100644
> --- a/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> +++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> @@ -127,8 +127,8 @@ static void intel_cx0_phy_transaction_end(struct
> intel_encoder *encoder, struct
> intel_display_power_put(display, POWER_DOMAIN_DC_OFF,
> wakeref); }
>
> -void intel_clear_response_ready_flag(struct intel_encoder *encoder,
> - int lane)
> +void intel_cx0_clear_response_ready_flag(struct intel_encoder *encoder,
> + int lane)
> {
> struct intel_display *display = to_intel_display(encoder);
>
> @@ -155,7 +155,7 @@ void intel_cx0_bus_reset(struct intel_encoder
> *encoder, int lane)
> return;
> }
>
> - intel_clear_response_ready_flag(encoder, lane);
> + intel_cx0_clear_response_ready_flag(encoder, lane);
> }
>
> int intel_cx0_wait_for_ack(struct intel_encoder *encoder, @@ -222,7 +222,7
> @@ static int __intel_cx0_read_once(struct intel_encoder *encoder,
> return -ETIMEDOUT;
> }
>
> - intel_clear_response_ready_flag(encoder, lane);
> + intel_cx0_clear_response_ready_flag(encoder, lane);
>
> intel_de_write(display, XELPDP_PORT_M2P_MSGBUS_CTL(display,
> port, lane),
> XELPDP_PORT_M2P_TRANSACTION_PENDING | @@ -
> 233,7 +233,7 @@ static int __intel_cx0_read_once(struct intel_encoder
> *encoder,
> if (ack < 0)
> return ack;
>
> - intel_clear_response_ready_flag(encoder, lane);
> + intel_cx0_clear_response_ready_flag(encoder, lane);
>
> /*
> * FIXME: Workaround to let HW to settle @@ -295,7 +295,7 @@
> static int __intel_cx0_write_once(struct intel_encoder *encoder,
> return -ETIMEDOUT;
> }
>
> - intel_clear_response_ready_flag(encoder, lane);
> + intel_cx0_clear_response_ready_flag(encoder, lane);
>
> intel_de_write(display, XELPDP_PORT_M2P_MSGBUS_CTL(display,
> port, lane),
> XELPDP_PORT_M2P_TRANSACTION_PENDING | @@ -
> 325,7 +325,7 @@ static int __intel_cx0_write_once(struct intel_encoder
> *encoder,
> return -EINVAL;
> }
>
> - intel_clear_response_ready_flag(encoder, lane);
> + intel_cx0_clear_response_ready_flag(encoder, lane);
>
> /*
> * FIXME: Workaround to let HW to settle diff --git
> a/drivers/gpu/drm/i915/display/intel_cx0_phy.h
> b/drivers/gpu/drm/i915/display/intel_cx0_phy.h
> index ae98ac23ea22..87d3bdaca3ec 100644
> --- a/drivers/gpu/drm/i915/display/intel_cx0_phy.h
> +++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.h
> @@ -25,8 +25,8 @@ struct intel_dpll_hw_state; struct intel_encoder; struct
> intel_hdmi;
>
> -void intel_clear_response_ready_flag(struct intel_encoder *encoder,
> - int lane);
> +void intel_cx0_clear_response_ready_flag(struct intel_encoder *encoder,
> + int lane);
> bool intel_encoder_is_c10phy(struct intel_encoder *encoder); void
> intel_mtl_pll_enable(struct intel_encoder *encoder,
> struct intel_dpll *pll,
> diff --git a/drivers/gpu/drm/i915/display/intel_lt_phy.c
> b/drivers/gpu/drm/i915/display/intel_lt_phy.c
> index 6cdae03ee172..e174ca011d50 100644
> --- a/drivers/gpu/drm/i915/display/intel_lt_phy.c
> +++ b/drivers/gpu/drm/i915/display/intel_lt_phy.c
> @@ -1106,7 +1106,7 @@ static int __intel_lt_phy_p2p_write_once(struct
> intel_encoder *encoder,
> * This is the time PHY takes to settle down after programming the
> PHY.
> */
> udelay(150);
> - intel_clear_response_ready_flag(encoder, lane);
> + intel_cx0_clear_response_ready_flag(encoder, lane);
> intel_lt_phy_clear_status_p2p(encoder, lane);
>
> return 0;
> --
LGTM,
Reviewed-by: Nemesa Garg <nemesa.garg@intel.com>
> 2.34.1
^ permalink raw reply [flat|nested] 11+ messages in thread
* ✗ Xe.CI.Full: failure for Fix Cx0 Suspend Resume issue (rev2)
2026-01-14 3:42 [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Suraj Kandpal
` (4 preceding siblings ...)
2026-01-14 5:08 ` ✗ Xe.CI.BAT: failure " Patchwork
@ 2026-01-14 11:50 ` Patchwork
2026-01-14 15:10 ` [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Rodrigo Vivi
6 siblings, 0 replies; 11+ messages in thread
From: Patchwork @ 2026-01-14 11:50 UTC (permalink / raw)
To: Kandpal, Suraj; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 15608 bytes --]
== Series Details ==
Series: Fix Cx0 Suspend Resume issue (rev2)
URL : https://patchwork.freedesktop.org/series/159539/
State : failure
== Summary ==
CI Bug Log - changes from xe-4380-1580579412915ac76344699e53124b580060302d_FULL -> xe-pw-159539v2_FULL
====================================================
Summary
-------
**WARNING**
Minor unknown changes coming with xe-pw-159539v2_FULL need to be verified
manually.
If you think the reported changes have nothing to do with the changes
introduced in xe-pw-159539v2_FULL, please notify your bug team (I915-ci-infra@lists.freedesktop.org) to allow them
to document this new failure mode, which will reduce false positives in CI.
Participating hosts (2 -> 2)
------------------------------
No changes in participating hosts
Possible new issues
-------------------
Here are the unknown changes that may have been introduced in xe-pw-159539v2_FULL:
### IGT changes ###
#### Warnings ####
* igt@xe_module_load@load:
- shard-lnl: ([PASS][1], [PASS][2], [PASS][3], [PASS][4], [PASS][5], [PASS][6], [PASS][7], [PASS][8], [PASS][9], [PASS][10], [PASS][11], [PASS][12], [PASS][13], [PASS][14], [PASS][15], [SKIP][16], [PASS][17], [PASS][18], [PASS][19], [PASS][20], [PASS][21], [PASS][22], [PASS][23], [PASS][24], [PASS][25], [PASS][26]) ([Intel XE#378]) -> ([DMESG-WARN][27], [DMESG-WARN][28], [DMESG-WARN][29], [DMESG-WARN][30], [DMESG-WARN][31], [DMESG-WARN][32], [DMESG-WARN][33], [DMESG-WARN][34], [DMESG-WARN][35], [DMESG-WARN][36], [DMESG-WARN][37], [DMESG-WARN][38], [DMESG-WARN][39], [DMESG-WARN][40], [DMESG-WARN][41], [DMESG-WARN][42], [DMESG-WARN][43], [DMESG-WARN][44], [DMESG-WARN][45], [DMESG-WARN][46], [DMESG-WARN][47], [DMESG-WARN][48], [DMESG-WARN][49], [DMESG-WARN][50], [DMESG-WARN][51])
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-7/igt@xe_module_load@load.html
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-2/igt@xe_module_load@load.html
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-3/igt@xe_module_load@load.html
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-1/igt@xe_module_load@load.html
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-1/igt@xe_module_load@load.html
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-3/igt@xe_module_load@load.html
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-3/igt@xe_module_load@load.html
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-3/igt@xe_module_load@load.html
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-4/igt@xe_module_load@load.html
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-4/igt@xe_module_load@load.html
[11]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-4/igt@xe_module_load@load.html
[12]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-5/igt@xe_module_load@load.html
[13]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-7/igt@xe_module_load@load.html
[14]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-2/igt@xe_module_load@load.html
[15]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-2/igt@xe_module_load@load.html
[16]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-4/igt@xe_module_load@load.html
[17]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-1/igt@xe_module_load@load.html
[18]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-5/igt@xe_module_load@load.html
[19]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-5/igt@xe_module_load@load.html
[20]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-1/igt@xe_module_load@load.html
[21]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-8/igt@xe_module_load@load.html
[22]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-8/igt@xe_module_load@load.html
[23]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-8/igt@xe_module_load@load.html
[24]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-2/igt@xe_module_load@load.html
[25]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-8/igt@xe_module_load@load.html
[26]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-lnl-7/igt@xe_module_load@load.html
[27]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-1/igt@xe_module_load@load.html
[28]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-1/igt@xe_module_load@load.html
[29]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-1/igt@xe_module_load@load.html
[30]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-8/igt@xe_module_load@load.html
[31]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-8/igt@xe_module_load@load.html
[32]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-8/igt@xe_module_load@load.html
[33]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-4/igt@xe_module_load@load.html
[34]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-4/igt@xe_module_load@load.html
[35]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-4/igt@xe_module_load@load.html
[36]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-4/igt@xe_module_load@load.html
[37]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-3/igt@xe_module_load@load.html
[38]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-3/igt@xe_module_load@load.html
[39]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-3/igt@xe_module_load@load.html
[40]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-3/igt@xe_module_load@load.html
[41]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-2/igt@xe_module_load@load.html
[42]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-2/igt@xe_module_load@load.html
[43]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-7/igt@xe_module_load@load.html
[44]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-7/igt@xe_module_load@load.html
[45]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-7/igt@xe_module_load@load.html
[46]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-7/igt@xe_module_load@load.html
[47]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-7/igt@xe_module_load@load.html
[48]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-5/igt@xe_module_load@load.html
[49]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-5/igt@xe_module_load@load.html
[50]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-5/igt@xe_module_load@load.html
[51]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-lnl-5/igt@xe_module_load@load.html
- shard-bmg: ([PASS][52], [PASS][53], [PASS][54], [SKIP][55], [PASS][56], [PASS][57], [PASS][58], [PASS][59], [PASS][60], [PASS][61], [PASS][62], [PASS][63], [PASS][64], [PASS][65], [PASS][66], [PASS][67], [PASS][68], [PASS][69], [PASS][70], [PASS][71], [PASS][72], [PASS][73], [PASS][74], [PASS][75], [PASS][76]) ([Intel XE#2457]) -> ([ABORT][77], [DMESG-WARN][78], [DMESG-WARN][79], [DMESG-WARN][80], [DMESG-WARN][81], [DMESG-WARN][82], [DMESG-WARN][83], [DMESG-WARN][84], [DMESG-WARN][85], [DMESG-WARN][86], [DMESG-WARN][87], [DMESG-WARN][88], [DMESG-WARN][89], [DMESG-WARN][90], [DMESG-WARN][91], [DMESG-WARN][92], [DMESG-WARN][93], [DMESG-WARN][94], [DMESG-WARN][95], [DMESG-WARN][96], [DMESG-WARN][97], [DMESG-WARN][98], [DMESG-WARN][99], [DMESG-WARN][100])
[52]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-1/igt@xe_module_load@load.html
[53]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-8/igt@xe_module_load@load.html
[54]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-8/igt@xe_module_load@load.html
[55]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-8/igt@xe_module_load@load.html
[56]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-10/igt@xe_module_load@load.html
[57]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-10/igt@xe_module_load@load.html
[58]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-8/igt@xe_module_load@load.html
[59]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-3/igt@xe_module_load@load.html
[60]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-2/igt@xe_module_load@load.html
[61]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-2/igt@xe_module_load@load.html
[62]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-10/igt@xe_module_load@load.html
[63]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-9/igt@xe_module_load@load.html
[64]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-9/igt@xe_module_load@load.html
[65]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-9/igt@xe_module_load@load.html
[66]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-1/igt@xe_module_load@load.html
[67]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-3/igt@xe_module_load@load.html
[68]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-3/igt@xe_module_load@load.html
[69]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-1/igt@xe_module_load@load.html
[70]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-7/igt@xe_module_load@load.html
[71]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-7/igt@xe_module_load@load.html
[72]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-7/igt@xe_module_load@load.html
[73]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-7/igt@xe_module_load@load.html
[74]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-6/igt@xe_module_load@load.html
[75]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-6/igt@xe_module_load@load.html
[76]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4380-1580579412915ac76344699e53124b580060302d/shard-bmg-6/igt@xe_module_load@load.html
[77]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-4/igt@xe_module_load@load.html
[78]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-8/igt@xe_module_load@load.html
[79]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-8/igt@xe_module_load@load.html
[80]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-10/igt@xe_module_load@load.html
[81]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-10/igt@xe_module_load@load.html
[82]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-10/igt@xe_module_load@load.html
[83]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-10/igt@xe_module_load@load.html
[84]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-1/igt@xe_module_load@load.html
[85]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-1/igt@xe_module_load@load.html
[86]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-1/igt@xe_module_load@load.html
[87]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-7/igt@xe_module_load@load.html
[88]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-7/igt@xe_module_load@load.html
[89]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-9/igt@xe_module_load@load.html
[90]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-9/igt@xe_module_load@load.html
[91]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-9/igt@xe_module_load@load.html
[92]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-2/igt@xe_module_load@load.html
[93]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-2/igt@xe_module_load@load.html
[94]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-2/igt@xe_module_load@load.html
[95]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-2/igt@xe_module_load@load.html
[96]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-6/igt@xe_module_load@load.html
[97]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-3/igt@xe_module_load@load.html
[98]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-3/igt@xe_module_load@load.html
[99]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-3/igt@xe_module_load@load.html
[100]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/shard-bmg-3/igt@xe_module_load@load.html
[Intel XE#2457]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2457
[Intel XE#378]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/378
Build changes
-------------
* Linux: xe-4380-1580579412915ac76344699e53124b580060302d -> xe-pw-159539v2
IGT_8699: 0b67ab25f2eb58b296872c8c34474b79353727d5 @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
xe-4380-1580579412915ac76344699e53124b580060302d: 1580579412915ac76344699e53124b580060302d
xe-pw-159539v2: 159539v2
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-159539v2/index.html
[-- Attachment #2: Type: text/html, Size: 16155 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2 0/3] Fix Cx0 Suspend Resume issue
2026-01-14 3:42 [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Suraj Kandpal
` (5 preceding siblings ...)
2026-01-14 11:50 ` ✗ Xe.CI.Full: " Patchwork
@ 2026-01-14 15:10 ` Rodrigo Vivi
2026-01-14 15:42 ` Saarinen, Jani
6 siblings, 1 reply; 11+ messages in thread
From: Rodrigo Vivi @ 2026-01-14 15:10 UTC (permalink / raw)
To: Suraj Kandpal; +Cc: intel-xe, intel-gfx, ankit.k.nautiyal
On Wed, Jan 14, 2026 at 09:12:56AM +0530, Suraj Kandpal wrote:
> CX0 PHY currently has two issues which cause a hang when we try
> to suspend resume machine with a delay of 15mins and 1+ hour.
> This happens due to two reasons:
> 1) We do not follow the Enablement sequence where we need to
> enable our clock after PPS Enablement cycle
> 2) We do not make sure response ready and error bit are cleared
> in P2M_MSGBUS_STATUS before writing the transaction pending bit.
> This series aims to solve this.
Is there any Fixes: tag that we should add to any of the commits
in this series?
Also, next time, consider a fix as the first patch for easy backport
and the refactor on top.
Thanks,
Rodrigo.
>
> Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com>
>
> Mika Kahola (1):
> drm/i915/cx0: Split PLL enabling/disabling in two parts
>
> Suraj Kandpal (2):
> drm/i915/cx0: Clear response ready & error bit
> drm/i915/cx0: Rename intel_clear_response_ready flag
>
> drivers/gpu/drm/i915/display/intel_cx0_phy.c | 134 +++++++++++-------
> drivers/gpu/drm/i915/display/intel_cx0_phy.h | 4 +-
> drivers/gpu/drm/i915/display/intel_dpll_mgr.c | 7 +-
> drivers/gpu/drm/i915/display/intel_lt_phy.c | 2 +-
> 4 files changed, 92 insertions(+), 55 deletions(-)
>
> --
> 2.34.1
>
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2 1/3] drm/i915/cx0: Split PLL enabling/disabling in two parts
2026-01-14 3:42 ` [PATCH v2 1/3] drm/i915/cx0: Split PLL enabling/disabling in two parts Suraj Kandpal
@ 2026-01-14 15:12 ` Imre Deak
0 siblings, 0 replies; 11+ messages in thread
From: Imre Deak @ 2026-01-14 15:12 UTC (permalink / raw)
To: Suraj Kandpal
Cc: intel-xe, intel-gfx, ankit.k.nautiyal, Mika Kahola,
Michał Grzelak
On Wed, Jan 14, 2026 at 09:12:57AM +0530, Suraj Kandpal wrote:
> From: Mika Kahola <mika.kahola@intel.com>
>
> Split PLL enabling/disabling in two parts - one for pll setting
> pll dividers and second one to enable/disable pll clock. PLL
> clock enabling/disbling happens via encoder->enable_clock/disable_clock
> function hook.
This is missing the rationale for the change. As I understand it
appeares to fix a PLL enabling/disabling timeout, if so that should be
described here in the commit log and also explain how the change fixes
the timeout, IOW wrt. what are the enabling/disabling steps gets
reordered?
Also, what about CMTG? It may require an output/DDI's PLL for another
ouput/DDI even if the former output/DDI is disabled.
Also, there is an ordering issue in the change, see below.
> PLL state verification happens now earlier than the clock is enabled
> which causes a drm warn to be thrown. Silence this warning by
> allowing this check for only earlier platforms than MeteorLake.
>
> While at it also add the necessary argument to cx0_enable_clock
> so that we can move step 12 of the enable sequence.
>
> v2:
> - Move state verification to enable_clock() function for
> MTL+ platforms
> - Squash patch 1 & 2 (Gustavo)
> - Use correct Bspec references (Gustavo)
> - Fix build error (Michal)
>
> Bspec: 65448, 68849
> Signed-off-by: Mika Kahola <mika.kahola@intel.com>
> Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com>
> Reviewed-by: Michał Grzelak <michal.grzelak@intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_cx0_phy.c | 120 +++++++++++-------
> drivers/gpu/drm/i915/display/intel_dpll_mgr.c | 7 +-
> 2 files changed, 80 insertions(+), 47 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_cx0_phy.c b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> index 7288065d2461..3418a3ed28fd 100644
> --- a/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> +++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> @@ -3225,11 +3225,8 @@ static void intel_cx0pll_enable(struct intel_encoder *encoder,
> {
> int port_clock = pll_state->use_c10 ? pll_state->c10.clock : pll_state->c20.clock;
> struct intel_display *display = to_intel_display(encoder);
> - enum phy phy = intel_encoder_to_phy(encoder);
> struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
> bool lane_reversal = dig_port->lane_reversal;
> - u8 maxpclk_lane = lane_reversal ? INTEL_CX0_LANE1 :
> - INTEL_CX0_LANE0;
> struct ref_tracker *wakeref = intel_cx0_phy_transaction_begin(encoder);
>
> /*
> @@ -3284,42 +3281,6 @@ static void intel_cx0pll_enable(struct intel_encoder *encoder,
> */
> intel_de_write(display, DDI_CLK_VALFREQ(encoder->port), port_clock);
>
> - /*
> - * 9. Set PORT_CLOCK_CTL register PCLK PLL Request
> - * LN<Lane for maxPCLK> to "1" to enable PLL.
> - */
> - intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
> - intel_cx0_get_pclk_pll_request(INTEL_CX0_BOTH_LANES),
> - intel_cx0_get_pclk_pll_request(maxpclk_lane));
> -
> - /* 10. Poll on PORT_CLOCK_CTL PCLK PLL Ack LN<Lane for maxPCLK> == "1". */
> - if (intel_de_wait_us(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
> - intel_cx0_get_pclk_pll_ack(INTEL_CX0_BOTH_LANES),
> - intel_cx0_get_pclk_pll_ack(maxpclk_lane),
> - XELPDP_PCLK_PLL_ENABLE_TIMEOUT_US, NULL))
> - drm_warn(display->drm, "Port %c PLL not locked\n",
> - phy_name(phy));
> -
> - /*
> - * 11. Follow the Display Voltage Frequency Switching Sequence After
> - * Frequency Change. We handle this step in bxt_set_cdclk().
> - */
> -
> - /*
> - * 12. Toggle powerdown if HDMI is enabled on C10 PHY.
> - *
> - * Wa_13013502646:
> - * Fixes: HDMI lane to lane skew violations on C10 display PHYs.
> - * Workaround: Toggle powerdown value by setting first to P0 and then to P2, for both
> - * PHY lanes.
> - */
> - if (!cx0pll_state_is_dp(pll_state) && pll_state->use_c10) {
> - intel_cx0_powerdown_change_sequence(encoder, INTEL_CX0_BOTH_LANES,
> - XELPDP_P0_STATE_ACTIVE);
> - intel_cx0_powerdown_change_sequence(encoder, INTEL_CX0_BOTH_LANES,
> - XELPDP_P2_STATE_READY);
> - }
> -
> intel_cx0_phy_transaction_end(encoder, wakeref);
> }
>
> @@ -3403,6 +3364,56 @@ static int intel_mtl_tbt_clock_select(struct intel_display *display,
> }
> }
>
> +static void intel_cx0pll_enable_clock(struct intel_encoder *encoder,
> + const struct intel_cx0pll_state *pll_state)
> +{
> + struct intel_display *display = to_intel_display(encoder);
> + enum phy phy = intel_encoder_to_phy(encoder);
> + struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
> + bool lane_reversal = dig_port->lane_reversal;
> + u8 maxpclk_lane = lane_reversal ? INTEL_CX0_LANE1 :
> + INTEL_CX0_LANE0;
> + struct ref_tracker *wakeref = intel_cx0_phy_transaction_begin(encoder);
> +
> + /*
> + * 9. Set PORT_CLOCK_CTL register PCLK PLL Request
> + * LN<Lane for maxPCLK> to "1" to enable PLL.
> + */
> + intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
> + intel_cx0_get_pclk_pll_request(INTEL_CX0_BOTH_LANES),
> + intel_cx0_get_pclk_pll_request(maxpclk_lane));
> +
> + /* 10. Poll on PORT_CLOCK_CTL PCLK PLL Ack LN<Lane for maxPCLK> == "1". */
> + if (intel_de_wait_us(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
> + intel_cx0_get_pclk_pll_ack(INTEL_CX0_BOTH_LANES),
> + intel_cx0_get_pclk_pll_ack(maxpclk_lane),
> + XELPDP_PCLK_PLL_ENABLE_TIMEOUT_US, NULL))
> + drm_warn(display->drm, "Port %c PLL not locked\n",
> + phy_name(phy));
> +
> + /*
> + * 11. Follow the Display Voltage Frequency Switching Sequence After
> + * Frequency Change. We handle this step in bxt_set_cdclk().
> + */
> +
> + /*
> + * 12. Toggle powerdown if HDMI is enabled on C10 PHY.
> + *
> + * Wa_13013502646:
> + * Fixes: HDMI lane to lane skew violations on C10 display PHYs.
> + * Workaround: Toggle powerdown value by setting first to P0 and then to P2, for both
> + * PHY lanes.
> + */
> + if (!cx0pll_state_is_dp(pll_state) && pll_state->use_c10) {
> + intel_cx0_powerdown_change_sequence(encoder, INTEL_CX0_BOTH_LANES,
> + XELPDP_P0_STATE_ACTIVE);
> + intel_cx0_powerdown_change_sequence(encoder, INTEL_CX0_BOTH_LANES,
> + XELPDP_P2_STATE_READY);
> + }
> +
> + intel_cx0_phy_transaction_end(encoder, wakeref);
> +}
> +
> void intel_mtl_tbt_pll_enable_clock(struct intel_encoder *encoder, int port_clock)
> {
> struct intel_display *display = to_intel_display(encoder);
> @@ -3468,10 +3479,16 @@ void intel_mtl_pll_enable(struct intel_encoder *encoder,
> void intel_mtl_pll_enable_clock(struct intel_encoder *encoder,
> const struct intel_crtc_state *crtc_state)
> {
> + struct intel_display *display = to_intel_display(encoder);
> + struct intel_dpll *pll = crtc_state->intel_dpll;
> struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
>
> if (intel_tc_port_in_tbt_alt_mode(dig_port))
> intel_mtl_tbt_pll_enable_clock(encoder, crtc_state->port_clock);
> + else
> + intel_cx0pll_enable_clock(encoder, &crtc_state->dpll_hw_state.cx0pll);
> +
> + assert_dpll_enabled(display, pll);
> }
>
> /*
> @@ -3567,12 +3584,6 @@ static void intel_cx0pll_disable(struct intel_encoder *encoder)
> * Frequency Change. We handle this step in bxt_set_cdclk().
> */
>
> - /* 7. Program PORT_CLOCK_CTL register to disable and gate clocks. */
> - intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
> - XELPDP_DDI_CLOCK_SELECT_MASK(display), 0);
> - intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
> - XELPDP_FORWARD_CLOCK_UNGATE, 0);
> -
> intel_cx0_phy_transaction_end(encoder, wakeref);
> }
>
> @@ -3586,6 +3597,20 @@ static bool intel_cx0_pll_is_enabled(struct intel_encoder *encoder)
> intel_cx0_get_pclk_pll_request(lane);
> }
>
> +static void intel_cx0pll_disable_clock(struct intel_encoder *encoder)
> +{
> + struct intel_display *display = to_intel_display(encoder);
> + struct ref_tracker *wakeref = intel_cx0_phy_transaction_begin(encoder);
> +
> + /* 7. Program PORT_CLOCK_CTL register to disable and gate clocks. */
> + intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
> + XELPDP_DDI_CLOCK_SELECT_MASK(display), 0);
> + intel_de_rmw(display, XELPDP_PORT_CLOCK_CTL(display, encoder->port),
> + XELPDP_FORWARD_CLOCK_UNGATE, 0);
> +
> + intel_cx0_phy_transaction_end(encoder, wakeref);
During a modeset disable sequence encoder::disable_clock() is called
first and only afterwards intel_dpll_funcs::disable() is called. So the
above will incorrectly reorder the clearing of the clock-select and
forward-clock-ungate flags wrt. the rest of the steps
intel_cx0pll_disable(), i.e. not matching now bspec at all.
> +}
> +
> void intel_mtl_tbt_pll_disable_clock(struct intel_encoder *encoder)
> {
> struct intel_display *display = to_intel_display(encoder);
> @@ -3635,6 +3660,9 @@ void intel_mtl_pll_disable_clock(struct intel_encoder *encoder)
>
> if (intel_tc_port_in_tbt_alt_mode(dig_port))
> intel_mtl_tbt_pll_disable_clock(encoder);
> + else
> + intel_cx0pll_disable_clock(encoder);
> +
> }
>
> enum icl_port_dpll_id
> @@ -3783,6 +3811,8 @@ void intel_cx0_pll_power_save_wa(struct intel_display *display)
> encoder->base.base.id, encoder->base.name);
>
> intel_cx0pll_enable(encoder, &pll_state);
> + intel_cx0pll_enable_clock(encoder, &pll_state);
> intel_cx0pll_disable(encoder);
> + intel_cx0pll_disable_clock(encoder);
> }
> }
> diff --git a/drivers/gpu/drm/i915/display/intel_dpll_mgr.c b/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> index 9aa84a430f09..040c97d81302 100644
> --- a/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> +++ b/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> @@ -298,7 +298,8 @@ void intel_dpll_enable(const struct intel_crtc_state *crtc_state)
>
> if (old_mask) {
> drm_WARN_ON(display->drm, !pll->on);
> - assert_dpll_enabled(display, pll);
> + if (DISPLAY_VER(display) < 14)
> + assert_dpll_enabled(display, pll);
> goto out;
> }
> drm_WARN_ON(display->drm, pll->on);
> @@ -342,7 +343,9 @@ void intel_dpll_disable(const struct intel_crtc_state *crtc_state)
> pll->info->name, pll->active_mask, pll->on,
> crtc->base.base.id, crtc->base.name);
>
> - assert_dpll_enabled(display, pll);
> + if (DISPLAY_VER(display) < 14)
> + assert_dpll_enabled(display, pll);
> +
> drm_WARN_ON(display->drm, !pll->on);
>
> pll->active_mask &= ~pipe_mask;
> --
> 2.34.1
>
^ permalink raw reply [flat|nested] 11+ messages in thread
* RE: [PATCH v2 0/3] Fix Cx0 Suspend Resume issue
2026-01-14 15:10 ` [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Rodrigo Vivi
@ 2026-01-14 15:42 ` Saarinen, Jani
0 siblings, 0 replies; 11+ messages in thread
From: Saarinen, Jani @ 2026-01-14 15:42 UTC (permalink / raw)
To: Vivi, Rodrigo, Kandpal, Suraj
Cc: intel-xe@lists.freedesktop.org, intel-gfx@lists.freedesktop.org,
Nautiyal, Ankit K
Hi,
> -----Original Message-----
> From: Intel-gfx <intel-gfx-bounces@lists.freedesktop.org> On Behalf Of
> Rodrigo Vivi
> Sent: Wednesday, 14 January 2026 17.10
> To: Kandpal, Suraj <suraj.kandpal@intel.com>
> Cc: intel-xe@lists.freedesktop.org; intel-gfx@lists.freedesktop.org; Nautiyal,
> Ankit K <ankit.k.nautiyal@intel.com>
> Subject: Re: [PATCH v2 0/3] Fix Cx0 Suspend Resume issue
>
> On Wed, Jan 14, 2026 at 09:12:56AM +0530, Suraj Kandpal wrote:
> > CX0 PHY currently has two issues which cause a hang when we try to
> > suspend resume machine with a delay of 15mins and 1+ hour.
> > This happens due to two reasons:
> > 1) We do not follow the Enablement sequence where we need to enable
> > our clock after PPS Enablement cycle
> > 2) We do not make sure response ready and error bit are cleared in
> > P2M_MSGBUS_STATUS before writing the transaction pending bit.
> > This series aims to solve this.
>
> Is there any Fixes: tag that we should add to any of the commits in this series?
>
> Also, next time, consider a fix as the first patch for easy backport and the
> refactor on top.
Looking at both i915 and xe CI results this is not really ready as is.
Br,
Jani
>
> Thanks,
> Rodrigo.
>
> >
> > Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com>
> >
> > Mika Kahola (1):
> > drm/i915/cx0: Split PLL enabling/disabling in two parts
> >
> > Suraj Kandpal (2):
> > drm/i915/cx0: Clear response ready & error bit
> > drm/i915/cx0: Rename intel_clear_response_ready flag
> >
> > drivers/gpu/drm/i915/display/intel_cx0_phy.c | 134 +++++++++++-------
> > drivers/gpu/drm/i915/display/intel_cx0_phy.h | 4 +-
> > drivers/gpu/drm/i915/display/intel_dpll_mgr.c | 7 +-
> > drivers/gpu/drm/i915/display/intel_lt_phy.c | 2 +-
> > 4 files changed, 92 insertions(+), 55 deletions(-)
> >
> > --
> > 2.34.1
> >
^ permalink raw reply [flat|nested] 11+ messages in thread
end of thread, other threads:[~2026-01-14 15:42 UTC | newest]
Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-01-14 3:42 [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Suraj Kandpal
2026-01-14 3:42 ` [PATCH v2 1/3] drm/i915/cx0: Split PLL enabling/disabling in two parts Suraj Kandpal
2026-01-14 15:12 ` Imre Deak
2026-01-14 3:42 ` [PATCH v2 2/3] drm/i915/cx0: Clear response ready & error bit Suraj Kandpal
2026-01-14 3:42 ` [PATCH v2 3/3] drm/i915/cx0: Rename intel_clear_response_ready flag Suraj Kandpal
2026-01-14 6:03 ` Garg, Nemesa
2026-01-14 4:35 ` ✓ CI.KUnit: success for Fix Cx0 Suspend Resume issue (rev2) Patchwork
2026-01-14 5:08 ` ✗ Xe.CI.BAT: failure " Patchwork
2026-01-14 11:50 ` ✗ Xe.CI.Full: " Patchwork
2026-01-14 15:10 ` [PATCH v2 0/3] Fix Cx0 Suspend Resume issue Rodrigo Vivi
2026-01-14 15:42 ` Saarinen, Jani
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox