[Intel-gfx] [PATCH i-g-t] tests/kms_frontbuffer_tracking: Skip tests when PSR cannot be enabled
Pandiyan, Dhinakaran
dhinakaran.pandiyan at intel.com
Thu Oct 26 19:46:01 UTC 2017
On Thu, 2017-10-26 at 17:35 -0200, Paulo Zanoni wrote:
> Em Qui, 2017-10-26 às 12:32 -0700, Rodrigo Vivi escreveu:
> > On Thu, Oct 26, 2017 at 01:29:57PM +0000, Paulo Zanoni wrote:
> > > Em Qua, 2017-10-25 às 17:37 -0700, Dhinakaran Pandiyan escreveu:
> > > > The frontbuffer_tracking PSR tests fail if PSR cannot be
> > > > activated
> > > > when
> > > > there is sink support. But, there are several other requirements
> > > > related to
> > > > mode timings that have to be satisfied before PSR can be enabled.
> > > > No
> > > > reason
> > > > to fail these tests when PSR cannot be enabled.
> > > >
> > > > Cc: Paulo Zanoni <paulo.r.zanoni at intel.com>
> > > > Cc: Rodrigo Vivi <rodrigo.vivi at intel.com>
> > > > Signed-off-by: Dhinakaran Pandiyan <dhinakaran.pandiyan at intel.com
> > > > >
> > > > ---
> > > > tests/kms_frontbuffer_tracking.c | 8 ++++----
> > > > 1 file changed, 4 insertions(+), 4 deletions(-)
> > > >
> > > > diff --git a/tests/kms_frontbuffer_tracking.c
> > > > b/tests/kms_frontbuffer_tracking.c
> > > > index a068c8af..13c948de 100644
> > > > --- a/tests/kms_frontbuffer_tracking.c
> > > > +++ b/tests/kms_frontbuffer_tracking.c
> > > > @@ -1548,12 +1548,12 @@ static void teardown_fbc(void)
> > > > {
> > > > }
> > > >
> > > > -static bool psr_sink_has_support(void)
> > > > +static bool psr_has_support(void)
> > > > {
> > > > char buf[256];
> > > >
> > > > debugfs_read("i915_edp_psr_status", buf);
> > > > - return strstr(buf, "Sink_Support: yes\n");
> > > > + return strstr(buf, "Enabled: yes\n");
> > >
> > > What if PSR can be enabled but is just not enabled due to a bug?
My reasoning was psr.enabled will be true as long as intel_psr_enable()
is called. But, yeah there is a chance that intel_psr_enable() is not
called.
> >
> > then psr basic should be the one failing...
>
> But if we apply this patch we'll skip it instead of fail.
>
> >
> > >
> > > I suppose we could print on debugfs whether source+sink support
> > > equals
> > > yes.
> >
> > or maybe here instead of sink: yes or enable: yes
> > we could check
> > sink: yes && source: yes
> >
That's how I wrote this initially, but source_ok appears to be in the
wrong place in the driver, i.e., source_ok is set inside psr_enable()
and hence has the same effect as checking for enabled. Moving source_ok
= true inside psr_compute_config() and changing the IGT to test for
sink_support && source_ok will solve our problem.
> > if sink yes and source yes and psr is still disabled when we
> > expect that enabled than we have the bug paulo mentioned.
> >
> > >
> > > > }
> > > >
> > > > static void setup_psr(void)
> > > > @@ -1564,8 +1564,8 @@ static void setup_psr(void)
> > > > return;
> > > > }
> > > >
> > > > - if (!psr_sink_has_support()) {
> > > > - igt_info("Can't test PSR: not supported by
> > > > sink.\n");
> > > > + if (!psr_has_support()) {
> > > > + igt_info("Can't test PSR: not supported.\n");
> > > > return;
> > > > }
> > > > psr.can_test = true;
More information about the Intel-gfx
mailing list