Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp947640imw; Tue, 5 Jul 2022 00:42:14 -0700 (PDT) X-Google-Smtp-Source: AGRyM1ttCmmhjW5PqomWPGQTwCNk5WHjLcsIzjxr62ybttlypkf5QuGiD18qWeqAWO6TVaaxTbK5 X-Received: by 2002:a05:6402:3047:b0:435:9af7:7af3 with SMTP id bs7-20020a056402304700b004359af77af3mr45740764edb.252.1657006934680; Tue, 05 Jul 2022 00:42:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657006934; cv=none; d=google.com; s=arc-20160816; b=m6hbQWfLkBze2EDIYXCxTx4wtcgOIRTo2aYHapnDukN+q2hvI4lw+CcY4Hz2eVsBXL wUzXjQmWbDcrb7/H3m1tZ+rU4X0ibw4LUhUEs5lmNl6FQVinuNFTO2du1fXsNoxRJoRl JSZXxvnfQS6/+hBfspHCpfXPiMVfLdcU+w+utf0Gor8UicgUzQYIxAhR3gBYmUQvF11L 4v5FUn/hX8UkmWLFLK8fiKbT2IjFi/GXE0VwhqONVCGUCwzDSoa/GjkM5wtEW7Fi0xwE ErVDY9FYpe/1Wq4nxKaZn1vO1sQZ4ejqsXVHKVu7+eKv0KReAxxTD3drypxY8m7IK1nU GgiQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :organization:from:cc:references:to:content-language:subject :user-agent:mime-version:date:message-id:dkim-signature; bh=8usoLhk9ovXL0VS3GA/YN9J82Mt+1GOJy2yE4dko6a0=; b=Inibbp5tN7QATib6jpo+egI+Ym1sb1cogY1Su70Xjkx9GrnVfNDsgCKX6RPAsfc9mw bTMm8bOw3gZTlEUDJwhyr2RnvlX6azMP23/YZY6nee1oK4+y7syPornEJR1dNVYQYsB6 dnBLUFiUsGJ8WXZ4XEeLToke7HilBIFdMDC7aJufcQtAuQalc86PSJwkjSLyyjhlnb6Q RC2Bfz7YiNp7EjidpWcxPEPlv1F9ktjfAiurGLuBNOlWXHtRiGsVkLPqzEbkizUydpgv BIz0UrhhhVR0TE6inM3ehEgr+mn0iItO8AVbEpBJ7pbFV4TJLUc7HuZFa0nPjBhdFsIe sg0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b="txG/xRqN"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id fi23-20020a056402551700b0043a65b00adbsi2727797edb.413.2022.07.05.00.41.49; Tue, 05 Jul 2022 00:42:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b="txG/xRqN"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230139AbiGEHW3 (ORCPT + 99 others); Tue, 5 Jul 2022 03:22:29 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50502 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229900AbiGEHW1 (ORCPT ); Tue, 5 Jul 2022 03:22:27 -0400 Received: from mail-wr1-x42b.google.com (mail-wr1-x42b.google.com [IPv6:2a00:1450:4864:20::42b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 48B2511143 for ; Tue, 5 Jul 2022 00:22:25 -0700 (PDT) Received: by mail-wr1-x42b.google.com with SMTP id o4so16202889wrh.3 for ; Tue, 05 Jul 2022 00:22:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20210112.gappssmtp.com; s=20210112; h=message-id:date:mime-version:user-agent:subject:content-language:to :references:cc:from:organization:in-reply-to :content-transfer-encoding; bh=8usoLhk9ovXL0VS3GA/YN9J82Mt+1GOJy2yE4dko6a0=; b=txG/xRqNc6oEFbK0RW1XEurQ0naCyxCJC/Eiilem93tWdd9hnz85Y8XFr1hgWYsbbK RGehH4WkOmGstmSt0iaiJ/MR42Txb6KfIn14+W2PtA0f1Q8ILxDZtelZXLBBbgFSD+0I nFA8O/Mv41ABZ7BR5vbmH1iVk6ZiO46+I9adc+oxbLiVk3LD3mLbJUg5ONZMDCXkKDmR y2tHcvYlQk50Pip8Gr8Zr2ZTXk+4hd7p2Qr9k4wvJ3Lf/WUXmFosEVFvP2PFBWFYVBAA HWCcduzModaFma/1939yHkpuz4SRjld80v/HfDXTw2861sP29uGwpq3XWYH+JH2jFzaY MSBg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:to:references:cc:from:organization:in-reply-to :content-transfer-encoding; bh=8usoLhk9ovXL0VS3GA/YN9J82Mt+1GOJy2yE4dko6a0=; b=RAPrywnw8FS2Tk6T+5IO3Nvi1MURBjq2HtLOPr0nm7+myZGmuFm50YgHkT1nofwBaC cGw4zZ5yh2oO//Y4hhFbaQmGFizN+NSiIcW0Dz8gQEyVLfXRkWXL4/UW+vsyqOWvJwvf 9A4iN7YFu+SUKPorsOKkFnq7T7UgjYMQsjjb76NHmiGn5Olq+eXaqhzGANmQfvvUuX3G h7reM5dMTx0V3k7sKSpZmR2UZIeDNByWKChsolzCXNp+wHKsNlLuz2fpSxC6tQNdKZQL wxX+KV3Ahl0dDFVk0ieFonx+74+I5kOaewZzirZU64/xGTpndZHiziqj5z9fk+ETdOva lxNQ== X-Gm-Message-State: AJIora83uaAW9HBZ5XAZtPtMLj3Ly9OIF6vWOF6SrXeQG2xCcu6vs+7s DVWIKt22un6dNYB4pWScssEnHg== X-Received: by 2002:a05:6000:118e:b0:21d:701e:7cc5 with SMTP id g14-20020a056000118e00b0021d701e7cc5mr3214424wrx.376.1657005743778; Tue, 05 Jul 2022 00:22:23 -0700 (PDT) Received: from ?IPV6:2001:861:44c0:66c0:3c4f:78be:dc90:14f9? ([2001:861:44c0:66c0:3c4f:78be:dc90:14f9]) by smtp.gmail.com with ESMTPSA id d7-20020a5d5387000000b0021d5c52f4b4sm8416024wrv.34.2022.07.05.00.22.22 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 05 Jul 2022 00:22:23 -0700 (PDT) Message-ID: Date: Tue, 5 Jul 2022 09:22:22 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.8.1 Subject: Re: [PATCH] soc: amlogic: meson-pwrc: Hold reference returned by of_get_parent() Content-Language: en-US To: Liang He , khilman@baylibre.com, jbrunet@baylibre.com, martin.blumenstingl@googlemail.com, inux-amlogic@lists.infradead.org References: <20220705022032.281665-1-windhl@126.com> Cc: "open list:ARM/Amlogic Meson..." , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" From: Neil Armstrong Organization: Baylibre In-Reply-To: <20220705022032.281665-1-windhl@126.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,NICE_REPLY_A,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org + linux-amlogic, linux-arm-kernel, linux-kernel On 05/07/2022 04:20, Liang He wrote: > We should hold the reference returned by of_get_parent() and use > it to call of_node_put() for refcount balance. > > Signed-off-by: Liang He > --- > drivers/soc/amlogic/meson-ee-pwrc.c | 5 ++++- > drivers/soc/amlogic/meson-gx-pwrc-vpu.c | 5 ++++- > 2 files changed, 8 insertions(+), 2 deletions(-) > > diff --git a/drivers/soc/amlogic/meson-ee-pwrc.c b/drivers/soc/amlogic/meson-ee-pwrc.c > index 2be3afe6c2e3..872ab8ba90bc 100644 > --- a/drivers/soc/amlogic/meson-ee-pwrc.c > +++ b/drivers/soc/amlogic/meson-ee-pwrc.c > @@ -470,6 +470,7 @@ static int meson_ee_pwrc_probe(struct platform_device *pdev) > const struct meson_ee_pwrc_domain_data *match; > struct regmap *regmap_ao, *regmap_hhi; > struct meson_ee_pwrc *pwrc; > + struct device_node *np; > int i, ret; > > match = of_device_get_match_data(&pdev->dev); > @@ -495,7 +496,9 @@ static int meson_ee_pwrc_probe(struct platform_device *pdev) > > pwrc->xlate.num_domains = match->count; > > - regmap_hhi = syscon_node_to_regmap(of_get_parent(pdev->dev.of_node)); > + np = of_get_parent(pdev->dev.of_node); > + regmap_hhi = syscon_node_to_regmap(np); > + of_node_put(np); > if (IS_ERR(regmap_hhi)) { > dev_err(&pdev->dev, "failed to get HHI regmap\n"); > return PTR_ERR(regmap_hhi); > diff --git a/drivers/soc/amlogic/meson-gx-pwrc-vpu.c b/drivers/soc/amlogic/meson-gx-pwrc-vpu.c > index b4615b288625..75a4e1cec416 100644 > --- a/drivers/soc/amlogic/meson-gx-pwrc-vpu.c > +++ b/drivers/soc/amlogic/meson-gx-pwrc-vpu.c > @@ -274,6 +274,7 @@ static int meson_gx_pwrc_vpu_probe(struct platform_device *pdev) > struct regmap *regmap_ao, *regmap_hhi; > struct meson_gx_pwrc_vpu *vpu_pd; > struct reset_control *rstc; > + struct device_node *np; > struct clk *vpu_clk; > struct clk *vapb_clk; > bool powered_off; > @@ -291,7 +292,9 @@ static int meson_gx_pwrc_vpu_probe(struct platform_device *pdev) > > memcpy(vpu_pd, vpu_pd_match, sizeof(*vpu_pd)); > > - regmap_ao = syscon_node_to_regmap(of_get_parent(pdev->dev.of_node)); > + np = of_get_parent(pdev->dev.of_node); > + regmap_ao = syscon_node_to_regmap(np); > + of_node_put(np); > if (IS_ERR(regmap_ao)) { > dev_err(&pdev->dev, "failed to get regmap\n"); > return PTR_ERR(regmap_ao);