All of lore.kernel.org
 help / color / mirror / Atom feed
From: Mika Kahola <mika.kahola@intel.com>
To: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>,
	intel-gfx@lists.freedesktop.org
Subject: Re: [PATCH i-g-t v2 09/14] lib/igt_kms: Add igt_$obj_get_prop functions
Date: Thu, 19 Oct 2017 15:58:39 +0300	[thread overview]
Message-ID: <1508417919.3274.132.camel@intel.com> (raw)
In-Reply-To: <20171012115435.18880-10-maarten.lankhorst@linux.intel.com>

Reviewed-by: Mika Kahola <mika.kahola@intel.com>

On Thu, 2017-10-12 at 13:54 +0200, Maarten Lankhorst wrote:
> Some tests need to get the current kernel value for properties
> as part of the test. Add get_prop functions that will retrieve
> the current kernel value.
> 
> Signed-off-by: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
> ---
>  lib/igt_kms.c | 81
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  lib/igt_kms.h | 24 ++++++++++++++++++
>  2 files changed, 105 insertions(+)
> 
> diff --git a/lib/igt_kms.c b/lib/igt_kms.c
> index 339c11843154..176e6825a492 100644
> --- a/lib/igt_kms.c
> +++ b/lib/igt_kms.c
> @@ -2407,6 +2407,51 @@ static int igt_output_commit(igt_output_t
> *output,
>  	return 0;
>  }
>  
> +static uint64_t igt_mode_object_get_prop(igt_display_t *display,
> +					 uint32_t object_type,
> +					 uint32_t object_id,
> +					 uint32_t prop)
> +{
> +	drmModeObjectPropertiesPtr proplist;
> +	bool found = false;
> +	int i;
> +	uint64_t ret;
> +
> +	proplist = drmModeObjectGetProperties(display->drm_fd,
> object_id, object_type);
> +	for (i = 0; i < proplist->count_props; i++) {
> +		if (proplist->props[i] != prop)
> +			continue;
> +
> +		found = true;
> +		break;
> +	}
> +
> +	igt_assert(found);
> +
> +	ret = proplist->prop_values[i];
> +
> +	drmModeFreeObjectProperties(proplist);
> +	return ret;
> +}
> +
> +/**
> + * igt_plane_get_prop - Return current value on a plane for a given
> property.
> + *
> + * @plane: Target plane.
> + * @prop: Property to check.
> + *
> + * Returns: The value the property is set to, if this
> + * is a blob, the blob id is returned. This can be passed
> + * to drmModeGetPropertyBlob() to get the contents of the blob.
> + */
> +uint64_t igt_plane_get_prop(igt_plane_t *plane, enum
> igt_atomic_plane_properties prop)
> +{
> +	igt_assert(igt_plane_has_prop(plane, prop));
> +
> +	return igt_mode_object_get_prop(plane->pipe->display,
> DRM_MODE_OBJECT_PLANE,
> +					plane->drm_plane->plane_id,
> plane->props[prop]);
> +}
> +
>  /**
>   * igt_plane_replace_prop_blob:
>   * @plane: plane to set property on.
> @@ -2439,6 +2484,24 @@ igt_plane_replace_prop_blob(igt_plane_t
> *plane, enum igt_atomic_plane_properties
>  	igt_plane_set_prop_changed(plane, prop);
>  }
>  
> +/**
> + * igt_output_get_prop - Return current value on an output for a
> given property.
> + *
> + * @output: Target output.
> + * @prop: Property to return.
> + *
> + * Returns: The value the property is set to, if this
> + * is a blob, the blob id is returned. This can be passed
> + * to drmModeGetPropertyBlob() to get the contents of the blob.
> + */
> +uint64_t igt_output_get_prop(igt_output_t *output, enum
> igt_atomic_connector_properties prop)
> +{
> +	igt_assert(igt_output_has_prop(output, prop));
> +
> +	return igt_mode_object_get_prop(output->display,
> DRM_MODE_OBJECT_CONNECTOR,
> +					output->id, output-
> >props[prop]);
> +}
> +
>  /**
>   * igt_output_replace_prop_blob:
>   * @output: output to set property on.
> @@ -2471,6 +2534,24 @@ igt_output_replace_prop_blob(igt_output_t
> *output, enum igt_atomic_connector_pro
>  	igt_output_set_prop_changed(output, prop);
>  }
>  
> +/**
> + * igt_pipe_obj_get_prop - Return current value on a pipe for a
> given property.
> + *
> + * @pipe: Target pipe.
> + * @prop: Property to return.
> + *
> + * Returns: The value the property is set to, if this
> + * is a blob, the blob id is returned. This can be passed
> + * to drmModeGetPropertyBlob() to get the contents of the blob.
> + */
> +uint64_t igt_pipe_obj_get_prop(igt_pipe_t *pipe, enum
> igt_atomic_crtc_properties prop)
> +{
> +	igt_assert(igt_pipe_obj_has_prop(pipe, prop));
> +
> +	return igt_mode_object_get_prop(pipe->display,
> DRM_MODE_OBJECT_CRTC,
> +					pipe->crtc_id, pipe-
> >props[prop]);
> +}
> +
>  /**
>   * igt_pipe_obj_replace_prop_blob:
>   * @pipe: pipe to set property on.
> diff --git a/lib/igt_kms.h b/lib/igt_kms.h
> index 916cd359519a..fda94cb640de 100644
> --- a/lib/igt_kms.h
> +++ b/lib/igt_kms.h
> @@ -503,6 +503,8 @@ igt_plane_has_prop(igt_plane_t *plane, enum
> igt_atomic_plane_properties prop)
>  	return plane->props[prop];
>  }
>  
> +uint64_t igt_plane_get_prop(igt_plane_t *plane, enum
> igt_atomic_plane_properties prop);
> +
>  #define igt_plane_is_prop_changed(plane, prop) \
>  	(!!((plane)->changed & (1 << (prop))))
>  
> @@ -536,6 +538,8 @@ igt_output_has_prop(igt_output_t *output, enum
> igt_atomic_connector_properties p
>  	return output->props[prop];
>  }
>  
> +uint64_t igt_output_get_prop(igt_output_t *output, enum
> igt_atomic_connector_properties prop);
> +
>  #define igt_output_is_prop_changed(output, prop) \
>  	(!!((output)->changed & (1 << (prop))))
>  #define igt_output_set_prop_changed(output, prop) \
> @@ -568,6 +572,26 @@ igt_pipe_obj_has_prop(igt_pipe_t *pipe, enum
> igt_atomic_crtc_properties prop)
>  	return pipe->props[prop];
>  }
>  
> +uint64_t igt_pipe_obj_get_prop(igt_pipe_t *pipe, enum
> igt_atomic_crtc_properties prop);
> +
> +/**
> + * igt_pipe_get_prop - Return current value on a pipe for a given
> property.
> + *
> + * @display: Pointer to display.
> + * @pipe: Target pipe.
> + * @prop: Property to return.
> + *
> + * Returns: The value the property is set to, if this
> + * is a blob, the blob id is returned. This can be passed
> + * to drmModeGetPropertyBlob() to get the contents of the blob.
> + */
> +static inline uint64_t
> +igt_pipe_get_prop(igt_display_t *display, enum pipe pipe,
> +		  enum igt_atomic_crtc_properties prop)
> +{
> +	return igt_pipe_obj_get_prop(&display->pipes[pipe], prop);
> +}
> +
>  /**
>   * igt_pipe_has_prop - Check whether pipe supports a given property.
>   *
-- 
Mika Kahola - Intel OTC

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

  reply	other threads:[~2017-10-19 12:56 UTC|newest]

Thread overview: 45+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-10-12 11:54 [PATCH i-g-t v2 00/14] lib/igt_kms: Rewrite property handling to better match atomic Maarten Lankhorst
2017-10-12 11:54 ` [PATCH i-g-t v2 01/14] lib/igt_kms: Rework connector properties to be more atomic, v2 Maarten Lankhorst
2017-10-12 11:54 ` [PATCH i-g-t v2 02/14] lib/igt_kms: Rework plane properties to be more atomic, v5 Maarten Lankhorst
2017-10-19  9:08   ` Mika Kahola
2017-10-19  9:44     ` Maarten Lankhorst
2017-10-20  8:03       ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 03/14] lib/igt_kms: Rework pipe properties to be more atomic, v7 Maarten Lankhorst
2017-10-19 10:28   ` Mika Kahola
2018-03-05 14:37   ` Maxime Ripard
2018-03-05 14:37     ` [igt-dev] [Intel-gfx] " Maxime Ripard
2018-03-06 13:41     ` Daniel Vetter
2018-03-06 13:41       ` [igt-dev] [Intel-gfx] " Daniel Vetter
2018-03-06 13:47       ` Maarten Lankhorst
2018-03-06 13:47         ` [Intel-gfx] " Maarten Lankhorst
2017-10-12 11:54 ` [PATCH i-g-t v2 04/14] lib/igt_kms: Allow setting any plane property through the universal path Maarten Lankhorst
2017-10-19 11:04   ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 05/14] lib/igt_kms: Allow setting any output property through the !atomic paths Maarten Lankhorst
2017-10-20  9:38   ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 06/14] lib/igt_kms: Export property blob functions for output/pipe/plane, v2 Maarten Lankhorst
2017-10-19 11:24   ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 07/14] lib/igt_kms: Unexport broadcast rgb API Maarten Lankhorst
2017-10-19 11:28   ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 08/14] lib/igt_kms: Add igt_$obj_has_prop functions Maarten Lankhorst
2017-10-12 15:33   ` [PATCH i-g-t v2] lib/igt_kms: Add igt_$obj_has_prop functions, v2 Maarten Lankhorst
2017-10-19 12:06     ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 09/14] lib/igt_kms: Add igt_$obj_get_prop functions Maarten Lankhorst
2017-10-19 12:58   ` Mika Kahola [this message]
2017-10-12 11:54 ` [PATCH i-g-t v2 10/14] lib/igt_kms: Remove igt_pipe_get_property Maarten Lankhorst
2017-10-19 13:18   ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 11/14] lib/igt_kms: Remove igt_crtc_set_background() Maarten Lankhorst
2017-10-20  6:33   ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 12/14] tests/kms_color: Rework tests slightly to work better with new atomic api Maarten Lankhorst
2017-10-20  7:14   ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 13/14] tests/chamelium: Remove reliance on output->config.pipe Maarten Lankhorst
2017-10-20  7:15   ` Mika Kahola
2017-10-12 11:54 ` [PATCH i-g-t v2 14/14] tests/kms_atomic: Convert/rewrite tests to use igt_kms framework Maarten Lankhorst
2017-10-12 15:33   ` [PATCH i-g-t v2] tests/kms_atomic: Convert/rewrite tests to use igt_kms framework, v2 Maarten Lankhorst
2017-10-20 10:02     ` Mika Kahola
2017-10-20 10:08       ` Maarten Lankhorst
2017-10-20 10:16         ` Mika Kahola
2017-10-20 11:43           ` Maarten Lankhorst
2017-10-12 12:28 ` ✓ Fi.CI.BAT: success for lib/igt_kms: Rewrite property handling to better match atomic. (rev4) Patchwork
2017-10-12 15:01 ` ✗ Fi.CI.IGT: failure " Patchwork
2017-10-12 16:04 ` ✓ Fi.CI.BAT: success for lib/igt_kms: Rewrite property handling to better match atomic. (rev6) Patchwork
2017-10-12 23:47 ` ✗ Fi.CI.IGT: 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=1508417919.3274.132.camel@intel.com \
    --to=mika.kahola@intel.com \
    --cc=intel-gfx@lists.freedesktop.org \
    --cc=maarten.lankhorst@linux.intel.com \
    /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 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.