Igt-dev Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Bhanuprakash Modem <bhanuprakash.modem@intel.com>
To: igt-dev@lists.freedesktop.org
Subject: [igt-dev] [i-g-t 33/79] tests/kms_atomic: Document each subtest for testplan
Date: Mon, 15 May 2023 13:46:34 +0530	[thread overview]
Message-ID: <20230515081720.3713293-34-bhanuprakash.modem@intel.com> (raw)
In-Reply-To: <20230515081720.3713293-1-bhanuprakash.modem@intel.com>

Add documentation for all kms tests which is used by IGT testplan
documentation.

Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem@intel.com>
---
 tests/kms_atomic.c | 102 ++++++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 100 insertions(+), 2 deletions(-)

diff --git a/tests/kms_atomic.c b/tests/kms_atomic.c
index 037db2d36..27c0e6368 100644
--- a/tests/kms_atomic.c
+++ b/tests/kms_atomic.c
@@ -27,8 +27,10 @@
  *    Pekka Paalanen <pekka.paalanen@collabora.co.uk>
  */
 
-/*
- * Testcase: testing atomic modesetting API
+/**
+ * TEST: kms atomic
+ * Category: Display
+ * Description: Test atomic modesetting API
  */
 
 #include <unistd.h>
@@ -287,6 +289,16 @@ static uint32_t plane_get_igt_format(igt_plane_t *plane)
 	return 0;
 }
 
