[igt-dev] [PATCH i-g-t 15/17] tests/kms_dp_dsc: Use helper functions to read/write dsc debugfs

Petri Latvala petri.latvala at intel.com
Tue Jun 15 09:15:09 UTC 2021


On Fri, Jun 11, 2021 at 10:50:03AM +0530, venkata.sai.patnana at intel.com wrote:
> From: Ankit Nautiyal <ankit.k.nautiyal at intel.com>
> 
> Remove funtions for reading different dsc parameters from dsc debugfs.
> Use the helper functions for reading and writing dsc debugfs.
> 
> Cc: Petri Latvala <petri.latvala at intel.com> (v3)
> Signed-off-by: Ankit Nautiyal <ankit.k.nautiyal at intel.com>

Reviewed-by: Petri Latvala <petri.latvala at intel.com>


> ---
>  tests/kms_dp_dsc.c | 87 ++++++++--------------------------------------
>  1 file changed, 15 insertions(+), 72 deletions(-)
> 
> diff --git a/tests/kms_dp_dsc.c b/tests/kms_dp_dsc.c
> index eecb9e45da..f87112e6e7 100644
> --- a/tests/kms_dp_dsc.c
> +++ b/tests/kms_dp_dsc.c
> @@ -55,7 +55,6 @@ enum dsc_test_type
>  
>  typedef struct {
>  	int drm_fd;
> -	int debugfs_fd;
>  	uint32_t devid;
>  	igt_display_t display;
>  	struct igt_fb fb_test_pattern;
> @@ -77,91 +76,36 @@ static inline void manual(const char *expected)
>  	igt_debug_manual_check("all", expected);
>  }
>  
> -static bool is_dp_dsc_supported(data_t *data)
> -{
> -	char file_name[128] = {0};
> -	char buf[512];
> -
> -	strcpy(file_name, data->conn_name);
> -	strcat(file_name, "/i915_dsc_fec_support");
> -	igt_debugfs_read(data->drm_fd, file_name, buf);
> -
> -	return strstr(buf, "DSC_Sink_Support: yes");
> -}
> -
> -static bool is_dp_fec_supported(data_t *data)
> -{
> -	char file_name[128] = {0};
> -	char buf[512];
> -
> -	strcpy(file_name, data->conn_name);
> -	strcat(file_name, "/i915_dsc_fec_support");
> -	igt_debugfs_read(data->drm_fd, file_name, buf);
> -
> -	return strstr(buf, "FEC_Sink_Support: yes");
> -}
> -
> -static bool is_dp_dsc_enabled(data_t *data)
> -{
> -	char file_name[128] = {0};
> -	char buf[512];
> -
> -	strcpy(file_name, data->conn_name);
> -	strcat(file_name, "/i915_dsc_fec_support");
> -	igt_debugfs_read(data->drm_fd, file_name, buf);
> -
> -	return strstr(buf, "DSC_Enabled: yes");
> -}
> -
>  static void force_dp_dsc_enable(data_t *data)
>  {
> -	char file_name[128] = {0};
>  	int ret;
>  
> -	strcpy(file_name, data->conn_name);
> -	strcat(file_name, "/i915_dsc_fec_support");
>  	igt_debug ("Forcing DSC enable on %s\n", data->conn_name);
> -	ret = igt_sysfs_write(data->debugfs_fd, file_name, "1", 1);
> +	ret = igt_force_dp_dsc_enable(data->drm_fd,
> +				      data->output->config.connector);
>  	igt_assert_f(ret > 0, "debugfs_write failed");
>  }
>  
>  static void force_dp_dsc_enable_bpp(data_t *data)
>  {
>  	int ret;
> -	char file_name[128] = {0};
> -	char buffer[20];
>  
> -	sprintf(buffer, "%d", data->compression_bpp);
> -	strcpy(file_name, data->conn_name);
> -	strcat(file_name, "/i915_dsc_bpp_support");
>  	igt_debug("Forcing DSC BPP to %d on %s\n",
>  		  data->compression_bpp, data->conn_name);
> -	ret = igt_sysfs_write(data->debugfs_fd, file_name,
> -			      buffer, sizeof(buffer));
> +	ret = igt_force_dp_dsc_enable_bpp(data->drm_fd,
> +					  data->output->config.connector,
> +					  data->compression_bpp);
>  	igt_assert_f(ret > 0, "debugfs_write failed");
>  }
>  
> -static bool is_force_dsc_enabled(data_t *data)
> -{
> -	char file_name[128] = {0};
> -	char buf[512];
> -
> -	strcpy(file_name, data->conn_name);
> -	strcat(file_name, "/i915_dsc_fec_support");
> -	igt_debugfs_read(data->drm_fd, file_name, buf);
> -
> -	return strstr(buf, "Force_DSC_Enable: yes");
> -}
> -
>  static void save_force_dsc_en(data_t *data)
>  {
> -	char file_name[128] = {0};
> -
> -	force_dsc_en_orig = is_force_dsc_enabled(data);
> -	strcpy(file_name, data->conn_name);
> -	strcat(file_name, "/i915_dsc_fec_support");
> -	force_dsc_restore_fd = openat(igt_debugfs_dir(data->drm_fd),
> -				      file_name, O_WRONLY);
> +	force_dsc_en_orig =
> +		igt_is_force_dsc_enabled(data->drm_fd,
> +					 data->output->config.connector);
> +	force_dsc_restore_fd =
> +		igt_get_dp_dsc_debugfs_fd(data->drm_fd,
> +					  data->output->config.connector);
>  	igt_assert(force_dsc_restore_fd >= 0);
>  }
>  
> @@ -211,13 +155,13 @@ static bool check_dsc_on_connector(data_t *data, uint32_t drmConnector)
>  		kmstest_connector_type_str(connector->connector_type),
>  		connector->connector_type_id);
>  
> -	if (!is_dp_dsc_supported(data)) {
> +	if (!igt_is_dp_dsc_supported(data->drm_fd, connector)) {
>  		igt_debug("DSC not supported on connector %s\n",
>  			  data->conn_name);
>  		return false;
>  	}
>  	if (connector->connector_type == DRM_MODE_CONNECTOR_DisplayPort &&
> -	    !is_dp_fec_supported(data)) {
> +	    !igt_is_dp_fec_supported(data->drm_fd, connector)) {
>  		igt_debug("DSC cannot be enabled without FEC on %s\n",
>  			  data->conn_name);
>  		return false;
> @@ -263,7 +207,8 @@ static void update_display(data_t *data, enum dsc_test_type test_type)
>  	 */
>  	manual("RGB test pattern without corruption");
>  
> -	enabled = is_dp_dsc_enabled(data);
> +	enabled = igt_is_dp_dsc_enabled(data->drm_fd,
> +					data->output->config.connector);
>  	restore_force_dsc_en();
>  
>  	igt_assert_f(enabled,
> @@ -320,7 +265,6 @@ igt_main
>  		data.drm_fd = drm_open_driver_master(DRIVER_ANY);
>  		igt_require_intel(data.drm_fd);
>  		data.devid = intel_get_drm_devid(data.drm_fd);
> -		data.debugfs_fd = igt_debugfs_dir(data.drm_fd);
>  		kmstest_set_vt_graphics_mode();
>  		igt_install_exit_handler(kms_dp_dsc_exit_handler);
>  		igt_display_require(&data.display, data.drm_fd);
> @@ -356,7 +300,6 @@ igt_main
>  		test_cleanup(&data);
>  		drmModeFreeConnector(connector);
>  		drmModeFreeResources(res);
> -		close(data.debugfs_fd);
>  		close(data.drm_fd);
>  		igt_display_fini(&data.display);
>  	}
> -- 
> 2.25.1
> 


More information about the igt-dev mailing list