Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp689480pxb; Wed, 22 Sep 2021 10:35:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyJZhYE1yOfCU+HM7H+bOuIjchLCKFDK0W1ZJ69FYO67gRRwGYqlhbFley4eaOWNerkmFdb X-Received: by 2002:a50:cf08:: with SMTP id c8mr569788edk.86.1632332100354; Wed, 22 Sep 2021 10:35:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632332100; cv=none; d=google.com; s=arc-20160816; b=zBiuntJxwfjsudTLlMmDCtt4TiHvuSIv8e3aGtc6RQ4+LNmqQoqDP6YMo8JzYlRHks tsNCSlP5eHXfYabXjqvmGJAOZ1+SbMl7D8pg7HRcDyCiZG5qFF8oZS1zm7NQ1e2EcdYW dwso2GGHjx+75OoJdUz9eLJz6G8VnjlF08BZ0yPx3aCSjhDTGYiVYXrA3LJshW1AOIgq FiGsGayistlqTorb3AAciRaJP8Dd85B2PVrzEALs4GcQlKV+9veSM2QLTMadgGYsVo7T riNk1UbYDxai78C3yiur+Knp9q81UM+68Gra1B99wDQMJjmZukA9WGu4giqO5LCjvfsR XJgA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=q6yz4Rj2Yb85SboOfaCfWVjp3ckXrv2v2xvRSlhbhS4=; b=Mv6/E0H4fvPq57k6KRHef665gt+M77r/vq9MFLWf5zJDVdg+Vxk885NXJieJqGrH/w l+wveraF+oJlbwgtgbiml1V92whoeHRZQZtLpta6J1JBYN7upraver8jfMfqjundYFLt IYrWMiPdjRcwlcYqDVnzX3PdrdHfpIgfupV1gfOxBPnA62w6osgl7YsUbvJgfISu4L2U OBvL3Fj/lZV1Pw2FVNQc50/hjf+FaWFHYymfHHmAyy4EjiA1tfnsvx+FKDnFBRYWQthM tlkeRrRsYgv819HAXtY/qy+VEDhl9ZmwYPl26TiAlIJbmeMFITtBkNQMA1YYQQxxmwAz YXgg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=oCKd9Kb2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id yd27si3505658ejb.451.2021.09.22.10.34.35; Wed, 22 Sep 2021 10:35:00 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=oCKd9Kb2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236781AbhIVRdU (ORCPT + 99 others); Wed, 22 Sep 2021 13:33:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43730 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236717AbhIVRdT (ORCPT ); Wed, 22 Sep 2021 13:33:19 -0400 Received: from mail-wr1-x42c.google.com (mail-wr1-x42c.google.com [IPv6:2a00:1450:4864:20::42c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7A2FBC061574; Wed, 22 Sep 2021 10:31:49 -0700 (PDT) Received: by mail-wr1-x42c.google.com with SMTP id t18so9274163wrb.0; Wed, 22 Sep 2021 10:31:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=q6yz4Rj2Yb85SboOfaCfWVjp3ckXrv2v2xvRSlhbhS4=; b=oCKd9Kb2l0T6kb81SffKU7Phf2iYRvRnxIT9JH9nYrk325y43X37E+7vvs+57M5SEJ AoUtGfuLNT/8cwHrOJoNZdAPm2/Ki7Ssz0myeaw/ks593qoTVcuzK9OXXt8pMihLGxcF 7jEHPqzBVGOgzXSqV/ON5cWqaJqch7QKj9vHzJDIYngQA38DV78aaVLGeyIA1P5Q8XAR ZXiKKjSdMsJvhnp9V0M+NVTlf8Hfrfddq018WwJL3w3f5d+iXqYH4pOk/TJJXQRXvzYs xC9237Rw2w4GSK7BHToMVnl/BImKOuDposDftkN9+BujcUM0ENqNBrINAOQ2QmzaiYiS K/6Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=q6yz4Rj2Yb85SboOfaCfWVjp3ckXrv2v2xvRSlhbhS4=; b=TR8/wkX9Hnschj8DkQCEENA2KekpGZGfMgumqAGiIeU94ier5y2eh3qPrEx7DgqEmw GlTmxSLn4RD6rdhy1k72AGGaHjhBKg86yD/s0lp8WGZlkPwl1kUsafydyhbzITcqIiL5 DCMbBmTO1NkZg1Sek+tfJZ0NwOnH5f6VtktzlmIXv1RkVgR2WiiDeDdAUUe36YOykhCd hP6fqpDHxLDVwSFxN16lngxRv9Xk/5CZl5U5Jt8E/a+BWMAx5Sqbi8ylRdbHYBU6QBXn nhTorhd2hg8vXc1uyFvJKEx2W/WO6nTfHOphdhy0G2/Rq4CxvsjqrstnZhIwrK3HT1Bm Z45g== X-Gm-Message-State: AOAM532Uv5+Nw537yUjKCLkgQppZx9mf3A4PhFxRWiIEXb8PP0vpbHH7 z7D8ri8Z3vaDDSjMt5hNMlZXFPhTRg== X-Received: by 2002:adf:f108:: with SMTP id r8mr195060wro.180.1632331908067; Wed, 22 Sep 2021 10:31:48 -0700 (PDT) Received: from [192.168.200.23] (ip5b434083.dynamic.kabel-deutschland.de. [91.67.64.131]) by smtp.gmail.com with ESMTPSA id q3sm1492343wmc.25.2021.09.22.10.31.47 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 22 Sep 2021 10:31:47 -0700 (PDT) Subject: Re: [PATCH][next] drm/rockchip: Remove redundant assignment of pointer connector To: =?UTF-8?Q?Heiko_St=c3=bcbner?= , Colin King , Sandy Huang , David Airlie , Daniel Vetter , dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org Cc: kernel-janitors@vger.kernel.org, linux-kernel@vger.kernel.org References: <20210922112416.182134-1-colin.king@canonical.com> <27c79f7a-8e4c-fad8-c6cf-a89793f2e3c6@gmail.com> <22365175.EbdSka62eY@diego> From: Alex Bee Message-ID: <6d18a1a6-37e3-41f9-ddd1-1dae33864d23@gmail.com> Date: Wed, 22 Sep 2021 19:31:46 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 MIME-Version: 1.0 In-Reply-To: <22365175.EbdSka62eY@diego> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Heiko, Am 22.09.21 um 18:45 schrieb Heiko Stübner: > Hi Alex, > > Am Mittwoch, 22. September 2021, 18:35:38 CEST schrieb Alex Bee: >> Hi Colin, >> Am 22.09.21 um 13:24 schrieb Colin King: >>> From: Colin Ian King >>> >>> The pointer connector is being assigned a value that is never >>> read, it is being updated immediately afterwards. The assignment >>> is redundant and can be removed. >> The pointer to the connector is used in rockchip_rgb_fini for >> drm_connector_cleanup. >> It's pretty much the same for the encoder, btw. > I think the issue is more the two lines > > connector = &rgb->connector; > connector = drm_bridge_connector_init(rgb->drm_dev, encoder); > > hence the connector = &rgb->connector being overwritten immediately after > > Now that I look at it again, the whole approach looks strange. > drm_bridge_connector_init() creates the connector structure and > returns a pointer to it. Totally agreed. The main reason I was doing it that way, was the way it was done already in rockchip_lvds.c, where the connector was already existent in the struct rockchip_lvds (and was already used in the panel-case - all places where it is used accept pointers also, btw) and is *no* pointer - and is done already this very strange way. I wanted to re-use it for the bridge-case and didn't want to differ in coding in rockchip-rgb to much. The only reason I can think of, why it was done that way is, that we might need a pointer to a fully initialized struct drm_connector for some reason (drm_connector_cleanup ?), what we wouldn't have if have just a pointer and something goes wrong before drm_connector_init respectivly drm_bridge_connector_init. Alex > So the first line below sets the connector pointer to point to the > &rgb->connector element and the second line then set a completely > different address into it. > > So the connector element in rockchip_lvds and rockchip_rgb should actually > become a pointer itself to hold the connector element returned from > drm_bridge_connector_init() . > > > Heiko > >> Regards, >> >> Alex >>> Addresses-Coverity: ("Unused value") >>> Signed-off-by: Colin Ian King >>> --- >>> drivers/gpu/drm/rockchip/rockchip_rgb.c | 1 - >>> 1 file changed, 1 deletion(-) >>> >>> diff --git a/drivers/gpu/drm/rockchip/rockchip_rgb.c b/drivers/gpu/drm/rockchip/rockchip_rgb.c >>> index 09be9678f2bd..18fb84068a64 100644 >>> --- a/drivers/gpu/drm/rockchip/rockchip_rgb.c >>> +++ b/drivers/gpu/drm/rockchip/rockchip_rgb.c >>> @@ -150,7 +150,6 @@ struct rockchip_rgb *rockchip_rgb_init(struct device *dev, >>> if (ret) >>> goto err_free_encoder; >>> >>> - connector = &rgb->connector; >>> connector = drm_bridge_connector_init(rgb->drm_dev, encoder); >>> if (IS_ERR(connector)) { >>> DRM_DEV_ERROR(drm_dev->dev, >>> >> > > >