Received: by 2002:ac0:a591:0:0:0:0:0 with SMTP id m17-v6csp991559imm; Thu, 5 Jul 2018 12:34:10 -0700 (PDT) X-Google-Smtp-Source: AAOMgpe8ix9ng7f66IrpvyWy4VBslhTcoZsHn2K11YqqTQy1KUPZEKX09cEmWk67USJNwzRn/NAi X-Received: by 2002:a63:65c2:: with SMTP id z185-v6mr891949pgb.276.1530819250707; Thu, 05 Jul 2018 12:34:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530819250; cv=none; d=google.com; s=arc-20160816; b=wTwdrjmdoE7Xh5mocoxNMg/qImHyeqh5Hck64/2IzaWzOgAi+VyXArFuc7IPljLFF5 jfLV9e6R+8De7rOuiYNuuvUYsuglBPIDUZENTx8E4haqSZwSHNHFpWo9d/iDm9qTDd6w eGa6X/SMwvcx8AJglond2x5iCTcaUiezo+nhv89jP7eRU0KW7XXtzvzrA4ZfhGm2tq9W 3NRv9GtlfnFcYsvjfIsgHYKVUwpHvn2+Otob2fYrxRu1tDFkIfqBgYQjej18i0IWjw5L uytRYN/8H9fmh/VTIju3ChNEQHABV5AHF5ADag7Khd+dmJpCIEKslDPZm6Yy9iEZKDw6 T+VQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject:arc-authentication-results; bh=YsRy26SaVA9x0fnWoopEqLaE/H0fHsvtg/EhrP16K1o=; b=XYcfva+fDI17s9URc3KUVdlaUHzSzDIF5ItEM+4hORi7tlIjYgJCAWBujLlMAVbrlu e/KnoZJ8kEYkVaJLk0MyrutHXOQosbM9FguMoYZvf0jxF+eMIf03+qJFEqggpJMtgEZ1 VVLR9SUgOJI2w8UCJEglau+SV5JFJs3VfC+Cml7j5OCxIGT2GmKaoZt1oRU4sunt+nkN hWdhjb5rlW80eowH4+WCoPG7BvhvRGWeKzB9VBHw9bHg+vBlvw1uI69JUjVNMCbmHtte K87dmaKLc8zwhlUFO9dEJ4WlKKWy9MReIl/dU3uZGsYU6/9HeDGNn4ALrDbuSZpxO8v8 Vxyg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a8-v6si6596213pfj.300.2018.07.05.12.33.56; Thu, 05 Jul 2018 12:34:10 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754052AbeGETcZ convert rfc822-to-8bit (ORCPT + 99 others); Thu, 5 Jul 2018 15:32:25 -0400 Received: from hqemgate14.nvidia.com ([216.228.121.143]:16854 "EHLO hqemgate14.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753464AbeGETcY (ORCPT ); Thu, 5 Jul 2018 15:32:24 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqemgate14.nvidia.com (using TLS: TLSv1, AES128-SHA) id ; Thu, 05 Jul 2018 12:32:23 -0700 Received: from HQMAIL108.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Thu, 05 Jul 2018 12:32:23 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Thu, 05 Jul 2018 12:32:23 -0700 Received: from [172.17.136.14] (172.17.136.14) by HQMAIL108.nvidia.com (172.18.146.13) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Thu, 5 Jul 2018 19:32:22 +0000 Subject: Re: [PATCH] irqchip/gic: check return value of of_address_to_resource From: Bo Yan To: Marc Zyngier CC: , , References: <1530814859-11610-1-git-send-email-byan@nvidia.com> <20180705201327.4a4dc7dd@why.wild-wind.fr.eu.org> <5548bdf4-4e4f-a2e1-b194-da35da87e3d3@nvidia.com> X-Nvconfidentiality: public Message-ID: Date: Thu, 5 Jul 2018 12:32:22 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <5548bdf4-4e4f-a2e1-b194-da35da87e3d3@nvidia.com> X-Originating-IP: [172.17.136.14] X-ClientProxiedBy: HQMAIL105.nvidia.com (172.20.187.12) To HQMAIL108.nvidia.com (172.18.146.13) Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Marc, Sorry for the previous reply. My email settings were not correct, so it inserted those confidentiality text, which was not what I intended. This is what I think: diff --git a/drivers/irqchip/irq-gic.c b/drivers/irqchip/irq-gic.c index ced10c4..0b60bb0 100644 --- a/drivers/irqchip/irq-gic.c +++ b/drivers/irqchip/irq-gic.c @@ -1284,7 +1284,7 @@ static bool gic_check_eoimode(struct device_node *node, void __iomem **base) { struct resource cpuif_res; - of_address_to_resource(node, 1, &cpuif_res); + (void)of_address_to_resource(node, 1, &cpuif_res); if (!is_hyp_mode_available()) return false; We are 100% sure of_address_to_resource will succeed in this particular case, so "(void)" will help suppress Coverity warning. On 07/05/2018 12:18 PM, Bo Yan wrote: > Marc, > > I'm also wondering if of_address_to_resource can really fail in this > particular case? > > What if we just explicitly discard the return value like this: > > (void)of_address_to_resource(node, 1, &cpuif_res); > > This suppresses Coverity warning by explicitly stating we are 100% sure > the function call will always return success. > > On 07/05/2018 12:13 PM, Marc Zyngier wrote: >> Hi Bo, >> >> On Thu, 5 Jul 2018 11:20:59 -0700 >> Bo Yan wrote: >> >>> The of_address_to_resource returns 0 if successful. gic_check_eoimode >>> calls it without checking the return value. This induces Coverity >>> warning: "Unchecked return value". >>> >>> Return false from gic_check_eoimode if of_address_to_resource returns >>> non-0 value. >>> >>> Signed-off-by: Bo Yan >>> --- >>>   drivers/irqchip/irq-gic.c | 3 ++- >>>   1 file changed, 2 insertions(+), 1 deletion(-) >>> >>> diff --git a/drivers/irqchip/irq-gic.c b/drivers/irqchip/irq-gic.c >>> index ced10c4..0bceb10 100644 >>> --- a/drivers/irqchip/irq-gic.c >>> +++ b/drivers/irqchip/irq-gic.c >>> @@ -1284,7 +1284,8 @@ static bool gic_check_eoimode(struct >>> device_node *node, void __iomem **base) >>>   { >>>       struct resource cpuif_res; >>> -    of_address_to_resource(node, 1, &cpuif_res); >>> +    if (of_address_to_resource(node, 1, &cpuif_res)) >>> +        return false; >> >> We've just done an of_iomap() on this resource, which succeeded. How >> can the same thing now fail? It would mean that the device tree has >> been pulled from under our feet... >> >> And if it could happen, why is returning false the right thing to do? >> Why would we say we want EOImode==0 instead of 1? >> >>>       if (!is_hyp_mode_available()) >>>           return false; >> >> As it stands, I'm not taking such a patch. It either papers over a >> bigger problem, or just keeps a warning quiet for the sake of it. >> >> Thanks, >> >>     M. >>