Re: [bug report] drm/ingenic: Add support for the IPU

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Dan,

Le lun. 20 juil. 2020 à 10:22, dan.carpenter@xxxxxxxxxx a écrit :
Hello Paul Cercueil,

The patch fc1acf317b01: "drm/ingenic: Add support for the IPU" from
Jul 16, 2020, leads to the following static checker warning:

drivers/gpu/drm/ingenic/ingenic-drm-drv.c:232 ingenic_drm_crtc_atomic_check()
	error: potentially dereferencing uninitialized 'ipu_state'.

I fixed it yesterday, commit 40a55dc13e9d in drm-misc-next.

drivers/gpu/drm/ingenic/ingenic-drm-drv.c
197 static int ingenic_drm_crtc_atomic_check(struct drm_crtc *crtc, 198 struct drm_crtc_state *state)
   199  {
   200          struct ingenic_drm *priv = drm_crtc_get_priv(crtc);
201 struct drm_plane_state *f1_state, *f0_state, *ipu_state;
   202          long rate;
   203
   204          if (!drm_atomic_crtc_needs_modeset(state))
   205                  return 0;
   206
207 if (state->mode.hdisplay > priv->soc_info->max_width ||
   208              state->mode.vdisplay > priv->soc_info->max_height)
   209                  return -EINVAL;
   210
   211          rate = clk_round_rate(priv->pix_clk,
212 state->adjusted_mode.clock * 1000);
   213          if (rate < 0)
   214                  return rate;
   215
   216          if (priv->soc_info->has_osd) {
217 f1_state = drm_atomic_get_plane_state(state->state, &priv->f1); 218 f0_state = drm_atomic_get_plane_state(state->state, &priv->f0);
   219
220 if (IS_ENABLED(CONFIG_DRM_INGENIC_IPU) && priv->ipu_plane) {

Do we need to check both the CONFIG and the priv->ipu_plane or would it
be sufficient to just check if (priv->ipu_plane) {?

It would be enough, yes.

Cheers,
-Paul

221 ipu_state = drm_atomic_get_plane_state(state->state, priv->ipu_plane);
   222
223 /* IPU and F1 planes cannot be enabled at the same time. */
   224                          if (f1_state->fb && ipu_state->fb) {
225 dev_dbg(priv->dev, "Cannot enable both F1 and IPU\n");
   226                                  return -EINVAL;
   227                          }
   228                  }
   229
230 /* If all the planes are disabled, we won't get a VBLANK IRQ */ 231 priv->no_vblank = !f1_state->fb && !f0_state->fb && 232 !(priv->ipu_plane && ipu_state->fb);
                                            ^^^^^^^^^^^^^^^
Because here we're only checking "priv->ipu_plane".

   233          }
   234
   235          return 0;
   236  }

regards,
dan carpenter


_______________________________________________
dri-devel mailing list
dri-devel@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/dri-devel




[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux