* [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: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
* 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
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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.