Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp4370082pxb; Tue, 2 Nov 2021 08:37:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw6R9+MJMFq5qIH6e+7oyck/JiB4CN20oc2r2Ae4lzlGvooZb7xkl1CFJqD15ow1e7Ee8N4 X-Received: by 2002:a05:6402:55:: with SMTP id f21mr51826469edu.8.1635867454122; Tue, 02 Nov 2021 08:37:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635867454; cv=none; d=google.com; s=arc-20160816; b=meaW1xu/I7/FmWa9IuucdzYcPKwhD3Utvx0f5TxLqBYbS2aAJbnyR8ZtEbJgXdln2h 3oaRMlre5d+ZxEX61HlWpKzQVAM15c10S4X4f5z1YzwKBFz1ih/NQXwL1ckNZT/pu0I0 E0mDotKH0BANdEQqdxn3S5PioMXQjGt1IesMN+J7CBgSmmpZ+aW75asg6uSWa2DzNbGn vScMzrNlKkXMHYI14N5QF7p4rpVLd74Jpo07jshVFg/9bVouraoBH1Es2Jj5ZyeUBKno ed/hbWLW6xV/3xsstCw9qCZz9HptXxEIGGKrXu3v8CboMZAXgP15nqpwKD5G1h5uxwcp pMfQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature :dkim-signature; bh=GAofqbfPUokCWaAMbYDnlRK3LBSNmSEwo1+DLnUZQPA=; b=slyS5y8/IgEFYpHSTPkFhPLNmfKA4hoO+T2FyJxM1gk8aU8w4t/y4Mejl2vN53p6e0 V2KOra6sU3WBTx7gdv1kHfsbXBPrpoHtfN2rewsurEIjqdFIKqMCsNoJ7qTXSp4SHMN4 4WXBatrfzal0zWxaossV+9gV/iOjYoNWsQLzp5fXH+su9ZsvQWMjR0g3gABOY4U5eSh+ 7F+XRhV6mxW8cyuZPJTxe4XngEwW87RzoOK/B8HGXa6eorKZxIqslapcPJRvtHXPkTWY cVCvdXHSthMppBL0P+rbRr/HH6bjf0txKiIMGvDavvpZP+cd/beekbbKnmfs7kh8ffha /CCA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cerno.tech header.s=fm1 header.b=icIDIil8; dkim=pass header.i=@messagingengine.com header.s=fm1 header.b=lS0scAA9; 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=NONE dis=NONE) header.from=cerno.tech Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hv17si13488908ejc.360.2021.11.02.08.37.08; Tue, 02 Nov 2021 08:37:34 -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=@cerno.tech header.s=fm1 header.b=icIDIil8; dkim=pass header.i=@messagingengine.com header.s=fm1 header.b=lS0scAA9; 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=NONE dis=NONE) header.from=cerno.tech Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233841AbhKBPGK (ORCPT + 99 others); Tue, 2 Nov 2021 11:06:10 -0400 Received: from out2-smtp.messagingengine.com ([66.111.4.26]:36561 "EHLO out2-smtp.messagingengine.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233836AbhKBPGJ (ORCPT ); Tue, 2 Nov 2021 11:06:09 -0400 Received: from compute4.internal (compute4.nyi.internal [10.202.2.44]) by mailout.nyi.internal (Postfix) with ESMTP id 4D4095C011D; Tue, 2 Nov 2021 11:03:34 -0400 (EDT) Received: from mailfrontend1 ([10.202.2.162]) by compute4.internal (MEProxy); Tue, 02 Nov 2021 11:03:34 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cerno.tech; h= date:from:to:cc:subject:message-id:references:mime-version :content-type:in-reply-to; s=fm1; bh=GAofqbfPUokCWaAMbYDnlRK3LBS NmSEwo1+DLnUZQPA=; b=icIDIil8mCAEUKdAFEM7bbBKJM4c3tow+C1rVnwW+ad MUznoFGp9DBv7dGPibZgqbCm0Q0tey6/FvtxvGMTRKDKo83rf9G2yKhxNdlMfmt3 ok2BETvZfc6A/FXWa6HLmILlHq/2W0Ck38KgBOdvnRtyQqqCBsCdjlPMMDrLUlN7 TPUzShVSc2FtOhQABLAW/nG6CDrBSWD+zUDV7qS7QsKhJaLjtTsOky7z599t4nBN tzOxG1hwiy8jQtszA5drBNszSvA9817qpmRN5zGc/F9WFvj7hPNm1Mja00T9Qmdx PwF2Xw5SxETNMj8EsV57HNLhF+qICNKMGAt7pjXOjkA== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to:x-me-proxy :x-me-proxy:x-me-sender:x-me-sender:x-sasl-enc; s=fm1; bh=GAofqb fPUokCWaAMbYDnlRK3LBSNmSEwo1+DLnUZQPA=; b=lS0scAA9GuTPiuitbEC3dS qv4c6dADfSp8kKPWNRIHuE8oZuUWdIo6GylFAh7GPQ0zXHM35MDtWC8cyw6xfjOM D5+yvuEOr4r+xowlLSaL23J92PnfZKpdj1TkHj7FM0wJXjlbpqCsykl0M3ii8rnP OwIi08sSnJid0I0s4RAGF2pueZ517h5EQD+sMcxGjVxAZQwA3pdpPya5nXluxxNo 4xxkCQ5fLaREA7RfKJkCC8eK13Qhxi5/nImYPMxSxUHyxlvmBjlf+0eBfQwX97rY jZK0kMOquZ5OVO1hIGPffYkGO1dkiRR6VSHgUkwtySG+ZoFPtemUHHwf/xBowLeQ == X-ME-Sender: X-ME-Received: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedvuddrtddtgdeghecutefuodetggdotefrodftvf curfhrohhfihhlvgemucfhrghsthforghilhdpqfgfvfdpuffrtefokffrpgfnqfghnecu uegrihhlohhuthemuceftddtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmdenuc fjughrpeffhffvuffkfhggtggujgesghdtreertddtvdenucfhrhhomhepofgrgihimhgv ucftihhprghrugcuoehmrgigihhmvgestggvrhhnohdrthgvtghhqeenucggtffrrghtth gvrhhnpeelkeeghefhuddtleejgfeljeffheffgfeijefhgfeufefhtdevteegheeiheeg udenucevlhhushhtvghrufhiiigvpedtnecurfgrrhgrmhepmhgrihhlfhhrohhmpehmrg igihhmvgestggvrhhnohdrthgvtghh X-ME-Proxy: Received: by mail.messagingengine.com (Postfix) with ESMTPA; Tue, 2 Nov 2021 11:03:32 -0400 (EDT) Date: Tue, 2 Nov 2021 16:03:31 +0100 From: Maxime Ripard To: He Ying Cc: wens@csie.org, airlied@linux.ie, daniel@ffwll.ch, jernej.skrabec@gmail.com, dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, linux-sunxi@lists.linux.dev, linux-kernel@vger.kernel.org Subject: Re: [PATCH -V2] drm/sun4i: Grab reference of connector before return connector from sun4i_tcon_get_connector Message-ID: <20211102150331.526nn2e6oqjbf6ur@gilmour> References: <33e01d45-c9f9-0e8c-6871-868ecd198368@huawei.com> <20211102084628.149070-1-heying24@huawei.com> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha512; protocol="application/pgp-signature"; boundary="vw4qxeyln6gwbonp" Content-Disposition: inline In-Reply-To: <20211102084628.149070-1-heying24@huawei.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --vw4qxeyln6gwbonp Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable Hi, On Tue, Nov 02, 2021 at 04:46:28AM -0400, He Ying wrote: > From the comments of drm_for_each_connector_iter(), we know > that "connector is only valid within the list body, if you > want to use connector after calling drm_connector_list_iter_end() > then you need to grab your own reference first using > drm_connector_get()". So fix the wrong use of connector > according to the comments and then call drm_connector_put() > after using connector finishes. >=20 > Signed-off-by: He Ying > --- >=20 > V2: > Use proper subject prefix >=20 > drivers/gpu/drm/sun4i/sun4i_tcon.c | 18 +++++++++++++----- > 1 file changed, 13 insertions(+), 5 deletions(-) >=20 > diff --git a/drivers/gpu/drm/sun4i/sun4i_tcon.c b/drivers/gpu/drm/sun4i/s= un4i_tcon.c > index 9f06dec0fc61..24fa6784ee5f 100644 > --- a/drivers/gpu/drm/sun4i/sun4i_tcon.c > +++ b/drivers/gpu/drm/sun4i/sun4i_tcon.c > @@ -47,12 +47,12 @@ static struct drm_connector *sun4i_tcon_get_connector= (const struct drm_encoder * > drm_connector_list_iter_begin(encoder->dev, &iter); > drm_for_each_connector_iter(connector, &iter) > if (connector->encoder =3D=3D encoder) { > - drm_connector_list_iter_end(&iter); > - return connector; > + drm_connector_get(connector); > + break; > } > drm_connector_list_iter_end(&iter); > =20 > - return NULL; > + return connector; Connector might be uninitialized if we don't find one here > } > =20 > static int sun4i_tcon_get_pixel_depth(const struct drm_encoder *encoder) > @@ -65,6 +65,7 @@ static int sun4i_tcon_get_pixel_depth(const struct drm_= encoder *encoder) > return -EINVAL; > =20 > info =3D &connector->display_info; > + drm_connector_put(connector); > if (info->num_bus_formats !=3D 1) We're still accessing connector->display_info here, but it might have been freed already. Maxime --vw4qxeyln6gwbonp Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iHUEABYKAB0WIQRcEzekXsqa64kGDp7j7w1vZxhRxQUCYYFTQwAKCRDj7w1vZxhR xW5tAP4vLeRUB7hovZ/pzeMNYb3F27REbqDmaJ5hMt09+f8PEwD/cTbVT8+nLcMU bJyX2cCnGrXIgeAL3mxTmb8Efmeypg0= =d0nY -----END PGP SIGNATURE----- --vw4qxeyln6gwbonp--