+/**
+ * SUBTEST: plane-primary-overlay-mutable-zpos
+ * Description: Verify that the overlay plane can cover the primary one (and
+ *              vice versa) by changing their zpos property.
+ * Driver requirement: any
+ * Functionality: kms_core
+ * Mega feature: General Display Features
+ * Run type: FULL
+ * Test category: functionality test
+ */
 static void
 plane_primary_overlay_mutable_zpos(igt_pipe_t *pipe, igt_output_t *output,
 				   igt_plane_t *primary, igt_plane_t *overlay,
@@ -369,6 +381,16 @@ plane_primary_overlay_mutable_zpos(igt_pipe_t *pipe, igt_output_t *output,
 	igt_assert_eq_u64(igt_plane_get_prop(overlay, IGT_PLANE_ZPOS), 1);
 }
 
+/**
+ * SUBTEST: plane-immutable-zpos
+ * Description: Verify the reported zpos property of planes by making sure only
+ *              higher zpos planes cover the lower zpos ones.
+ * Driver requirement: any
+ * Functionality: kms_core
+ * Mega feature: General Display Features
+ * Run type: FULL
+ * Test category: functionality test
+ */
 static void
 plane_immutable_zpos(igt_display_t *display, igt_pipe_t *pipe,
 		     igt_output_t *output)
@@ -505,6 +527,22 @@ plane_immutable_zpos(igt_display_t *display, igt_pipe_t *pipe,
 	igt_remove_fb(display->drm_fd, &fb_upper);
 }
 
+/**
+ * SUBTEST: plane-%s-legacy
+ * Description: Test for KMS atomic modesetting on %arg[1] and ensure coherency
+ *              between legacy and atomic interfaces.
+ * Driver requirement: any
+ * Functionality: kms_core
+ * Mega feature: General Display Features
+ * Run type: FULL
+ * Test category: functionality test
+ *
+ * arg[1]:
+ *
+ * @cursor:         Cursor plane
+ * @overlay:        Overlay plane
+ * @primary:        Primary plane
+ */
 static void plane_overlay(igt_pipe_t *pipe, igt_output_t *output, igt_plane_t *plane)
 {
 	drmModeModeInfo *mode = igt_output_get_mode(output);
@@ -579,6 +617,17 @@ static void plane_primary(igt_pipe_t *pipe, igt_plane_t *plane, struct igt_fb *f
 	plane_commit(plane, COMMIT_UNIVERSAL, ATOMIC_RELAX_NONE);
 }
 
+/**
+ * SUBTEST: test-only
+ * Description: Test to ensure that DRM_MODE_ATOMIC_TEST_ONLY really only touches
+ *              the free-standing state objects and nothing else.
+ * Driver requirement: any
+ * Functionality: kms_core
+ * Mega feature: General Display Features
+ * Run type: FULL
+ * Test category: functionality test
+ */
+
 /* test to ensure that DRM_MODE_ATOMIC_TEST_ONLY really only touches the
  * free-standing state objects and nothing else.
  */
@@ -687,6 +736,20 @@ static void plane_cursor(igt_pipe_t *pipe_obj,
 	plane_commit(cursor, COMMIT_LEGACY, ATOMIC_RELAX_NONE);
 }
 
+/**
+ * SUBTEST: plane-invalid-%s
+ * Description: Test error handling when invalid %arg[1] are passed
+ * Driver requirement: any
+ * Functionality: kms_core
+ * Mega feature: General Display Features
+ * Run type: FULL
+ * Test category: functionality test
+ *
+ * arg[1]:
+ *
+ * @params:           plane parameters
+ * @params-fence:     plane fence parameters
+ */
 static void plane_invalid_params(igt_pipe_t *pipe,
 				 igt_output_t *output,
 				 igt_plane_t *plane,
@@ -776,6 +839,20 @@ static void plane_invalid_params_fence(igt_pipe_t *pipe,
 	close(timeline);
 }
 
+/**
+ * SUBTEST: crtc-invalid-%s
+ * Description: Test error handling when invalid %arg[1] are passed
+ * Driver requirement: any
+ * Functionality: kms_core
+ * Mega feature: General Display Features
+ * Run type: FULL
+ * Test category: functionality test
+ *
+ * arg[1]:
+ *
+ * @params:           crtc parameters
+ * @params-fence:     crtc fence parameters
+ */
 static void crtc_invalid_params(igt_pipe_t *pipe,
 				igt_output_t *output,
 				igt_plane_t *plane,
@@ -923,6 +1000,18 @@ static void crtc_invalid_params_fence(igt_pipe_t *pipe,
 	igt_assert(pipe->out_fence_fd != -1);
 }
 
+/**
+ * SUBTEST: atomic-invalid-params
+ * Description: Test abuse the atomic ioctl directly in order to test various
+ *              invalid conditions which the libdrm wrapper won't allow us to
+ *              create.
+ * Driver requirement: any
+ * Functionality: kms_core
+ * Mega feature: General Display Features
+ * Run type: FULL
+ * Test category: functionality test
+ */
+
 /* Abuse the atomic ioctl directly in order to test various invalid conditions,
  * which the libdrm wrapper won't allow us to create. */
 static void atomic_invalid_params(igt_pipe_t *pipe,
@@ -1064,6 +1153,15 @@ static void atomic_invalid_params(igt_pipe_t *pipe,
 	do_ioctl_err(display->drm_fd, DRM_IOCTL_MODE_ATOMIC, &ioc, EFAULT);
 }
 
+/**
+ * SUBTEST: atomic_plane_damage
+ * Description: Simple test cases to use FB_DAMAGE_CLIPS plane property
+ * Driver requirement: any
+ * Functionality: kms_core
+ * Mega feature: General Display Features
+ * Run type: FULL
+ * Test category: functionality test
+ */
 static void atomic_plane_damage(igt_pipe_t *pipe, igt_plane_t *plane, struct igt_fb *fb)
 {
 	struct drm_mode_rect damage[2];
-- 
2.40.0

  parent reply	other threads:[~2023-05-15  8:23 UTC|newest]

Thread overview: 94+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-05-15  8:16 [igt-dev] [i-g-t 00/79] Document KMS tests Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 01/79] tests/chamelium: Move chamelium helpers to lib Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 02/79] tests/dsc: Move dsc " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 03/79] tests/color: Move color " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 04/79] testplan/kms: Add support to differentiate b/w drivers Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 05/79] tests/chamelium/kms_chamelium_audio: Document each subtest for testplan Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 06/79] tests/chamelium/kms_chamelium_color: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 07/79] tests/chamelium/kms_chamelium_edid: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 08/79] tests/chamelium/kms_chamelium_frames: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 09/79] tests/chamelium/kms_chamelium_hpd: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 10/79] tests/i915/kms_big_fb: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 11/79] tests/i915/kms_big_joiner: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 12/79] tests/i915/kms_busy: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 13/79] tests/i915/kms_ccs: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 14/79] tests/i915/kms_cdclk: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 15/79] tests/i915/kms_draw_crc: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 16/79] tests/i915/kms_dsc: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 17/79] tests/i915/kms_fbcon_fbt: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 18/79] tests/i915/kms_fence_pin_leak: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 19/79] tests/i915/kms_flip_scaled_crc: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 20/79] tests/i915/kms_flip_tiling: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 21/79] tests/i915/kms_frontbuffer_tracking: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 22/79] tests/i915/kms_legacy_colorkey: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 23/79] tests/i915/kms_mmap_write_crc: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 24/79] tests/i915/kms_pipe_b_c_ivb: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 25/79] tests/i915/kms_psr: " Bhanuprakash Modem
2023-05-15 16:43   ` [igt-dev] [i-g-t V2 " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 26/79] tests/i915/kms_psr2_sf: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 27/79] tests/i915/kms_psr2_su: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 28/79] tests/i915/kms_psr_stress_test: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 29/79] tests/i915/kms_pwrite_crc: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 30/79] tests/kms_3d: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 31/79] tests/kms_addfb_basic: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 32/79] tests/kms_async_flips: " Bhanuprakash Modem
2023-05-15  8:16 ` Bhanuprakash Modem [this message]
2023-05-15  8:16 ` [igt-dev] [i-g-t 34/79] tests/kms_atomic_interruptible: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 35/79] tests/kms_atomic_transition: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 36/79] tests/kms_bw: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 37/79] tests/kms_color: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 38/79] tests/kms_concurrent: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 39/79] tests/kms_content_protection: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 40/79] tests/kms_cursor_crc: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 41/79] tests/kms_cursor_edge_walk: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 42/79] tests/kms_cursor_legacy: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 43/79] tests/kms_display_modes: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 44/79] tests/kms_dither: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 45/79] tests/kms_dp_aux_dev: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 46/79] tests/kms_dp_tiled_display: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 47/79] tests/kms_flip: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 48/79] tests/kms_flip_event_leak: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 49/79] tests/kms_force_connector_basic: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 50/79] tests/kms_getfb: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 51/79] tests/kms_hdmi_inject: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 52/79] tests/kms_hdr: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 53/79] tests/kms_invalid_mode: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 54/79] tests/kms_lease: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 55/79] tests/kms_multipipe_modeset: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 56/79] tests/kms_panel_fitting: " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 57/79] tests/kms_pipe_crc_basic: " Bhanuprakash Modem
2023-05-15 16:43   ` [igt-dev] [i-g-t V2 " Bhanuprakash Modem
2023-05-15  8:16 ` [igt-dev] [i-g-t 58/79] tests/kms_plane: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 59/79] tests/kms_plane_alpha_blend: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 60/79] tests/kms_plane_cursor: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 61/79] tests/kms_plane_lowres: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 62/79] tests/kms_plane_multiple: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 63/79] tests/kms_plane_scaling: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 64/79] tests/kms_prime: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 65/79] tests/kms_prop_blob: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 66/79] tests/kms_properties: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 67/79] tests/kms_rmfb: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 68/79] tests/kms_rotation_crc: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 69/79] tests/kms_scaling_modes: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 70/79] tests/kms_selftest: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 71/79] tests/kms_sequence: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 72/79] tests/kms_setmode: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 73/79] tests/kms_sysfs_edid_timing: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 74/79] tests/kms_tv_load_detect: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 75/79] tests/kms_universal_plane: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 76/79] tests/kms_vblank: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 77/79] tests/kms_vrr: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 78/79] tests/kms_writeback: " Bhanuprakash Modem
2023-05-15  8:17 ` [igt-dev] [i-g-t 79/79] testplan/kms: Make documentation is mandatory for all kms subtests Bhanuprakash Modem
2023-05-15 12:17   ` [igt-dev] [i-g-t V2 " Bhanuprakash Modem
2023-05-16  3:53     ` [igt-dev] [i-g-t V3 " Bhanuprakash Modem
2023-05-15 14:58 ` [igt-dev] ✗ GitLab.Pipeline: warning for Document KMS tests (rev2) Patchwork
2023-05-15 15:29 ` [igt-dev] ✗ Fi.CI.BAT: failure " Patchwork
2023-05-15 17:38 ` [igt-dev] ✗ GitLab.Pipeline: warning for Document KMS tests (rev4) Patchwork
2023-05-15 18:06 ` [igt-dev] ✓ Fi.CI.BAT: success " Patchwork
2023-05-15 19:56 ` [igt-dev] ✗ Fi.CI.BUILD: failure for Document KMS tests (rev5) Patchwork
2023-05-15 23:27 ` [igt-dev] ✓ Fi.CI.IGT: success for Document KMS tests (rev4) Patchwork
2023-05-16  4:10 ` [igt-dev] ✗ GitLab.Pipeline: warning for Document KMS tests (rev6) Patchwork
2023-05-16  4:41 ` [igt-dev] ✗ Fi.CI.BAT: failure " Patchwork
2023-05-16  6:30 ` [igt-dev] ✗ GitLab.Pipeline: warning for Document KMS tests (rev7) Patchwork
2023-05-16  6:56 ` [igt-dev] ✗ Fi.CI.BAT: failure " Patchwork

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20230515081720.3713293-34-bhanuprakash.modem@intel.com \
    --to=bhanuprakash.modem@intel.com \
    --cc=igt-dev@lists.freedesktop.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox