[PATCH i-g-t] tests/amdgpu/amd_abm: Remove the modeset for ABM level setting

Leo Li sunpeng.li at amd.com
Mon Aug 26 18:03:07 UTC 2024



On 2024-08-26 04:25, Tom Chung wrote:
> [Why]
> Set the ABM level does not need to trigger the modeset to take effect.
> 
> [How]
> Replace the DPMS off -> on transition in set_abm_level() with
> atomic commit.
> 
> Signed-off-by: Tom Chung <chiahsuan.chung at amd.com>
Reviewed-by: Leo Li <sunpeng.li at amd.com>
Thanks!

> ---
>   tests/amdgpu/amd_abm.c | 99 ++++++++++++++++++++++++++++++------------
>   1 file changed, 71 insertions(+), 28 deletions(-)
> 
> diff --git a/tests/amdgpu/amd_abm.c b/tests/amdgpu/amd_abm.c
> index 2882c2c18..a85f444c4 100644
> --- a/tests/amdgpu/amd_abm.c
> +++ b/tests/amdgpu/amd_abm.c
> @@ -39,9 +39,75 @@
>   
>   typedef struct data {
>   	igt_display_t display;
> +	igt_plane_t *primary;
> +	igt_output_t *output;
> +	igt_pipe_t *pipe;
>   	int drm_fd;
> +	drmModeModeInfo *mode;
> +	enum pipe pipe_id;
> +	int w, h;
> +	igt_fb_t ref_fb;
>   } data_t;
>   
> +/* Common test setup. */
> +static void test_init(data_t *data)
> +{
> +	igt_display_t *display = &data->display;
> +	drmModeConnectorPtr conn;
> +	bool has_edp = false;
> +	int i;
> +
> +	/* Skip test if no eDP connected. */
> +	for (i = 0; i < display->n_outputs; i++) {
> +		conn = display->outputs[i].config.connector;
> +
> +		if (conn->connector_type == DRM_MODE_CONNECTOR_eDP &&
> +		    conn->connection == DRM_MODE_CONNECTED) {
> +			has_edp = true;
> +		}
> +	}
> +	if (!has_edp)
> +		igt_skip("No eDP connector found\n");
> +
> +	/* It doesn't matter which pipe we choose on amdpgu. */
> +	data->pipe_id = PIPE_A;
> +	data->pipe = &data->display.pipes[data->pipe_id];
> +
> +	igt_display_reset(display);
> +
> +	data->output = igt_get_single_output_for_pipe(display, data->pipe_id);
> +	igt_require(data->output);
> +	igt_info("output %s\n", data->output->name);
> +
> +	data->mode = igt_output_get_mode(data->output);
> +	igt_assert(data->mode);
> +	kmstest_dump_mode(data->mode);
> +
> +	data->primary =
> +		 igt_pipe_get_plane_type(data->pipe, DRM_PLANE_TYPE_PRIMARY);
> +
> +	igt_output_set_pipe(data->output, data->pipe_id);
> +
> +	data->w = data->mode->hdisplay;
> +	data->h = data->mode->vdisplay;
> +
> +	data->ref_fb.fb_id = 0;
> +
> +	igt_create_color_fb(data->drm_fd, data->mode->hdisplay,
> +		data->mode->vdisplay, DRM_FORMAT_XRGB8888, 0, 0.0, 0.6, 0.6, &data->ref_fb);
> +}
> +
> +/* Common test cleanup. */
> +static void test_fini(data_t *data)
> +{
> +	igt_display_t *display = &data->display;
> +
> +	igt_display_reset(display);
> +	igt_display_commit_atomic(display, DRM_MODE_ATOMIC_ALLOW_MODESET, 0);
> +
> +	if (data->ref_fb.fb_id)
> +		igt_remove_fb(data->drm_fd, &data->ref_fb);
> +}
>   
>   
>   static int read_current_backlight_pwm(int drm_fd, char *connector_name)
> @@ -121,14 +187,9 @@ static void set_abm_level(data_t *data, igt_output_t *output, int level)
>   
>   	igt_assert_eq(close(fd), 0);
>   
> -	/**
> -	 * We need to trigger a full modeset to have the new ABM level take effect.
> -	 * DPMS off -> on transition is one of many approaches.
> -	 */
> -	kmstest_set_connector_dpms(data->drm_fd, output->config.connector,
> -			 DRM_MODE_DPMS_OFF);
> -	kmstest_set_connector_dpms(data->drm_fd, output->config.connector,
> -			 DRM_MODE_DPMS_ON);
> +	igt_output_set_pipe(data->output, data->pipe_id);
> +	igt_plane_set_fb(data->primary, &data->ref_fb);
> +	igt_display_commit_atomic(&data->display, 0, 0);
>   }
>   
>   static int backlight_read_max_brightness(int *result)
> @@ -156,25 +217,6 @@ static int backlight_read_max_brightness(int *result)
>   	return errno;
>   }
>   
> -static void test_init(data_t *data)
> -{
> -	igt_display_t *display = &data->display;
> -	drmModeConnectorPtr conn;
> -	int i;
> -
> -	for (i = 0; i < display->n_outputs; i++) {
> -		conn = display->outputs[i].config.connector;
> -
> -		if (conn->connector_type == DRM_MODE_CONNECTOR_eDP &&
> -		    conn->connection == DRM_MODE_CONNECTED) {
> -			return;
> -		}
> -	}
> -
> -	igt_skip("No eDP connector found\n");
> -}
> -
> -
>   static void backlight_dpms_cycle(data_t *data)
>   {
>   	int ret;
> @@ -354,7 +396,7 @@ static void abm_gradual(data_t *data)
>   
>   igt_main
>   {
> -	data_t data = {};
> +	data_t data = {0};
>   	igt_skip_on_simulation();
>   
>   	igt_fixture {
> @@ -382,6 +424,7 @@ igt_main
>   		abm_gradual(&data);
>   
>   	igt_fixture {
> +		test_fini(&data);
>   		igt_display_fini(&data.display);
>   		drm_close_driver(data.drm_fd);
>   	}


More information about the igt-dev mailing list