* [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos
@ 2020-02-26 13:45 Swati Sharma
2020-02-26 15:18 ` [igt-dev] ✗ GitLab.Pipeline: failure for " Patchwork
` (3 more replies)
0 siblings, 4 replies; 8+ messages in thread
From: Swati Sharma @ 2020-02-26 13:45 UTC (permalink / raw)
To: igt-dev; +Cc: petri.latvala
i915 implements immutable zpos property whereas the existing test
case is written to validate mutable zpos.
Added new test case to validate immutable zpos and skip existing
test case if i915 driver is not detected.
Issue: https://gitlab.freedesktop.org/drm/intel/issues/404
Signed-off-by: Swati Sharma <swati2.sharma@intel.com>
---
tests/kms_atomic.c | 120 ++++++++++++++++++++++++++++++++++++++++++---
1 file changed, 112 insertions(+), 8 deletions(-)
diff --git a/tests/kms_atomic.c b/tests/kms_atomic.c
index 8462d128..7a5edc8e 100644
--- a/tests/kms_atomic.c
+++ b/tests/kms_atomic.c
@@ -121,7 +121,7 @@ static void plane_check_current_state(igt_plane_t *plane, const uint64_t *values
}
static void plane_commit(igt_plane_t *plane, enum igt_commit_style s,
- enum kms_atomic_check_relax relax)
+ enum kms_atomic_check_relax relax)
{
igt_display_commit2(plane->pipe->display, s);
plane_check_current_state(plane, plane->values, relax);
@@ -277,9 +277,9 @@ static uint32_t plane_get_igt_format(igt_plane_t *plane)
}
static void
-plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output,
- igt_plane_t *primary, igt_plane_t *overlay,
- uint32_t format_primary, uint32_t format_overlay)
+plane_primary_overlay_mutable_zpos(igt_pipe_t *pipe, igt_output_t *output,
+ igt_plane_t *primary, igt_plane_t *overlay,
+ uint32_t format_primary, uint32_t format_overlay)
{
struct igt_fb fb_primary, fb_overlay;
drmModeModeInfo *mode = igt_output_get_mode(output);
@@ -358,6 +358,97 @@ plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output,
igt_assert_eq_u64(igt_plane_get_prop(overlay, IGT_PLANE_ZPOS), 1);
}
+static void
+plane_immutable_zpos(igt_display_t *display, igt_pipe_t *pipe,
+ igt_output_t *output)
+{
+ cairo_t *cr;
+ int n_planes;
+ uint32_t format;
+ struct igt_fb fb_ref;
+ igt_plane_t *primary;
+ drmModeModeInfo *mode;
+ igt_pipe_crc_t *pipe_crc;
+ igt_crc_t ref_crc, new_crc;
+ igt_plane_t *plane_lower, *plane_upper;
+ uint32_t w_lower, h_lower, w_upper, h_upper;
+
+ n_planes = pipe->n_planes;
+ mode = igt_output_get_mode(output);
+ primary = igt_pipe_get_plane_type(pipe, DRM_PLANE_TYPE_PRIMARY);
+
+ /* for lower plane */
+ w_lower = mode->hdisplay;
+ h_lower = mode->vdisplay;
+
+ /* for upper plane */
+ w_upper = mode->hdisplay / 2;
+ h_upper = mode->vdisplay / 2;
+
+ if (intel_gen(display->drm_fd) == 3)
+ format = DRM_FORMAT_RGB565;
+ else
+ format = DRM_FORMAT_ARGB8888;
+
+ igt_create_color_fb(display->drm_fd,
+ w_lower, h_lower,
+ format, I915_TILING_NONE,
+ 0.0, 0.0, 0.0, &fb_ref);
+
+ cr = igt_get_cairo_ctx(display->drm_fd, &fb_ref);
+ igt_assert(cairo_status(cr) == 0);
+ igt_paint_color(cr, 0, 0, w_lower, h_lower, 0.0, 0.0, 1.0);
+ igt_paint_color(cr, w_upper / 2, h_upper / 2, w_upper, h_upper, 1.0, 1.0, 0.0);
+ igt_put_cairo_ctx(display->drm_fd, &fb_ref, cr);
+ igt_plane_set_fb(primary, &fb_ref);
+ igt_display_commit2(display, COMMIT_ATOMIC);
+
+ /* create the pipe_crc object for this pipe */
+ pipe_crc = igt_pipe_crc_new(pipe->display->drm_fd, pipe->pipe,
+ INTEL_PIPE_CRC_SOURCE_AUTO);
+
+ /* get reference crc */
+ igt_pipe_crc_start(pipe_crc);
+ igt_pipe_crc_get_current(display->drm_fd, pipe_crc, &ref_crc);
+
+ igt_plane_set_fb(primary, NULL);
+
+ for (int i = 0; i < n_planes - 1; i++) {
+ struct igt_fb fb[2];
+ plane_lower = &display->pipes[pipe->pipe].planes[i];
+ plane_upper = &display->pipes[pipe->pipe].planes[i + 1];
+
+ igt_require(igt_plane_has_prop(plane_lower, IGT_PLANE_ZPOS));
+ igt_require(igt_plane_has_prop(plane_upper, IGT_PLANE_ZPOS));
+
+ if ((plane_lower->type == DRM_PLANE_TYPE_CURSOR) ||
+ (plane_upper->type == DRM_PLANE_TYPE_CURSOR))
+ continue;
+
+ igt_create_color_fb(display->drm_fd, w_lower, h_lower,
+ format, I915_TILING_NONE,
+ 0.0, 0.0, 1.0, &fb[0]);
+
+ igt_create_color_fb(display->drm_fd, w_upper, h_upper,
+ format, I915_TILING_NONE,
+ 1.0, 1.0, 0.0, &fb[1]);
+
+ igt_plane_set_position(plane_lower, 0, 0);
+ igt_plane_set_fb(plane_lower, &fb[0]);
+
+ igt_plane_set_position(plane_upper, w_upper / 2, h_upper / 2);
+ igt_plane_set_fb(plane_upper, &fb[1]);
+
+ igt_display_commit2(display, COMMIT_ATOMIC);
+ igt_pipe_crc_get_current(pipe->display->drm_fd, pipe_crc, &new_crc);
+
+ igt_assert_crc_equal(&ref_crc, &new_crc);
+
+ igt_plane_set_fb(plane_lower, NULL);
+ igt_plane_set_fb(plane_upper, NULL);
+ }
+}
+
static void plane_overlay(igt_pipe_t *pipe, igt_output_t *output, igt_plane_t *plane)
{
drmModeModeInfo *mode = igt_output_get_mode(output);
@@ -987,14 +1078,20 @@ igt_main
plane_primary(pipe_obj, primary, &fb);
}
- igt_subtest("plane_primary_overlay_zpos") {
+ igt_subtest("plane_primary_overlay_mutable_zpos") {
+ /*
+ * Since i915 driver doesn't support mutable zpos;
+ * skipping.
+ */
+ igt_require(!is_i915_device(display.drm_fd));
+
uint32_t format_primary = DRM_FORMAT_ARGB8888;
uint32_t format_overlay = DRM_FORMAT_ARGB1555;
igt_plane_t *overlay =
igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_OVERLAY);
-
igt_require(overlay);
+
igt_require(igt_plane_has_prop(primary, IGT_PLANE_ZPOS));
igt_require(igt_plane_has_prop(overlay, IGT_PLANE_ZPOS));
@@ -1002,8 +1099,14 @@ igt_main
igt_require(igt_plane_has_format_mod(overlay, format_overlay, 0x0));
igt_output_set_pipe(output, pipe);
- plane_primary_overlay_zpos(pipe_obj, output, primary, overlay,
- format_primary, format_overlay);
+ plane_primary_overlay_mutable_zpos(pipe_obj, output, primary, overlay,
+ format_primary, format_overlay);
+ }
+
+ igt_subtest("plane_immutable_zpos") {
+ igt_require(is_i915_device(display.drm_fd));
+ igt_output_set_pipe(output, pipe);
+ plane_immutable_zpos(&display, pipe_obj, output);
}
igt_subtest("test_only") {
@@ -1011,6 +1114,7 @@ igt_main
test_only(pipe_obj, primary, output);
}
+
igt_subtest("plane_cursor_legacy") {
igt_plane_t *cursor =
igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_CURSOR);
--
2.24.1
_______________________________________________
igt-dev mailing list
igt-dev@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/igt-dev
^ permalink raw reply related [flat|nested] 8+ messages in thread* [igt-dev] ✗ GitLab.Pipeline: failure for tests/kms_atomic: add test to validate immutable zpos 2020-02-26 13:45 [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos Swati Sharma @ 2020-02-26 15:18 ` Patchwork 2020-02-26 16:48 ` [igt-dev] ✓ Fi.CI.BAT: success " Patchwork ` (2 subsequent siblings) 3 siblings, 0 replies; 8+ messages in thread From: Patchwork @ 2020-02-26 15:18 UTC (permalink / raw) To: Swati Sharma; +Cc: igt-dev == Series Details == Series: tests/kms_atomic: add test to validate immutable zpos URL : https://patchwork.freedesktop.org/series/73956/ State : failure == Summary == ERROR! This series introduces new undocumented tests: kms_atomic@plane_immutable_zpos kms_atomic@plane_primary_overlay_mutable_zpos Can you document them as per the requirement in the [CONTRIBUTING.md]? [Documentation] has more details on how to do this. Here are few examples: https://gitlab.freedesktop.org/drm/igt-gpu-tools/commit/0316695d03aa46108296b27f3982ec93200c7a6e https://gitlab.freedesktop.org/drm/igt-gpu-tools/commit/443cc658e1e6b492ee17bf4f4d891029eb7a205d Thanks in advance! [CONTRIBUTING.md]: https://gitlab.freedesktop.org/drm/igt-gpu-tools/blob/master/CONTRIBUTING.md#L19 [Documentation]: https://drm.pages.freedesktop.org/igt-gpu-tools/igt-gpu-tools-Core.html#igt-describe Other than that, pipeline status: SUCCESS. see https://gitlab.freedesktop.org/gfx-ci/igt-ci-tags/pipelines/112899 for the overview. == Logs == For more details see: https://gitlab.freedesktop.org/gfx-ci/igt-ci-tags/pipelines/112899 _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 8+ messages in thread
* [igt-dev] ✓ Fi.CI.BAT: success for tests/kms_atomic: add test to validate immutable zpos 2020-02-26 13:45 [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos Swati Sharma 2020-02-26 15:18 ` [igt-dev] ✗ GitLab.Pipeline: failure for " Patchwork @ 2020-02-26 16:48 ` Patchwork 2020-02-27 4:49 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork 2020-02-27 7:03 ` [igt-dev] [PATCH i-g-t] " Martin Peres 3 siblings, 0 replies; 8+ messages in thread From: Patchwork @ 2020-02-26 16:48 UTC (permalink / raw) To: Swati Sharma; +Cc: igt-dev == Series Details == Series: tests/kms_atomic: add test to validate immutable zpos URL : https://patchwork.freedesktop.org/series/73956/ State : success == Summary == CI Bug Log - changes from CI_DRM_8007 -> IGTPW_4229 ==================================================== Summary ------- **SUCCESS** No regressions found. External URL: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/index.html Known issues ------------ Here are the changes found in IGTPW_4229 that come from known issues: ### IGT changes ### #### Issues hit #### * igt@i915_getparams_basic@basic-eu-total: - fi-tgl-y: [PASS][1] -> [DMESG-WARN][2] ([CI#94] / [i915#402]) [1]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/fi-tgl-y/igt@i915_getparams_basic@basic-eu-total.html [2]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/fi-tgl-y/igt@i915_getparams_basic@basic-eu-total.html #### Possible fixes #### * igt@gem_flink_basic@bad-flink: - fi-tgl-y: [DMESG-WARN][3] ([CI#94] / [i915#402]) -> [PASS][4] [3]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/fi-tgl-y/igt@gem_flink_basic@bad-flink.html [4]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/fi-tgl-y/igt@gem_flink_basic@bad-flink.html [CI#94]: https://gitlab.freedesktop.org/gfx-ci/i915-infra/issues/94 [i915#402]: https://gitlab.freedesktop.org/drm/intel/issues/402 Participating hosts (48 -> 44) ------------------------------ Additional (1): fi-tgl-u Missing (5): fi-hsw-4200u fi-bdw-gvtdvm fi-byt-squawks fi-bsw-cyan fi-bdw-samus Build changes ------------- * CI: CI-20190529 -> None * IGT: IGT_5469 -> IGTPW_4229 CI-20190529: 20190529 CI_DRM_8007: 8dbfb8dcfb623026de73fdb617785f507064af89 @ git://anongit.freedesktop.org/gfx-ci/linux IGTPW_4229: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/index.html IGT_5469: 4f875016eb1ebc211b8aadb280ae16c7e6cdc8ba @ git://anongit.freedesktop.org/xorg/app/intel-gpu-tools == Testlist changes == +igt@kms_atomic@plane_immutable_zpos +igt@kms_atomic@plane_primary_overlay_mutable_zpos -igt@kms_atomic@plane_primary_overlay_zpos == Logs == For more details see: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/index.html _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 8+ messages in thread
* [igt-dev] ✗ Fi.CI.IGT: failure for tests/kms_atomic: add test to validate immutable zpos 2020-02-26 13:45 [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos Swati Sharma 2020-02-26 15:18 ` [igt-dev] ✗ GitLab.Pipeline: failure for " Patchwork 2020-02-26 16:48 ` [igt-dev] ✓ Fi.CI.BAT: success " Patchwork @ 2020-02-27 4:49 ` Patchwork 2020-02-27 7:03 ` [igt-dev] [PATCH i-g-t] " Martin Peres 3 siblings, 0 replies; 8+ messages in thread From: Patchwork @ 2020-02-27 4:49 UTC (permalink / raw) To: Swati Sharma; +Cc: igt-dev == Series Details == Series: tests/kms_atomic: add test to validate immutable zpos URL : https://patchwork.freedesktop.org/series/73956/ State : failure == Summary == CI Bug Log - changes from CI_DRM_8007_full -> IGTPW_4229_full ==================================================== Summary ------- **FAILURE** Serious unknown changes coming with IGTPW_4229_full absolutely need to be verified manually. If you think the reported changes have nothing to do with the changes introduced in IGTPW_4229_full, please notify your bug team to allow them to document this new failure mode, which will reduce false positives in CI. External URL: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/index.html Possible new issues ------------------- Here are the unknown changes that may have been introduced in IGTPW_4229_full: ### IGT changes ### #### Possible regressions #### * igt@i915_pm_rpm@gem-idle: - shard-iclb: [PASS][1] -> [SKIP][2] +1 similar issue [1]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb1/igt@i915_pm_rpm@gem-idle.html [2]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb8/igt@i915_pm_rpm@gem-idle.html - shard-tglb: [PASS][3] -> [SKIP][4] +1 similar issue [3]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-tglb2/igt@i915_pm_rpm@gem-idle.html [4]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-tglb5/igt@i915_pm_rpm@gem-idle.html * {igt@kms_atomic@plane_immutable_zpos} (NEW): - shard-snb: NOTRUN -> [FAIL][5] [5]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb4/igt@kms_atomic@plane_immutable_zpos.html - shard-hsw: NOTRUN -> [FAIL][6] [6]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw6/igt@kms_atomic@plane_immutable_zpos.html * {igt@kms_atomic@plane_primary_overlay_mutable_zpos} (NEW): - shard-iclb: NOTRUN -> [SKIP][7] [7]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb3/igt@kms_atomic@plane_primary_overlay_mutable_zpos.html - shard-tglb: NOTRUN -> [SKIP][8] [8]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-tglb8/igt@kms_atomic@plane_primary_overlay_mutable_zpos.html * igt@sw_sync@sync_multi_producer_single_consumer: - shard-apl: [PASS][9] -> [TIMEOUT][10] [9]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-apl6/igt@sw_sync@sync_multi_producer_single_consumer.html [10]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-apl4/igt@sw_sync@sync_multi_producer_single_consumer.html New tests --------- New tests have been introduced between CI_DRM_8007_full and IGTPW_4229_full: ### New IGT tests (2) ### * igt@kms_atomic@plane_immutable_zpos: - Statuses : 2 fail(s) 5 pass(s) - Exec time: [0.09, 0.99] s * igt@kms_atomic@plane_primary_overlay_mutable_zpos: - Statuses : 7 skip(s) - Exec time: [0.0] s Known issues ------------ Here are the changes found in IGTPW_4229_full that come from known issues: ### IGT changes ### #### Issues hit #### * igt@gem_ctx_isolation@vcs1-dirty-create: - shard-iclb: [PASS][11] -> [SKIP][12] ([fdo#112080]) +9 similar issues [11]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb2/igt@gem_ctx_isolation@vcs1-dirty-create.html [12]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb7/igt@gem_ctx_isolation@vcs1-dirty-create.html * igt@gem_exec_balancer@smoke: - shard-iclb: [PASS][13] -> [SKIP][14] ([fdo#110854]) [13]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb2/igt@gem_exec_balancer@smoke.html [14]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb6/igt@gem_exec_balancer@smoke.html * igt@gem_exec_schedule@pi-distinct-iova-bsd: - shard-iclb: [PASS][15] -> [SKIP][16] ([i915#677]) [15]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb3/igt@gem_exec_schedule@pi-distinct-iova-bsd.html [16]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb2/igt@gem_exec_schedule@pi-distinct-iova-bsd.html * igt@gem_exec_schedule@reorder-wide-bsd: - shard-iclb: [PASS][17] -> [SKIP][18] ([fdo#112146]) +4 similar issues [17]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb5/igt@gem_exec_schedule@reorder-wide-bsd.html [18]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb2/igt@gem_exec_schedule@reorder-wide-bsd.html * igt@gem_ppgtt@flink-and-close-vma-leak: - shard-glk: [PASS][19] -> [FAIL][20] ([i915#644]) [19]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-glk8/igt@gem_ppgtt@flink-and-close-vma-leak.html [20]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-glk7/igt@gem_ppgtt@flink-and-close-vma-leak.html * igt@gem_tiled_swapping@non-threaded: - shard-hsw: [PASS][21] -> [INCOMPLETE][22] ([CI#80] / [i915#61]) [21]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw5/igt@gem_tiled_swapping@non-threaded.html [22]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw7/igt@gem_tiled_swapping@non-threaded.html * igt@gem_userptr_blits@sync-unmap-after-close: - shard-hsw: [PASS][23] -> [DMESG-WARN][24] ([fdo#111870]) +1 similar issue [23]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw5/igt@gem_userptr_blits@sync-unmap-after-close.html [24]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw1/igt@gem_userptr_blits@sync-unmap-after-close.html - shard-snb: [PASS][25] -> [DMESG-WARN][26] ([fdo#111870] / [i915#478]) +1 similar issue [25]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb6/igt@gem_userptr_blits@sync-unmap-after-close.html [26]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb5/igt@gem_userptr_blits@sync-unmap-after-close.html * igt@gem_workarounds@suspend-resume-context: - shard-apl: [PASS][27] -> [DMESG-WARN][28] ([i915#180]) +1 similar issue [27]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-apl4/igt@gem_workarounds@suspend-resume-context.html [28]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-apl1/igt@gem_workarounds@suspend-resume-context.html * igt@i915_pm_rpm@gem-idle: - shard-glk: [PASS][29] -> [SKIP][30] ([fdo#109271]) [29]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-glk9/igt@i915_pm_rpm@gem-idle.html [30]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-glk8/igt@i915_pm_rpm@gem-idle.html * igt@i915_pm_rpm@system-suspend-execbuf: - shard-hsw: [PASS][31] -> [SKIP][32] ([fdo#109271]) +1 similar issue [31]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw5/igt@i915_pm_rpm@system-suspend-execbuf.html [32]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw1/igt@i915_pm_rpm@system-suspend-execbuf.html * igt@kms_color@pipe-a-ctm-blue-to-red: - shard-kbl: [PASS][33] -> [FAIL][34] ([i915#129]) [33]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-kbl7/igt@kms_color@pipe-a-ctm-blue-to-red.html [34]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-kbl7/igt@kms_color@pipe-a-ctm-blue-to-red.html - shard-apl: [PASS][35] -> [FAIL][36] ([i915#129]) [35]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-apl4/igt@kms_color@pipe-a-ctm-blue-to-red.html [36]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-apl4/igt@kms_color@pipe-a-ctm-blue-to-red.html * igt@kms_cursor_crc@pipe-b-cursor-128x42-sliding: - shard-kbl: [PASS][37] -> [FAIL][38] ([i915#54]) [37]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-kbl4/igt@kms_cursor_crc@pipe-b-cursor-128x42-sliding.html [38]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-kbl3/igt@kms_cursor_crc@pipe-b-cursor-128x42-sliding.html - shard-apl: [PASS][39] -> [FAIL][40] ([i915#54]) [39]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-apl2/igt@kms_cursor_crc@pipe-b-cursor-128x42-sliding.html [40]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-apl7/igt@kms_cursor_crc@pipe-b-cursor-128x42-sliding.html * igt@kms_flip@2x-plain-flip-ts-check-interruptible: - shard-glk: [PASS][41] -> [FAIL][42] ([i915#34]) [41]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-glk2/igt@kms_flip@2x-plain-flip-ts-check-interruptible.html [42]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-glk2/igt@kms_flip@2x-plain-flip-ts-check-interruptible.html * igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible: - shard-tglb: [PASS][43] -> [FAIL][44] ([i915#488]) [43]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-tglb2/igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible.html [44]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-tglb7/igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible.html * igt@kms_flip@flip-vs-suspend: - shard-kbl: [PASS][45] -> [DMESG-WARN][46] ([i915#180]) +1 similar issue [45]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-kbl3/igt@kms_flip@flip-vs-suspend.html [46]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-kbl7/igt@kms_flip@flip-vs-suspend.html * igt@kms_frontbuffer_tracking@fbcpsr-indfb-scaledprimary: - shard-tglb: [PASS][47] -> [SKIP][48] ([i915#668]) +8 similar issues [47]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-tglb3/igt@kms_frontbuffer_tracking@fbcpsr-indfb-scaledprimary.html [48]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-tglb2/igt@kms_frontbuffer_tracking@fbcpsr-indfb-scaledprimary.html * igt@kms_plane_lowres@pipe-a-tiling-x: - shard-glk: [PASS][49] -> [FAIL][50] ([i915#899]) [49]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-glk7/igt@kms_plane_lowres@pipe-a-tiling-x.html [50]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-glk8/igt@kms_plane_lowres@pipe-a-tiling-x.html * igt@kms_psr@psr2_basic: - shard-iclb: [PASS][51] -> [SKIP][52] ([fdo#109441]) +1 similar issue [51]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb2/igt@kms_psr@psr2_basic.html [52]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb8/igt@kms_psr@psr2_basic.html * igt@prime_busy@hang-bsd2: - shard-iclb: [PASS][53] -> [SKIP][54] ([fdo#109276]) +16 similar issues [53]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb2/igt@prime_busy@hang-bsd2.html [54]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb3/igt@prime_busy@hang-bsd2.html #### Possible fixes #### * igt@gem_busy@busy-vcs1: - shard-iclb: [SKIP][55] ([fdo#112080]) -> [PASS][56] +10 similar issues [55]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb3/igt@gem_busy@busy-vcs1.html [56]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb2/igt@gem_busy@busy-vcs1.html * igt@gem_ctx_isolation@rcs0-s3: - shard-kbl: [DMESG-WARN][57] ([i915#180]) -> [PASS][58] +5 similar issues [57]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-kbl4/igt@gem_ctx_isolation@rcs0-s3.html [58]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-kbl6/igt@gem_ctx_isolation@rcs0-s3.html * {igt@gem_exec_schedule@implicit-both-bsd1}: - shard-iclb: [SKIP][59] ([fdo#109276] / [i915#677]) -> [PASS][60] +1 similar issue [59]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb7/igt@gem_exec_schedule@implicit-both-bsd1.html [60]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb1/igt@gem_exec_schedule@implicit-both-bsd1.html * igt@gem_exec_schedule@pi-shared-iova-bsd: - shard-iclb: [SKIP][61] ([i915#677]) -> [PASS][62] +2 similar issues [61]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb1/igt@gem_exec_schedule@pi-shared-iova-bsd.html [62]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb8/igt@gem_exec_schedule@pi-shared-iova-bsd.html * igt@gem_exec_schedule@preempt-bsd: - shard-iclb: [SKIP][63] ([fdo#112146]) -> [PASS][64] +5 similar issues [63]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb1/igt@gem_exec_schedule@preempt-bsd.html [64]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb8/igt@gem_exec_schedule@preempt-bsd.html * igt@gem_exec_schedule@preempt-contexts-bsd2: - shard-iclb: [SKIP][65] ([fdo#109276]) -> [PASS][66] +6 similar issues [65]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb8/igt@gem_exec_schedule@preempt-contexts-bsd2.html [66]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb4/igt@gem_exec_schedule@preempt-contexts-bsd2.html * {igt@gem_mmap_wc@write-wc-read-gtt}: - shard-hsw: [DMESG-WARN][67] -> [PASS][68] [67]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw5/igt@gem_mmap_wc@write-wc-read-gtt.html [68]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw1/igt@gem_mmap_wc@write-wc-read-gtt.html * igt@i915_pm_rpm@dpms-mode-unset-non-lpsp: - shard-hsw: [SKIP][69] ([fdo#109271]) -> [PASS][70] [69]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw1/igt@i915_pm_rpm@dpms-mode-unset-non-lpsp.html [70]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw4/igt@i915_pm_rpm@dpms-mode-unset-non-lpsp.html - shard-glk: [SKIP][71] ([fdo#109271]) -> [PASS][72] [71]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-glk7/igt@i915_pm_rpm@dpms-mode-unset-non-lpsp.html [72]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-glk6/igt@i915_pm_rpm@dpms-mode-unset-non-lpsp.html * igt@i915_pm_rpm@system-suspend-modeset: - shard-kbl: [FAIL][73] ([fdo#103375]) -> [PASS][74] +1 similar issue [73]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-kbl4/igt@i915_pm_rpm@system-suspend-modeset.html [74]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-kbl2/igt@i915_pm_rpm@system-suspend-modeset.html * igt@i915_pm_rps@reset: - shard-iclb: [FAIL][75] ([i915#413]) -> [PASS][76] [75]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb2/igt@i915_pm_rps@reset.html [76]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb2/igt@i915_pm_rps@reset.html * igt@kms_cursor_crc@pipe-a-cursor-64x21-sliding: - shard-apl: [FAIL][77] ([i915#54]) -> [PASS][78] [77]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-apl6/igt@kms_cursor_crc@pipe-a-cursor-64x21-sliding.html [78]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-apl2/igt@kms_cursor_crc@pipe-a-cursor-64x21-sliding.html * igt@kms_flip@2x-flip-vs-expired-vblank: - shard-glk: [FAIL][79] ([i915#79]) -> [PASS][80] [79]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-glk9/igt@kms_flip@2x-flip-vs-expired-vblank.html [80]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-glk1/igt@kms_flip@2x-flip-vs-expired-vblank.html * igt@kms_frontbuffer_tracking@fbc-1p-primscrn-cur-indfb-draw-render: - shard-snb: [DMESG-WARN][81] ([i915#478]) -> [PASS][82] +1 similar issue [81]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb6/igt@kms_frontbuffer_tracking@fbc-1p-primscrn-cur-indfb-draw-render.html [82]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb4/igt@kms_frontbuffer_tracking@fbc-1p-primscrn-cur-indfb-draw-render.html * igt@kms_frontbuffer_tracking@fbc-2p-primscrn-spr-indfb-draw-render: - shard-glk: [FAIL][83] ([i915#49]) -> [PASS][84] [83]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-glk3/igt@kms_frontbuffer_tracking@fbc-2p-primscrn-spr-indfb-draw-render.html [84]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-glk7/igt@kms_frontbuffer_tracking@fbc-2p-primscrn-spr-indfb-draw-render.html * igt@kms_plane@plane-panning-bottom-right-suspend-pipe-b-planes: - shard-apl: [DMESG-WARN][85] ([i915#180]) -> [PASS][86] +1 similar issue [85]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-apl6/igt@kms_plane@plane-panning-bottom-right-suspend-pipe-b-planes.html [86]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-apl3/igt@kms_plane@plane-panning-bottom-right-suspend-pipe-b-planes.html * igt@kms_psr@primary_mmap_gtt: - shard-tglb: [SKIP][87] ([i915#668]) -> [PASS][88] +8 similar issues [87]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-tglb3/igt@kms_psr@primary_mmap_gtt.html [88]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-tglb5/igt@kms_psr@primary_mmap_gtt.html * igt@kms_psr@psr2_sprite_mmap_gtt: - shard-iclb: [SKIP][89] ([fdo#109441]) -> [PASS][90] +2 similar issues [89]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb8/igt@kms_psr@psr2_sprite_mmap_gtt.html [90]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb2/igt@kms_psr@psr2_sprite_mmap_gtt.html * igt@sw_sync@sync_multi_producer_single_consumer: - shard-tglb: [TIMEOUT][91] -> [PASS][92] [91]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-tglb7/igt@sw_sync@sync_multi_producer_single_consumer.html [92]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-tglb5/igt@sw_sync@sync_multi_producer_single_consumer.html #### Warnings #### * igt@gem_softpin@noreloc-s3: - shard-kbl: [INCOMPLETE][93] ([fdo#103665]) -> [DMESG-WARN][94] ([i915#180]) [93]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-kbl2/igt@gem_softpin@noreloc-s3.html [94]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-kbl7/igt@gem_softpin@noreloc-s3.html * igt@i915_pm_dc@dc6-dpms: - shard-tglb: [FAIL][95] ([i915#454]) -> [SKIP][96] ([i915#468]) [95]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-tglb6/igt@i915_pm_dc@dc6-dpms.html [96]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-tglb2/igt@i915_pm_dc@dc6-dpms.html * igt@i915_pm_rpm@dpms-mode-unset-non-lpsp: - shard-tglb: [SKIP][97] -> [SKIP][98] ([fdo#111644]) [97]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-tglb6/igt@i915_pm_rpm@dpms-mode-unset-non-lpsp.html [98]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-tglb1/igt@i915_pm_rpm@dpms-mode-unset-non-lpsp.html - shard-iclb: [SKIP][99] -> [SKIP][100] ([fdo#110892]) [99]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-iclb2/igt@i915_pm_rpm@dpms-mode-unset-non-lpsp.html [100]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-iclb8/igt@i915_pm_rpm@dpms-mode-unset-non-lpsp.html * igt@i915_pm_rpm@modeset-pc8-residency-stress: - shard-snb: [INCOMPLETE][101] ([i915#82]) -> [SKIP][102] ([fdo#109271]) [101]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb2/igt@i915_pm_rpm@modeset-pc8-residency-stress.html [102]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb2/igt@i915_pm_rpm@modeset-pc8-residency-stress.html * igt@kms_content_protection@atomic: - shard-kbl: [TIMEOUT][103] ([i915#1319] / [i915#727]) -> [TIMEOUT][104] ([i915#1319]) [103]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-kbl2/igt@kms_content_protection@atomic.html [104]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-kbl3/igt@kms_content_protection@atomic.html * igt@runner@aborted: - shard-hsw: ([FAIL][105], [FAIL][106], [FAIL][107], [FAIL][108], [FAIL][109], [FAIL][110], [FAIL][111], [FAIL][112]) ([fdo#111870] / [i915#226]) -> ([FAIL][113], [FAIL][114], [FAIL][115], [FAIL][116], [FAIL][117], [FAIL][118]) ([fdo#111870]) [105]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw5/igt@runner@aborted.html [106]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw7/igt@runner@aborted.html [107]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw7/igt@runner@aborted.html [108]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw5/igt@runner@aborted.html [109]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw6/igt@runner@aborted.html [110]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw7/igt@runner@aborted.html [111]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw1/igt@runner@aborted.html [112]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-hsw5/igt@runner@aborted.html [113]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw1/igt@runner@aborted.html [114]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw1/igt@runner@aborted.html [115]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw1/igt@runner@aborted.html [116]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw1/igt@runner@aborted.html [117]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw6/igt@runner@aborted.html [118]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-hsw5/igt@runner@aborted.html - shard-snb: ([FAIL][119], [FAIL][120], [FAIL][121], [FAIL][122], [FAIL][123], [FAIL][124], [FAIL][125], [FAIL][126]) ([fdo#111870] / [i915#1077] / [i915#698]) -> ([FAIL][127], [FAIL][128], [FAIL][129], [FAIL][130], [FAIL][131], [FAIL][132]) ([fdo#111870] / [i915#1077]) [119]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb2/igt@runner@aborted.html [120]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb4/igt@runner@aborted.html [121]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb2/igt@runner@aborted.html [122]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb6/igt@runner@aborted.html [123]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb4/igt@runner@aborted.html [124]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb6/igt@runner@aborted.html [125]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb6/igt@runner@aborted.html [126]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_8007/shard-snb2/igt@runner@aborted.html [127]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb2/igt@runner@aborted.html [128]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb5/igt@runner@aborted.html [129]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb5/igt@runner@aborted.html [130]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb2/igt@runner@aborted.html [131]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb4/igt@runner@aborted.html [132]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/shard-snb5/igt@runner@aborted.html {name}: This element is suppressed. This means it is ignored when computing the status of the difference (SUCCESS, WARNING, or FAILURE). [CI#80]: https://gitlab.freedesktop.org/gfx-ci/i915-infra/issues/80 [fdo#103375]: https://bugs.freedesktop.org/show_bug.cgi?id=103375 [fdo#103665]: https://bugs.freedesktop.org/show_bug.cgi?id=103665 [fdo#103927]: https://bugs.freedesktop.org/show_bug.cgi?id=103927 [fdo#109271]: https://bugs.freedesktop.org/show_bug.cgi?id=109271 [fdo#109276]: https://bugs.freedesktop.org/show_bug.cgi?id=109276 [fdo#109441]: https://bugs.freedesktop.org/show_bug.cgi?id=109441 [fdo#110854]: https://bugs.freedesktop.org/show_bug.cgi?id=110854 [fdo#110892]: https://bugs.freedesktop.org/show_bug.cgi?id=110892 [fdo#111644]: https://bugs.freedesktop.org/show_bug.cgi?id=111644 [fdo#111870]: https://bugs.freedesktop.org/show_bug.cgi?id=111870 [fdo#112080]: https://bugs.freedesktop.org/show_bug.cgi?id=112080 [fdo#112146]: https://bugs.freedesktop.org/show_bug.cgi?id=112146 [i915#1077]: https://gitlab.freedesktop.org/drm/intel/issues/1077 [i915#129]: https://gitlab.freedesktop.org/drm/intel/issues/129 [i915#1319]: https://gitlab.freedesktop.org/drm/intel/issues/1319 [i915#180]: https://gitlab.freedesktop.org/drm/intel/issues/180 [i915#226]: https://gitlab.freedesktop.org/drm/intel/issues/226 [i915#34]: https://gitlab.freedesktop.org/drm/intel/issues/34 [i915#413]: https://gitlab.freedesktop.org/drm/intel/issues/413 [i915#454]: https://gitlab.freedesktop.org/drm/intel/issues/454 [i915#468]: https://gitlab.freedesktop.org/drm/intel/issues/468 [i915#478]: https://gitlab.freedesktop.org/drm/intel/issues/478 [i915#488]: https://gitlab.freedesktop.org/drm/intel/issues/488 [i915#49]: https://gitlab.freedesktop.org/drm/intel/issues/49 [i915#54]: https://gitlab.freedesktop.org/drm/intel/issues/54 [i915#61]: https://gitlab.freedesktop.org/drm/intel/issues/61 [i915#644]: https://gitlab.freedesktop.org/drm/intel/issues/644 [i915#668]: https://gitlab.freedesktop.org/drm/intel/issues/668 [i915#677]: https://gitlab.freedesktop.org/drm/intel/issues/677 [i915#698]: https://gitlab.freedesktop.org/drm/intel/issues/698 [i915#727]: https://gitlab.freedesktop.org/drm/intel/issues/727 [i915#79]: https://gitlab.freedesktop.org/drm/intel/issues/79 [i915#82]: https://gitlab.freedesktop.org/drm/intel/issues/82 [i915#899]: https://gitlab.freedesktop.org/drm/intel/issues/899 Participating hosts (10 -> 8) ------------------------------ Missing (2): pig-skl-6260u pig-glk-j5005 Build changes ------------- * CI: CI-20190529 -> None * IGT: IGT_5469 -> IGTPW_4229 * Piglit: piglit_4509 -> None CI-20190529: 20190529 CI_DRM_8007: 8dbfb8dcfb623026de73fdb617785f507064af89 @ git://anongit.freedesktop.org/gfx-ci/linux IGTPW_4229: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/index.html IGT_5469: 4f875016eb1ebc211b8aadb280ae16c7e6cdc8ba @ git://anongit.freedesktop.org/xorg/app/intel-gpu-tools piglit_4509: fdc5a4ca11124ab8413c7988896eec4c97336694 @ git://anongit.freedesktop.org/piglit == Logs == For more details see: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_4229/index.html _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos 2020-02-26 13:45 [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos Swati Sharma ` (2 preceding siblings ...) 2020-02-27 4:49 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork @ 2020-02-27 7:03 ` Martin Peres 2020-02-27 7:31 ` Martin Peres 2020-03-12 7:59 ` Sharma, Swati2 3 siblings, 2 replies; 8+ messages in thread From: Martin Peres @ 2020-02-27 7:03 UTC (permalink / raw) To: Swati Sharma, igt-dev; +Cc: petri.latvala On 2020-02-26 15:45, Swati Sharma wrote: > i915 implements immutable zpos property whereas the existing test > case is written to validate mutable zpos. > > Added new test case to validate immutable zpos and skip existing > test case if i915 driver is not detected. > > Issue: https://gitlab.freedesktop.org/drm/intel/issues/404 > Signed-off-by: Swati Sharma <swati2.sharma@intel.com> > --- > tests/kms_atomic.c | 120 ++++++++++++++++++++++++++++++++++++++++++--- > 1 file changed, 112 insertions(+), 8 deletions(-) > > diff --git a/tests/kms_atomic.c b/tests/kms_atomic.c > index 8462d128..7a5edc8e 100644 > --- a/tests/kms_atomic.c > +++ b/tests/kms_atomic.c > @@ -121,7 +121,7 @@ static void plane_check_current_state(igt_plane_t *plane, const uint64_t *values > } > > static void plane_commit(igt_plane_t *plane, enum igt_commit_style s, > - enum kms_atomic_check_relax relax) > + enum kms_atomic_check_relax relax) > { > igt_display_commit2(plane->pipe->display, s); > plane_check_current_state(plane, plane->values, relax); > @@ -277,9 +277,9 @@ static uint32_t plane_get_igt_format(igt_plane_t *plane) > } > > static void > -plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output, > - igt_plane_t *primary, igt_plane_t *overlay, > - uint32_t format_primary, uint32_t format_overlay) > +plane_primary_overlay_mutable_zpos(igt_pipe_t *pipe, igt_output_t *output, > + igt_plane_t *primary, igt_plane_t *overlay, > + uint32_t format_primary, uint32_t format_overlay) > { > struct igt_fb fb_primary, fb_overlay; > drmModeModeInfo *mode = igt_output_get_mode(output); > @@ -358,6 +358,97 @@ plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output, > igt_assert_eq_u64(igt_plane_get_prop(overlay, IGT_PLANE_ZPOS), 1); > } > > +static void > +plane_immutable_zpos(igt_display_t *display, igt_pipe_t *pipe, > + igt_output_t *output) > +{ > + cairo_t *cr; > + int n_planes; > + uint32_t format; > + struct igt_fb fb_ref; > + igt_plane_t *primary; > + drmModeModeInfo *mode; > + igt_pipe_crc_t *pipe_crc; > + igt_crc_t ref_crc, new_crc; > + igt_plane_t *plane_lower, *plane_upper; > + uint32_t w_lower, h_lower, w_upper, h_upper; > + > + n_planes = pipe->n_planes; > + mode = igt_output_get_mode(output); > + primary = igt_pipe_get_plane_type(pipe, DRM_PLANE_TYPE_PRIMARY); > + > + /* for lower plane */ > + w_lower = mode->hdisplay; > + h_lower = mode->vdisplay; > + > + /* for upper plane */ > + w_upper = mode->hdisplay / 2; > + h_upper = mode->vdisplay / 2; > + > + if (intel_gen(display->drm_fd) == 3) > + format = DRM_FORMAT_RGB565; > + else > + format = DRM_FORMAT_ARGB8888; Let's not make this test intel-only. There should be a function in IGT to pick an available format supported by IGT (no matter which one). > + > + igt_create_color_fb(display->drm_fd, > + w_lower, h_lower, > + format, I915_TILING_NONE, > + 0.0, 0.0, 0.0, &fb_ref); > + > + cr = igt_get_cairo_ctx(display->drm_fd, &fb_ref); > + igt_assert(cairo_status(cr) == 0); > + igt_paint_color(cr, 0, 0, w_lower, h_lower, 0.0, 0.0, 1.0); > + igt_paint_color(cr, w_upper / 2, h_upper / 2, w_upper, h_upper, 1.0, 1.0, 0.0); > + igt_put_cairo_ctx(display->drm_fd, &fb_ref, cr); > + igt_plane_set_fb(primary, &fb_ref); > + igt_display_commit2(display, COMMIT_ATOMIC); Isn't that something the other zpos function do too? Maybe extracting it into a function would be good? Or make the plane_zpos function take a parameter (immutable / mutable)? > + > + /* create the pipe_crc object for this pipe */ > + pipe_crc = igt_pipe_crc_new(pipe->display->drm_fd, pipe->pipe, > + INTEL_PIPE_CRC_SOURCE_AUTO); > + > + /* get reference crc */ > + igt_pipe_crc_start(pipe_crc); > + igt_pipe_crc_get_current(display->drm_fd, pipe_crc, &ref_crc); Space / tab issue here? > + > + igt_plane_set_fb(primary, NULL); > + A comment here explaining that we want to avoid combinatorial explosion and thus only check pairs of planes in an increasing fashion? > + for (int i = 0; i < n_planes - 1; i++) { > + struct igt_fb fb[2]; > + plane_lower = &display->pipes[pipe->pipe].planes[i]; > + plane_upper = &display->pipes[pipe->pipe].planes[i + 1]; > + > + igt_require(igt_plane_has_prop(plane_lower, IGT_PLANE_ZPOS)); > + igt_require(igt_plane_has_prop(plane_upper, IGT_PLANE_ZPOS)); Isn't require leading to a skip if one plane is not supporting the zpos? Shouldn't we just continue instead? > + > + if ((plane_lower->type == DRM_PLANE_TYPE_CURSOR) || > + (plane_upper->type == DRM_PLANE_TYPE_CURSOR)) > + continue; Why special case the cursor plane? Because of its size? > + > + igt_create_color_fb(display->drm_fd, w_lower, h_lower, > + format, I915_TILING_NONE, > + 0.0, 0.0, 1.0, &fb[0]); > + > + igt_create_color_fb(display->drm_fd, w_upper, h_upper, > + format, I915_TILING_NONE, > + 1.0, 1.0, 0.0, &fb[1]); > + > + igt_plane_set_position(plane_lower, 0, 0); > + igt_plane_set_fb(plane_lower, &fb[0]); > + > + igt_plane_set_position(plane_upper, w_upper / 2, h_upper / 2); > + igt_plane_set_fb(plane_upper, &fb[1]); > + > + igt_display_commit2(display, COMMIT_ATOMIC); > + igt_pipe_crc_get_current(pipe->display->drm_fd, pipe_crc, &new_crc); > + > + igt_assert_crc_equal(&ref_crc, &new_crc); Just a though, since the lower plane is supposed to always cover anything under, we could set all the planes under the lower plane to a solid red color. This would make sure that lower planes have no influence over upper planes. What do you think? > + > + igt_plane_set_fb(plane_lower, NULL); > + igt_plane_set_fb(plane_upper, NULL); > + } > +} > + > static void plane_overlay(igt_pipe_t *pipe, igt_output_t *output, igt_plane_t *plane) > { > drmModeModeInfo *mode = igt_output_get_mode(output); > @@ -987,14 +1078,20 @@ igt_main > plane_primary(pipe_obj, primary, &fb); > } > > - igt_subtest("plane_primary_overlay_zpos") { > + igt_subtest("plane_primary_overlay_mutable_zpos") { > + /* > + * Since i915 driver doesn't support mutable zpos; > + * skipping. > + */ > + igt_require(!is_i915_device(display.drm_fd)); > + Let it fail / skip, no need to encode in IGT the capabilities of i915. > uint32_t format_primary = DRM_FORMAT_ARGB8888; > uint32_t format_overlay = DRM_FORMAT_ARGB1555; > > igt_plane_t *overlay = > igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_OVERLAY); > - > igt_require(overlay); > + > igt_require(igt_plane_has_prop(primary, IGT_PLANE_ZPOS)); > igt_require(igt_plane_has_prop(overlay, IGT_PLANE_ZPOS)); > > @@ -1002,8 +1099,14 @@ igt_main > igt_require(igt_plane_has_format_mod(overlay, format_overlay, 0x0)); > > igt_output_set_pipe(output, pipe); > - plane_primary_overlay_zpos(pipe_obj, output, primary, overlay, > - format_primary, format_overlay); > + plane_primary_overlay_mutable_zpos(pipe_obj, output, primary, overlay, > + format_primary, format_overlay); > + } > + > + igt_subtest("plane_immutable_zpos") { > + igt_require(is_i915_device(display.drm_fd)); > + igt_output_set_pipe(output, pipe); > + plane_immutable_zpos(&display, pipe_obj, output); > } Documentation missing for both the plane_immutable_zpos and plane_primary_overlay_mutable_zpos. Since you are now the expert on this, it would be nice for you to explain what the tests do as explained in https://drm.pages.freedesktop.org/igt-gpu-tools/igt-gpu-tools-Core.html#igt-describe . Something like "Test that the reported zpos of a plane is correct by making sure a full-screen plane covers all other planes with a lower zpos, and the plane with the next available zpos is indeed partially covering the full-screen plane". Otherwise, it looks pretty good. Looks more minor improvements needed rather than anything big. Well done! Martin > > igt_subtest("test_only") { > @@ -1011,6 +1114,7 @@ igt_main > > test_only(pipe_obj, primary, output); > } > + > igt_subtest("plane_cursor_legacy") { > igt_plane_t *cursor = > igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_CURSOR); > _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos 2020-02-27 7:03 ` [igt-dev] [PATCH i-g-t] " Martin Peres @ 2020-02-27 7:31 ` Martin Peres 2020-03-12 8:00 ` Sharma, Swati2 2020-03-12 7:59 ` Sharma, Swati2 1 sibling, 1 reply; 8+ messages in thread From: Martin Peres @ 2020-02-27 7:31 UTC (permalink / raw) To: Swati Sharma, igt-dev; +Cc: petri.latvala On 2020-02-27 09:03, Martin Peres wrote: > On 2020-02-26 15:45, Swati Sharma wrote: >> i915 implements immutable zpos property whereas the existing test >> case is written to validate mutable zpos. >> >> Added new test case to validate immutable zpos and skip existing >> test case if i915 driver is not detected. >> >> Issue: https://gitlab.freedesktop.org/drm/intel/issues/404 >> Signed-off-by: Swati Sharma <swati2.sharma@intel.com> >> --- >> tests/kms_atomic.c | 120 ++++++++++++++++++++++++++++++++++++++++++--- >> 1 file changed, 112 insertions(+), 8 deletions(-) >> >> diff --git a/tests/kms_atomic.c b/tests/kms_atomic.c >> index 8462d128..7a5edc8e 100644 >> --- a/tests/kms_atomic.c >> +++ b/tests/kms_atomic.c >> @@ -121,7 +121,7 @@ static void plane_check_current_state(igt_plane_t *plane, const uint64_t *values >> } >> >> static void plane_commit(igt_plane_t *plane, enum igt_commit_style s, >> - enum kms_atomic_check_relax relax) >> + enum kms_atomic_check_relax relax) >> { >> igt_display_commit2(plane->pipe->display, s); >> plane_check_current_state(plane, plane->values, relax); >> @@ -277,9 +277,9 @@ static uint32_t plane_get_igt_format(igt_plane_t *plane) >> } >> >> static void >> -plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output, >> - igt_plane_t *primary, igt_plane_t *overlay, >> - uint32_t format_primary, uint32_t format_overlay) >> +plane_primary_overlay_mutable_zpos(igt_pipe_t *pipe, igt_output_t *output, >> + igt_plane_t *primary, igt_plane_t *overlay, >> + uint32_t format_primary, uint32_t format_overlay) >> { >> struct igt_fb fb_primary, fb_overlay; >> drmModeModeInfo *mode = igt_output_get_mode(output); >> @@ -358,6 +358,97 @@ plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output, >> igt_assert_eq_u64(igt_plane_get_prop(overlay, IGT_PLANE_ZPOS), 1); >> } >> >> +static void >> +plane_immutable_zpos(igt_display_t *display, igt_pipe_t *pipe, >> + igt_output_t *output) >> +{ >> + cairo_t *cr; >> + int n_planes; >> + uint32_t format; >> + struct igt_fb fb_ref; >> + igt_plane_t *primary; >> + drmModeModeInfo *mode; >> + igt_pipe_crc_t *pipe_crc; >> + igt_crc_t ref_crc, new_crc; >> + igt_plane_t *plane_lower, *plane_upper; >> + uint32_t w_lower, h_lower, w_upper, h_upper; >> + >> + n_planes = pipe->n_planes; >> + mode = igt_output_get_mode(output); >> + primary = igt_pipe_get_plane_type(pipe, DRM_PLANE_TYPE_PRIMARY); >> + >> + /* for lower plane */ >> + w_lower = mode->hdisplay; >> + h_lower = mode->vdisplay; >> + >> + /* for upper plane */ >> + w_upper = mode->hdisplay / 2; >> + h_upper = mode->vdisplay / 2; >> + >> + if (intel_gen(display->drm_fd) == 3) >> + format = DRM_FORMAT_RGB565; >> + else >> + format = DRM_FORMAT_ARGB8888; > > Let's not make this test intel-only. There should be a function in IGT > to pick an available format supported by IGT (no matter which one). > >> + >> + igt_create_color_fb(display->drm_fd, >> + w_lower, h_lower, >> + format, I915_TILING_NONE, >> + 0.0, 0.0, 0.0, &fb_ref); >> + >> + cr = igt_get_cairo_ctx(display->drm_fd, &fb_ref); >> + igt_assert(cairo_status(cr) == 0); >> + igt_paint_color(cr, 0, 0, w_lower, h_lower, 0.0, 0.0, 1.0); >> + igt_paint_color(cr, w_upper / 2, h_upper / 2, w_upper, h_upper, 1.0, 1.0, 0.0); >> + igt_put_cairo_ctx(display->drm_fd, &fb_ref, cr); >> + igt_plane_set_fb(primary, &fb_ref); >> + igt_display_commit2(display, COMMIT_ATOMIC); > > Isn't that something the other zpos function do too? Maybe extracting it > into a function would be good? Or make the plane_zpos function take a > parameter (immutable / mutable)? > >> + >> + /* create the pipe_crc object for this pipe */ >> + pipe_crc = igt_pipe_crc_new(pipe->display->drm_fd, pipe->pipe, >> + INTEL_PIPE_CRC_SOURCE_AUTO); >> + >> + /* get reference crc */ >> + igt_pipe_crc_start(pipe_crc); >> + igt_pipe_crc_get_current(display->drm_fd, pipe_crc, &ref_crc); > > Space / tab issue here? > >> + >> + igt_plane_set_fb(primary, NULL); >> + > > A comment here explaining that we want to avoid combinatorial explosion > and thus only check pairs of planes in an increasing fashion? Oops, forgot to say here that you are relying on the planes to be exposed with the same order as the zpos, and never checking it directly. I propose you create a new plane array here that you will iterate through that would order the planes by zpos. Warn about planes without a zpos and planes with the same zpos as a current one. Should should skip if there are no planes with a zpos. Ignore the n^2 loop, even on ARM there aren't that many planes that this would become a problem. > >> + for (int i = 0; i < n_planes - 1; i++) { >> + struct igt_fb fb[2]; >> + plane_lower = &display->pipes[pipe->pipe].planes[i]; >> + plane_upper = &display->pipes[pipe->pipe].planes[i + 1]; >> + >> + igt_require(igt_plane_has_prop(plane_lower, IGT_PLANE_ZPOS)); >> + igt_require(igt_plane_has_prop(plane_upper, IGT_PLANE_ZPOS)); > > Isn't require leading to a skip if one plane is not supporting the zpos? > Shouldn't we just continue instead? > >> + >> + if ((plane_lower->type == DRM_PLANE_TYPE_CURSOR) || >> + (plane_upper->type == DRM_PLANE_TYPE_CURSOR)) >> + continue; > > Why special case the cursor plane? Because of its size? > >> + >> + igt_create_color_fb(display->drm_fd, w_lower, h_lower, >> + format, I915_TILING_NONE, >> + 0.0, 0.0, 1.0, &fb[0]); >> + >> + igt_create_color_fb(display->drm_fd, w_upper, h_upper, >> + format, I915_TILING_NONE, >> + 1.0, 1.0, 0.0, &fb[1]); >> + >> + igt_plane_set_position(plane_lower, 0, 0); >> + igt_plane_set_fb(plane_lower, &fb[0]); >> + >> + igt_plane_set_position(plane_upper, w_upper / 2, h_upper / 2); >> + igt_plane_set_fb(plane_upper, &fb[1]); >> + >> + igt_display_commit2(display, COMMIT_ATOMIC); >> + igt_pipe_crc_get_current(pipe->display->drm_fd, pipe_crc, &new_crc); >> + >> + igt_assert_crc_equal(&ref_crc, &new_crc); > > Just a though, since the lower plane is supposed to always cover > anything under, we could set all the planes under the lower plane to a > solid red color. This would make sure that lower planes have no > influence over upper planes. > > What do you think? > >> + >> + igt_plane_set_fb(plane_lower, NULL); >> + igt_plane_set_fb(plane_upper, NULL); >> + } >> +} >> + >> static void plane_overlay(igt_pipe_t *pipe, igt_output_t *output, igt_plane_t *plane) >> { >> drmModeModeInfo *mode = igt_output_get_mode(output); >> @@ -987,14 +1078,20 @@ igt_main >> plane_primary(pipe_obj, primary, &fb); >> } >> >> - igt_subtest("plane_primary_overlay_zpos") { >> + igt_subtest("plane_primary_overlay_mutable_zpos") { >> + /* >> + * Since i915 driver doesn't support mutable zpos; >> + * skipping. >> + */ >> + igt_require(!is_i915_device(display.drm_fd)); >> + > > Let it fail / skip, no need to encode in IGT the capabilities of i915. > >> uint32_t format_primary = DRM_FORMAT_ARGB8888; >> uint32_t format_overlay = DRM_FORMAT_ARGB1555; >> >> igt_plane_t *overlay = >> igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_OVERLAY); >> - >> igt_require(overlay); >> + >> igt_require(igt_plane_has_prop(primary, IGT_PLANE_ZPOS)); >> igt_require(igt_plane_has_prop(overlay, IGT_PLANE_ZPOS)); >> >> @@ -1002,8 +1099,14 @@ igt_main >> igt_require(igt_plane_has_format_mod(overlay, format_overlay, 0x0)); >> >> igt_output_set_pipe(output, pipe); >> - plane_primary_overlay_zpos(pipe_obj, output, primary, overlay, >> - format_primary, format_overlay); >> + plane_primary_overlay_mutable_zpos(pipe_obj, output, primary, overlay, >> + format_primary, format_overlay); >> + } >> + >> + igt_subtest("plane_immutable_zpos") { >> + igt_require(is_i915_device(display.drm_fd)); >> + igt_output_set_pipe(output, pipe); >> + plane_immutable_zpos(&display, pipe_obj, output); >> } > > Documentation missing for both the plane_immutable_zpos and > plane_primary_overlay_mutable_zpos. Since you are now the expert on > this, it would be nice for you to explain what the tests do as explained > in > https://drm.pages.freedesktop.org/igt-gpu-tools/igt-gpu-tools-Core.html#igt-describe > . Something like "Test that the reported zpos of a plane is correct by > making sure a full-screen plane covers all other planes with a lower > zpos, and the plane with the next available zpos is indeed partially > covering the full-screen plane". > > Otherwise, it looks pretty good. Looks more minor improvements needed > rather than anything big. Well done! > > Martin > >> >> igt_subtest("test_only") { >> @@ -1011,6 +1114,7 @@ igt_main >> >> test_only(pipe_obj, primary, output); >> } >> + >> igt_subtest("plane_cursor_legacy") { >> igt_plane_t *cursor = >> igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_CURSOR); >> > _______________________________________________ > igt-dev mailing list > igt-dev@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/igt-dev > _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos 2020-02-27 7:31 ` Martin Peres @ 2020-03-12 8:00 ` Sharma, Swati2 0 siblings, 0 replies; 8+ messages in thread From: Sharma, Swati2 @ 2020-03-12 8:00 UTC (permalink / raw) To: Martin Peres, igt-dev; +Cc: petri.latvala On 27-Feb-20 1:01 PM, Martin Peres wrote: > On 2020-02-27 09:03, Martin Peres wrote: >> On 2020-02-26 15:45, Swati Sharma wrote: >>> i915 implements immutable zpos property whereas the existing test >>> case is written to validate mutable zpos. >>> >>> Added new test case to validate immutable zpos and skip existing >>> test case if i915 driver is not detected. >>> >>> Issue: https://gitlab.freedesktop.org/drm/intel/issues/404 >>> Signed-off-by: Swati Sharma <swati2.sharma@intel.com> >>> --- >>> tests/kms_atomic.c | 120 ++++++++++++++++++++++++++++++++++++++++++--- >>> 1 file changed, 112 insertions(+), 8 deletions(-) >>> >>> diff --git a/tests/kms_atomic.c b/tests/kms_atomic.c >>> index 8462d128..7a5edc8e 100644 >>> --- a/tests/kms_atomic.c >>> +++ b/tests/kms_atomic.c >>> @@ -121,7 +121,7 @@ static void plane_check_current_state(igt_plane_t *plane, const uint64_t *values >>> } >>> >>> static void plane_commit(igt_plane_t *plane, enum igt_commit_style s, >>> - enum kms_atomic_check_relax relax) >>> + enum kms_atomic_check_relax relax) >>> { >>> igt_display_commit2(plane->pipe->display, s); >>> plane_check_current_state(plane, plane->values, relax); >>> @@ -277,9 +277,9 @@ static uint32_t plane_get_igt_format(igt_plane_t *plane) >>> } >>> >>> static void >>> -plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output, >>> - igt_plane_t *primary, igt_plane_t *overlay, >>> - uint32_t format_primary, uint32_t format_overlay) >>> +plane_primary_overlay_mutable_zpos(igt_pipe_t *pipe, igt_output_t *output, >>> + igt_plane_t *primary, igt_plane_t *overlay, >>> + uint32_t format_primary, uint32_t format_overlay) >>> { >>> struct igt_fb fb_primary, fb_overlay; >>> drmModeModeInfo *mode = igt_output_get_mode(output); >>> @@ -358,6 +358,97 @@ plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output, >>> igt_assert_eq_u64(igt_plane_get_prop(overlay, IGT_PLANE_ZPOS), 1); >>> } >>> >>> +static void >>> +plane_immutable_zpos(igt_display_t *display, igt_pipe_t *pipe, >>> + igt_output_t *output) >>> +{ >>> + cairo_t *cr; >>> + int n_planes; >>> + uint32_t format; >>> + struct igt_fb fb_ref; >>> + igt_plane_t *primary; >>> + drmModeModeInfo *mode; >>> + igt_pipe_crc_t *pipe_crc; >>> + igt_crc_t ref_crc, new_crc; >>> + igt_plane_t *plane_lower, *plane_upper; >>> + uint32_t w_lower, h_lower, w_upper, h_upper; >>> + >>> + n_planes = pipe->n_planes; >>> + mode = igt_output_get_mode(output); >>> + primary = igt_pipe_get_plane_type(pipe, DRM_PLANE_TYPE_PRIMARY); >>> + >>> + /* for lower plane */ >>> + w_lower = mode->hdisplay; >>> + h_lower = mode->vdisplay; >>> + >>> + /* for upper plane */ >>> + w_upper = mode->hdisplay / 2; >>> + h_upper = mode->vdisplay / 2; >>> + >>> + if (intel_gen(display->drm_fd) == 3) >>> + format = DRM_FORMAT_RGB565; >>> + else >>> + format = DRM_FORMAT_ARGB8888; >> >> Let's not make this test intel-only. There should be a function in IGT >> to pick an available format supported by IGT (no matter which one). >> >>> + >>> + igt_create_color_fb(display->drm_fd, >>> + w_lower, h_lower, >>> + format, I915_TILING_NONE, >>> + 0.0, 0.0, 0.0, &fb_ref); >>> + >>> + cr = igt_get_cairo_ctx(display->drm_fd, &fb_ref); >>> + igt_assert(cairo_status(cr) == 0); >>> + igt_paint_color(cr, 0, 0, w_lower, h_lower, 0.0, 0.0, 1.0); >>> + igt_paint_color(cr, w_upper / 2, h_upper / 2, w_upper, h_upper, 1.0, 1.0, 0.0); >>> + igt_put_cairo_ctx(display->drm_fd, &fb_ref, cr); >>> + igt_plane_set_fb(primary, &fb_ref); >>> + igt_display_commit2(display, COMMIT_ATOMIC); >> >> Isn't that something the other zpos function do too? Maybe extracting it >> into a function would be good? Or make the plane_zpos function take a >> parameter (immutable / mutable)? >> >>> + >>> + /* create the pipe_crc object for this pipe */ >>> + pipe_crc = igt_pipe_crc_new(pipe->display->drm_fd, pipe->pipe, >>> + INTEL_PIPE_CRC_SOURCE_AUTO); >>> + >>> + /* get reference crc */ >>> + igt_pipe_crc_start(pipe_crc); >>> + igt_pipe_crc_get_current(display->drm_fd, pipe_crc, &ref_crc); >> >> Space / tab issue here? >> >>> + >>> + igt_plane_set_fb(primary, NULL); >>> + >> >> A comment here explaining that we want to avoid combinatorial explosion >> and thus only check pairs of planes in an increasing fashion? > > Oops, forgot to say here that you are relying on the planes to be > exposed with the same order as the zpos, and never checking it directly. > > I propose you create a new plane array here that you will iterate > through that would order the planes by zpos. Warn about planes without a > zpos and planes with the same zpos as a current one. Should should skip > if there are no planes with a zpos. Done in v2. > > Ignore the n^2 loop, even on ARM there aren't that many planes that this > would become a problem. > >> >>> + for (int i = 0; i < n_planes - 1; i++) { >>> + struct igt_fb fb[2]; >>> + plane_lower = &display->pipes[pipe->pipe].planes[i]; >>> + plane_upper = &display->pipes[pipe->pipe].planes[i + 1]; >>> + >>> + igt_require(igt_plane_has_prop(plane_lower, IGT_PLANE_ZPOS)); >>> + igt_require(igt_plane_has_prop(plane_upper, IGT_PLANE_ZPOS)); >> >> Isn't require leading to a skip if one plane is not supporting the zpos? >> Shouldn't we just continue instead? >> >>> + >>> + if ((plane_lower->type == DRM_PLANE_TYPE_CURSOR) || >>> + (plane_upper->type == DRM_PLANE_TYPE_CURSOR)) >>> + continue; >> >> Why special case the cursor plane? Because of its size? >> >>> + >>> + igt_create_color_fb(display->drm_fd, w_lower, h_lower, >>> + format, I915_TILING_NONE, >>> + 0.0, 0.0, 1.0, &fb[0]); >>> + >>> + igt_create_color_fb(display->drm_fd, w_upper, h_upper, >>> + format, I915_TILING_NONE, >>> + 1.0, 1.0, 0.0, &fb[1]); >>> + >>> + igt_plane_set_position(plane_lower, 0, 0); >>> + igt_plane_set_fb(plane_lower, &fb[0]); >>> + >>> + igt_plane_set_position(plane_upper, w_upper / 2, h_upper / 2); >>> + igt_plane_set_fb(plane_upper, &fb[1]); >>> + >>> + igt_display_commit2(display, COMMIT_ATOMIC); >>> + igt_pipe_crc_get_current(pipe->display->drm_fd, pipe_crc, &new_crc); >>> + >>> + igt_assert_crc_equal(&ref_crc, &new_crc); >> >> Just a though, since the lower plane is supposed to always cover >> anything under, we could set all the planes under the lower plane to a >> solid red color. This would make sure that lower planes have no >> influence over upper planes. >> >> What do you think? >> >>> + >>> + igt_plane_set_fb(plane_lower, NULL); >>> + igt_plane_set_fb(plane_upper, NULL); >>> + } >>> +} >>> + >>> static void plane_overlay(igt_pipe_t *pipe, igt_output_t *output, igt_plane_t *plane) >>> { >>> drmModeModeInfo *mode = igt_output_get_mode(output); >>> @@ -987,14 +1078,20 @@ igt_main >>> plane_primary(pipe_obj, primary, &fb); >>> } >>> >>> - igt_subtest("plane_primary_overlay_zpos") { >>> + igt_subtest("plane_primary_overlay_mutable_zpos") { >>> + /* >>> + * Since i915 driver doesn't support mutable zpos; >>> + * skipping. >>> + */ >>> + igt_require(!is_i915_device(display.drm_fd)); >>> + >> >> Let it fail / skip, no need to encode in IGT the capabilities of i915. >> >>> uint32_t format_primary = DRM_FORMAT_ARGB8888; >>> uint32_t format_overlay = DRM_FORMAT_ARGB1555; >>> >>> igt_plane_t *overlay = >>> igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_OVERLAY); >>> - >>> igt_require(overlay); >>> + >>> igt_require(igt_plane_has_prop(primary, IGT_PLANE_ZPOS)); >>> igt_require(igt_plane_has_prop(overlay, IGT_PLANE_ZPOS)); >>> >>> @@ -1002,8 +1099,14 @@ igt_main >>> igt_require(igt_plane_has_format_mod(overlay, format_overlay, 0x0)); >>> >>> igt_output_set_pipe(output, pipe); >>> - plane_primary_overlay_zpos(pipe_obj, output, primary, overlay, >>> - format_primary, format_overlay); >>> + plane_primary_overlay_mutable_zpos(pipe_obj, output, primary, overlay, >>> + format_primary, format_overlay); >>> + } >>> + >>> + igt_subtest("plane_immutable_zpos") { >>> + igt_require(is_i915_device(display.drm_fd)); >>> + igt_output_set_pipe(output, pipe); >>> + plane_immutable_zpos(&display, pipe_obj, output); >>> } >> >> Documentation missing for both the plane_immutable_zpos and >> plane_primary_overlay_mutable_zpos. Since you are now the expert on >> this, it would be nice for you to explain what the tests do as explained >> in >> https://drm.pages.freedesktop.org/igt-gpu-tools/igt-gpu-tools-Core.html#igt-describe >> . Something like "Test that the reported zpos of a plane is correct by >> making sure a full-screen plane covers all other planes with a lower >> zpos, and the plane with the next available zpos is indeed partially >> covering the full-screen plane". >> >> Otherwise, it looks pretty good. Looks more minor improvements needed >> rather than anything big. Well done! >> >> Martin >> >>> >>> igt_subtest("test_only") { >>> @@ -1011,6 +1114,7 @@ igt_main >>> >>> test_only(pipe_obj, primary, output); >>> } >>> + >>> igt_subtest("plane_cursor_legacy") { >>> igt_plane_t *cursor = >>> igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_CURSOR); >>> >> _______________________________________________ >> igt-dev mailing list >> igt-dev@lists.freedesktop.org >> https://lists.freedesktop.org/mailman/listinfo/igt-dev >> -- ~Swati Sharma _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos 2020-02-27 7:03 ` [igt-dev] [PATCH i-g-t] " Martin Peres 2020-02-27 7:31 ` Martin Peres @ 2020-03-12 7:59 ` Sharma, Swati2 1 sibling, 0 replies; 8+ messages in thread From: Sharma, Swati2 @ 2020-03-12 7:59 UTC (permalink / raw) To: Martin Peres, igt-dev; +Cc: petri.latvala On 27-Feb-20 12:33 PM, Martin Peres wrote: > On 2020-02-26 15:45, Swati Sharma wrote: >> i915 implements immutable zpos property whereas the existing test >> case is written to validate mutable zpos. >> >> Added new test case to validate immutable zpos and skip existing >> test case if i915 driver is not detected. >> >> Issue: https://gitlab.freedesktop.org/drm/intel/issues/404 >> Signed-off-by: Swati Sharma <swati2.sharma@intel.com> >> --- >> tests/kms_atomic.c | 120 ++++++++++++++++++++++++++++++++++++++++++--- >> 1 file changed, 112 insertions(+), 8 deletions(-) >> >> diff --git a/tests/kms_atomic.c b/tests/kms_atomic.c >> index 8462d128..7a5edc8e 100644 >> --- a/tests/kms_atomic.c >> +++ b/tests/kms_atomic.c >> @@ -121,7 +121,7 @@ static void plane_check_current_state(igt_plane_t *plane, const uint64_t *values >> } >> >> static void plane_commit(igt_plane_t *plane, enum igt_commit_style s, >> - enum kms_atomic_check_relax relax) >> + enum kms_atomic_check_relax relax) >> { >> igt_display_commit2(plane->pipe->display, s); >> plane_check_current_state(plane, plane->values, relax); >> @@ -277,9 +277,9 @@ static uint32_t plane_get_igt_format(igt_plane_t *plane) >> } >> >> static void >> -plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output, >> - igt_plane_t *primary, igt_plane_t *overlay, >> - uint32_t format_primary, uint32_t format_overlay) >> +plane_primary_overlay_mutable_zpos(igt_pipe_t *pipe, igt_output_t *output, >> + igt_plane_t *primary, igt_plane_t *overlay, >> + uint32_t format_primary, uint32_t format_overlay) >> { >> struct igt_fb fb_primary, fb_overlay; >> drmModeModeInfo *mode = igt_output_get_mode(output); >> @@ -358,6 +358,97 @@ plane_primary_overlay_zpos(igt_pipe_t *pipe, igt_output_t *output, >> igt_assert_eq_u64(igt_plane_get_prop(overlay, IGT_PLANE_ZPOS), 1); >> } >> >> +static void >> +plane_immutable_zpos(igt_display_t *display, igt_pipe_t *pipe, >> + igt_output_t *output) >> +{ >> + cairo_t *cr; >> + int n_planes; >> + uint32_t format; >> + struct igt_fb fb_ref; >> + igt_plane_t *primary; >> + drmModeModeInfo *mode; >> + igt_pipe_crc_t *pipe_crc; >> + igt_crc_t ref_crc, new_crc; >> + igt_plane_t *plane_lower, *plane_upper; >> + uint32_t w_lower, h_lower, w_upper, h_upper; >> + >> + n_planes = pipe->n_planes; >> + mode = igt_output_get_mode(output); >> + primary = igt_pipe_get_plane_type(pipe, DRM_PLANE_TYPE_PRIMARY); >> + >> + /* for lower plane */ >> + w_lower = mode->hdisplay; >> + h_lower = mode->vdisplay; >> + >> + /* for upper plane */ >> + w_upper = mode->hdisplay / 2; >> + h_upper = mode->vdisplay / 2; >> + >> + if (intel_gen(display->drm_fd) == 3) >> + format = DRM_FORMAT_RGB565; >> + else >> + format = DRM_FORMAT_ARGB8888; > > Let's not make this test intel-only. There should be a function in IGT > to pick an available format supported by IGT (no matter which one). Done in v2. I have used XRGB8888 pixel format, i could have used IGT func to pick an available format but since formats do come with limitations too..avoided that and used fixed XRGB8888 as used in other IGTs since this IGT doesn't test pixel formats and format shouldn't be constraint. Is it okay? > >> + >> + igt_create_color_fb(display->drm_fd, >> + w_lower, h_lower, >> + format, I915_TILING_NONE, >> + 0.0, 0.0, 0.0, &fb_ref); >> + >> + cr = igt_get_cairo_ctx(display->drm_fd, &fb_ref); >> + igt_assert(cairo_status(cr) == 0); >> + igt_paint_color(cr, 0, 0, w_lower, h_lower, 0.0, 0.0, 1.0); >> + igt_paint_color(cr, w_upper / 2, h_upper / 2, w_upper, h_upper, 1.0, 1.0, 0.0); >> + igt_put_cairo_ctx(display->drm_fd, &fb_ref, cr); >> + igt_plane_set_fb(primary, &fb_ref); >> + igt_display_commit2(display, COMMIT_ATOMIC); > > Isn't that something the other zpos function do too? Maybe extracting it > into a function would be good? Or make the plane_zpos function take a > parameter (immutable / mutable)? No the other mutable zpos doesn't do the same thing, function definition itself is different since it tests only 2 planes primary and overlay. And there is no CRC based validation, so no need to drawing reference image. > >> + >> + /* create the pipe_crc object for this pipe */ >> + pipe_crc = igt_pipe_crc_new(pipe->display->drm_fd, pipe->pipe, >> + INTEL_PIPE_CRC_SOURCE_AUTO); >> + >> + /* get reference crc */ >> + igt_pipe_crc_start(pipe_crc); >> + igt_pipe_crc_get_current(display->drm_fd, pipe_crc, &ref_crc); > > Space / tab issue here? Done in v2 > >> + >> + igt_plane_set_fb(primary, NULL); >> + > > A comment here explaining that we want to avoid combinatorial explosion > and thus only check pairs of planes in an increasing fashion? Done in v2 > >> + for (int i = 0; i < n_planes - 1; i++) { >> + struct igt_fb fb[2]; >> + plane_lower = &display->pipes[pipe->pipe].planes[i]; >> + plane_upper = &display->pipes[pipe->pipe].planes[i + 1]; >> + >> + igt_require(igt_plane_has_prop(plane_lower, IGT_PLANE_ZPOS)); >> + igt_require(igt_plane_has_prop(plane_upper, IGT_PLANE_ZPOS)); > > Isn't require leading to a skip if one plane is not supporting the zpos? > Shouldn't we just continue instead? Done in v2 > >> + >> + if ((plane_lower->type == DRM_PLANE_TYPE_CURSOR) || >> + (plane_upper->type == DRM_PLANE_TYPE_CURSOR)) >> + continue; > > Why special case the cursor plane? Because of its size? Yes, cursor needs small buffer size, so avoided that. > >> + >> + igt_create_color_fb(display->drm_fd, w_lower, h_lower, >> + format, I915_TILING_NONE, >> + 0.0, 0.0, 1.0, &fb[0]); >> + >> + igt_create_color_fb(display->drm_fd, w_upper, h_upper, >> + format, I915_TILING_NONE, >> + 1.0, 1.0, 0.0, &fb[1]); >> + >> + igt_plane_set_position(plane_lower, 0, 0); >> + igt_plane_set_fb(plane_lower, &fb[0]); >> + >> + igt_plane_set_position(plane_upper, w_upper / 2, h_upper / 2); >> + igt_plane_set_fb(plane_upper, &fb[1]); >> + >> + igt_display_commit2(display, COMMIT_ATOMIC); >> + igt_pipe_crc_get_current(pipe->display->drm_fd, pipe_crc, &new_crc); >> + >> + igt_assert_crc_equal(&ref_crc, &new_crc); > > Just a though, since the lower plane is supposed to always cover > anything under, we could set all the planes under the lower plane to a > solid red color. This would make sure that lower planes have no > influence over upper planes. > > What do you think? Since we are validating zpos 2 planes at time, there won't be any plane below the lower plane, so may be coloring lower planes as red not required. I tried to accommodate it like committing with plane_max => yellow, small size and plane_(max-1) => blue, full screen and rest planes as red..but for this we need to enable all planes which will lead to BW issues. Anyhow if we validate p1 & p2, p2 & p3 it automatically validates p1 & p3 (transitive). Is it okay? > >> + >> + igt_plane_set_fb(plane_lower, NULL); >> + igt_plane_set_fb(plane_upper, NULL); >> + } >> +} >> + >> static void plane_overlay(igt_pipe_t *pipe, igt_output_t *output, igt_plane_t *plane) >> { >> drmModeModeInfo *mode = igt_output_get_mode(output); >> @@ -987,14 +1078,20 @@ igt_main >> plane_primary(pipe_obj, primary, &fb); >> } >> >> - igt_subtest("plane_primary_overlay_zpos") { >> + igt_subtest("plane_primary_overlay_mutable_zpos") { >> + /* >> + * Since i915 driver doesn't support mutable zpos; >> + * skipping. >> + */ >> + igt_require(!is_i915_device(display.drm_fd)); >> + > > Let it fail / skip, no need to encode in IGT the capabilities of i915. Done in v2 > >> uint32_t format_primary = DRM_FORMAT_ARGB8888; >> uint32_t format_overlay = DRM_FORMAT_ARGB1555; >> >> igt_plane_t *overlay = >> igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_OVERLAY); >> - >> igt_require(overlay); >> + >> igt_require(igt_plane_has_prop(primary, IGT_PLANE_ZPOS)); >> igt_require(igt_plane_has_prop(overlay, IGT_PLANE_ZPOS)); >> >> @@ -1002,8 +1099,14 @@ igt_main >> igt_require(igt_plane_has_format_mod(overlay, format_overlay, 0x0)); >> >> igt_output_set_pipe(output, pipe); >> - plane_primary_overlay_zpos(pipe_obj, output, primary, overlay, >> - format_primary, format_overlay); >> + plane_primary_overlay_mutable_zpos(pipe_obj, output, primary, overlay, >> + format_primary, format_overlay); >> + } >> + >> + igt_subtest("plane_immutable_zpos") { >> + igt_require(is_i915_device(display.drm_fd)); >> + igt_output_set_pipe(output, pipe); >> + plane_immutable_zpos(&display, pipe_obj, output); >> } > > Documentation missing for both the plane_immutable_zpos and > plane_primary_overlay_mutable_zpos. Since you are now the expert on > this, it would be nice for you to explain what the tests do as explained > in > https://drm.pages.freedesktop.org/igt-gpu-tools/igt-gpu-tools-Core.html#igt-describe > . Something like "Test that the reported zpos of a plane is correct by > making sure a full-screen plane covers all other planes with a lower > zpos, and the plane with the next available zpos is indeed partially > covering the full-screen plane". > Done in v2. > Otherwise, it looks pretty good. Looks more minor improvements needed > rather than anything big. Well done! Thanks Martin for the review. > > Martin > >> >> igt_subtest("test_only") { >> @@ -1011,6 +1114,7 @@ igt_main >> >> test_only(pipe_obj, primary, output); >> } >> + >> igt_subtest("plane_cursor_legacy") { >> igt_plane_t *cursor = >> igt_pipe_get_plane_type(pipe_obj, DRM_PLANE_TYPE_CURSOR); >> -- ~Swati Sharma _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2020-03-12 8:00 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2020-02-26 13:45 [igt-dev] [PATCH i-g-t] tests/kms_atomic: add test to validate immutable zpos Swati Sharma 2020-02-26 15:18 ` [igt-dev] ✗ GitLab.Pipeline: failure for " Patchwork 2020-02-26 16:48 ` [igt-dev] ✓ Fi.CI.BAT: success " Patchwork 2020-02-27 4:49 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork 2020-02-27 7:03 ` [igt-dev] [PATCH i-g-t] " Martin Peres 2020-02-27 7:31 ` Martin Peres 2020-03-12 8:00 ` Sharma, Swati2 2020-03-12 7:59 ` Sharma, Swati2
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox