[Intel-gfx] [PATCH] drm/i915: Avoid divide by zero

Kahola, Mika mika.kahola at intel.com
Wed Jan 23 07:21:57 UTC 2019


On Tue, 2019-01-22 at 21:09 +0200, Ville Syrjälä wrote:
> On Tue, Jan 22, 2019 at 08:09:40PM +0200, Jani Nikula wrote:
> > On Tue, 22 Jan 2019, Ville Syrjälä <ville.syrjala at linux.intel.com>
> > wrote:
> > > On Tue, Jan 22, 2019 at 02:58:24PM +0200, Mika Kahola wrote:
> > > > Avoid divide by zero warning on static analysis.
> > > > 
> > > > Signed-off-by: Mika Kahola <mika.kahola at intel.com>
> > > > ---
> > > >  drivers/gpu/drm/i915/intel_pm.c | 6 ++++--
> > > >  1 file changed, 4 insertions(+), 2 deletions(-)
> > > > 
> > > > diff --git a/drivers/gpu/drm/i915/intel_pm.c
> > > > b/drivers/gpu/drm/i915/intel_pm.c
> > > > index 8b63afa3a221..6a8e8b3f44c2 100644
> > > > --- a/drivers/gpu/drm/i915/intel_pm.c
> > > > +++ b/drivers/gpu/drm/i915/intel_pm.c
> > > > @@ -3912,8 +3912,10 @@
> > > > skl_ddb_get_pipe_allocation_limits(struct drm_i915_private
> > > > *dev_priv,
> > > >  			pipe_width = hdisplay;
> > > >  	}
> > > >  
> > > > -	alloc->start = ddb_size * width_before_pipe /
> > > > total_width;
> > > > -	alloc->end = ddb_size * (width_before_pipe +
> > > > pipe_width) / total_width;
> > > > +	alloc->start = total_width == 0 ?
> > > > +		0 : ddb_size * width_before_pipe / total_width;
> > > > +	alloc->end = total_width == 0 ?
> > > > +		0 : ddb_size * (width_before_pipe + pipe_width)
> > > > / total_width;
> > > 
> > > Can't happen.
I'd say it's very unlikely to happen but in theory possible. If we
don't have any crtc_state enabled we end up having total_width = 0. In
this case it probably won't matter what numbers we end up with alloc-
>start and alloc->end.

Anyway, this was something that caught my eye while looking into crc
mismatch errors and static checker results.

Like Jani said, warn is sufficient with this case.

Cheers,
Mika

> > 
> > Yeah, it's about stfu the checker...
> 
> Feels like the tip of an iceberg. How many more uglies are we going
> to
> have to add?
> 
> > 
> > > 
> > > >  }
> > > >  
> > > >  static unsigned int skl_cursor_allocation(int num_active)
> > > > -- 
> > > > 2.17.1
> > > > 
> > > > _______________________________________________
> > > > Intel-gfx mailing list
> > > > Intel-gfx at lists.freedesktop.org
> > > > https://lists.freedesktop.org/mailman/listinfo/intel-gfx
> > 
> > -- 
> > Jani Nikula, Intel Open Source Graphics Center
> 
> 


More information about the Intel-gfx mailing list