[PATCH 8/9] drm: rcar-du: Skip encoder allocation for LVDS1 in dual-link mode
Laurent Pinchart
laurent.pinchart at ideasonboard.com
Mon Dec 14 13:32:12 UTC 2020
Hi Jacopo,
On Mon, Dec 14, 2020 at 12:04:49PM +0100, Jacopo Mondi wrote:
> On Sat, Dec 05, 2020 at 12:01:38AM +0200, Laurent Pinchart wrote:
> > The rcar-du driver skips registration of the encoder for the LVDS1
> > output when LVDS is used in dual-link mode, as the LVDS0 and LVDS1 links
> > are bundled and handled through the LVDS0 output. It however still
> > allocates the encoder and immediately destroys it, which is pointless.
> > Skip allocation of the encoder altogether in that case.
> >
> > Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas at ideasonboard.com>
> > ---
> > drivers/gpu/drm/rcar-du/rcar_du_encoder.c | 51 ++++++++++-------------
> > 1 file changed, 22 insertions(+), 29 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/rcar-du/rcar_du_encoder.c b/drivers/gpu/drm/rcar-du/rcar_du_encoder.c
> > index e4f35a88d00f..49c0b27e2f5a 100644
> > --- a/drivers/gpu/drm/rcar-du/rcar_du_encoder.c
> > +++ b/drivers/gpu/drm/rcar-du/rcar_du_encoder.c
> > @@ -65,17 +65,6 @@ int rcar_du_encoder_init(struct rcar_du_device *rcdu,
> > struct drm_bridge *bridge;
> > int ret;
> >
> > - renc = kzalloc(sizeof(*renc), GFP_KERNEL);
> > - if (renc == NULL)
> > - return -ENOMEM;
> > -
> > - rcdu->encoders[output] = renc;
> > - renc->output = output;
> > - encoder = rcar_encoder_to_drm_encoder(renc);
> > -
> > - dev_dbg(rcdu->dev, "initializing encoder %pOF for output %u\n",
> > - enc_node, output);
> > -
> > /*
> > * Locate the DRM bridge from the DT node. For the DPAD outputs, if the
> > * DT node has a single port, assume that it describes a panel and
> > @@ -86,23 +75,17 @@ int rcar_du_encoder_init(struct rcar_du_device *rcdu,
> > rcar_du_encoder_count_ports(enc_node) == 1) {
> > struct drm_panel *panel = of_drm_find_panel(enc_node);
> >
> > - if (IS_ERR(panel)) {
> > - ret = PTR_ERR(panel);
> > - goto error;
> > - }
> > + if (IS_ERR(panel))
> > + return PTR_ERR(panel);
> >
> > bridge = devm_drm_panel_bridge_add_typed(rcdu->dev, panel,
> > DRM_MODE_CONNECTOR_DPI);
> > - if (IS_ERR(bridge)) {
> > - ret = PTR_ERR(bridge);
> > - goto error;
> > - }
> > + if (IS_ERR(bridge))
> > + return PTR_ERR(bridge);
> > } else {
> > bridge = of_drm_find_bridge(enc_node);
> > - if (!bridge) {
> > - ret = -EPROBE_DEFER;
> > - goto error;
> > - }
> > + if (!bridge)
> > + return -EPROBE_DEFER;
> >
> > if (output == RCAR_DU_OUTPUT_LVDS0 ||
> > output == RCAR_DU_OUTPUT_LVDS1)
> > @@ -110,16 +93,26 @@ int rcar_du_encoder_init(struct rcar_du_device *rcdu,
> > }
> >
> > /*
> > - * On Gen3 skip the LVDS1 output if the LVDS1 encoder is used as a
> > - * companion for LVDS0 in dual-link mode.
> > + * Create and initialize the encoder. On Gen3 skip the LVDS1 output if
> > + * the LVDS1 encoder is used as a companion for LVDS0 in dual-link
> > + * mode.
>
> Oh, here's the answer to my question on 1/9, I should have not looked
> at DTS but to the driver
>
> > */
> > if (rcdu->info->gen >= 3 && output == RCAR_DU_OUTPUT_LVDS1) {
> > - if (rcar_lvds_dual_link(bridge)) {
> > - ret = -ENOLINK;
> > - goto error;
> > - }
> > + if (rcar_lvds_dual_link(bridge))
> > + return -ENOLINK;
> > }
> >
> > + renc = kzalloc(sizeof(*renc), GFP_KERNEL);
> > + if (renc == NULL)
> > + return -ENOMEM;
> > +
> > + rcdu->encoders[output] = renc;
> > + renc->output = output;
> > + encoder = rcar_encoder_to_drm_encoder(renc);
> > +
> > + dev_dbg(rcdu->dev, "initializing encoder %pOF for output %u\n",
> > + enc_node, output);
> > +
> > ret = drm_encoder_init(&rcdu->ddev, encoder, &rcar_du_encoder_funcs,
> > DRM_MODE_ENCODER_NONE, NULL);
> > if (ret < 0)
>
> Do you have any other caller of the 'done:' label left apart from the
> one after this last line ? In case you don't you can call devm_kfree()
> here
That would be kfree(), not devm_kfree(). I'll do so.
> With or without this addressed:
> Reviewed-by: Jacopo Mondi <jacopo+renesas at jmondi.org>
--
Regards,
Laurent Pinchart
More information about the dri-devel
mailing list