[Intel-gfx] [PATCH i-g-t 1/5] lib/igt_chamelium: Add support for HPD toggle scheduling

Lyude Paul lyude at redhat.com
Mon Jun 26 21:07:54 UTC 2017


This all looks great! I'm happy to see us finally getting rid of the
very hacky workaround I had to make async hotplugging work (to be fair,
it was only partly broken ;). Thanks for dealing with chameleond
upstream too, I couldn't stand how ugly the code in that thing is...

Anyway, this whole patchset looks good. The only thing I ask is that
you condense the patches a bit, mainly:

1-3 can all be one patch for adding real async HPD
4-5 can be another single patch for enabling VGA tests

On Mon, 2017-06-26 at 10:22 +0300, Paul Kocialkowski wrote:
> This adds support for the newly-introduced ScheduleHpdToggle XMLRPC
> method of the Chamelium's interface. It allows scheduling an HPD
> toggle,
> for which the call will return immediately.
> 
> This is especially useful for testing HPD during suspend/resume.
> 
> Signed-off-by: Paul Kocialkowski <paul.kocialkowski at linux.intel.com>
> ---
>  lib/igt_chamelium.c | 22 ++++++++++++++++++++++
>  lib/igt_chamelium.h |  3 +++
>  2 files changed, 25 insertions(+)
> 
> diff --git a/lib/igt_chamelium.c b/lib/igt_chamelium.c
> index 4a2af796..523cc853 100644
> --- a/lib/igt_chamelium.c
> +++ b/lib/igt_chamelium.c
> @@ -447,6 +447,28 @@ void chamelium_fire_mixed_hpd_pulses(struct
> chamelium *chamelium,
>  	xmlrpc_DECREF(pulse_widths);
>  }
>  
> +/**
> + * chamelium_schedule_hpd_toggle:
> + * @chamelium: The Chamelium instance to use
> + * @port: The port to fire the HPD pulses on
> + * @delay_ms: Delay in milli-second before the toggle takes place
> + * @rising_edge: Whether the toggle should be a rising edge or a
> falling edge
> + *
> + * Instructs the chamelium to schedule an hpd toggle (either a
> rising edge or
> + * a falling edge, depending on @rising_edg) after @delay_ms have
> passed.
> + * This is useful for testing things such as hpd after a
> suspend/resume cycle.
> + */
> +void chamelium_schedule_hpd_toggle(struct chamelium *chamelium,
> +				   struct chamelium_port *port, int
> delay_ms,
> +				   bool rising_edge)
> +{
> +	igt_debug("Scheduling HPD toggle on %s in %d ms\n", port-
> >name,
> +		  delay_ms);
> +
> +	xmlrpc_DECREF(chamelium_rpc(chamelium, NULL,
> "ScheduleHpdToggle",
> +				    "(iii)", port->id, delay_ms,
> rising_edge));
> +}
> +
>  static void async_rpc_handler(const char *server_url, const char
> *method_name,
>  			      xmlrpc_value *param_array, void
> *user_data,
>  			      xmlrpc_env *fault, xmlrpc_value
> *result)
> diff --git a/lib/igt_chamelium.h b/lib/igt_chamelium.h
> index 15f60246..408a4b85 100644
> --- a/lib/igt_chamelium.h
> +++ b/lib/igt_chamelium.h
> @@ -61,6 +61,9 @@ void chamelium_fire_mixed_hpd_pulses(struct
> chamelium *chamelium,
>  void chamelium_fire_hpd_pulses(struct chamelium *chamelium,
>  			       struct chamelium_port *port,
>  			       int width_msec, int count);
> +void chamelium_schedule_hpd_toggle(struct chamelium *chamelium,
> +				   struct chamelium_port *port, int
> delay_ms,
> +				   bool rising_edge);
>  void chamelium_async_hpd_pulse_start(struct chamelium *chamelium,
>  				     struct chamelium_port *port,
>  				     bool high, int delay_secs);


More information about the Intel-gfx mailing list