Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp3390881ybp; Sun, 6 Oct 2019 10:54:03 -0700 (PDT) X-Google-Smtp-Source: APXvYqwrZNJRPSOsNWfH4wOH7YYzDdhvzoTWwvzolIrOSmXpN1dAnDScCsTowHNfAnpewA2IzHIY X-Received: by 2002:a17:906:8319:: with SMTP id j25mr21186265ejx.122.1570384443863; Sun, 06 Oct 2019 10:54:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570384443; cv=none; d=google.com; s=arc-20160816; b=SKMptY70phefCyCC/RsKLjFb7p5pVwf7c4xK5sBlXH8G1Y9LFYfC9P3sY8npbB+LY5 KgJKugFysgUAEjlCTDRQbbFUfnGnKnLjJn2ZoC/Xo53ylTUEF3Chva0Vwlb3JPKIMR8S 9JmddlPJlg7zNgzDF/oapr+7AYpdjiIRW9isZn9QK+i3rqjm7jal0Cu+9Be5wsfDkj83 c0jHkMtN4uXX/rx736sluA71DnJSOcZpUSvJqJz9Kx6JjvILLfDujGB3kOfQEmb6D5Sa CTIeH48ylkXSfBkoPhUsPU7DLY8oHh99yxyYogF9xW6rMFW4PrDHgtaY874haPIofVH8 qbdw== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=zcfMdDbWivrixhfbuUd19qdzL1FtXxCOMjccAQZimk0=; b=0R0hN4U6v4FU1tWYcvQMuw29ealCBktI+lW8YtBukgW4LdkEYyh/gQxEzA+NNlp0mf ddEMP4Th/aJuIUBQeW8oyJX5snv0OJnCwM6qRLVjPY7Qs6+mzTLvINEecHRWcQxXs+J6 0joOAtoJiizHX+wIRaIdU4kI2WtCTvuFPbqUscLqkubN/EMFtNlLKge6hBSOhmqBe5/g jcjBH+DhSCfwwofn/wDqTYdD532Dfkqua36ET9t/IkBw8UQeU2WGJq1F1PXcgp3vXyHP rWH+h/8Ot1cbzOh8SQqOY2tCF9a/VWrQ3+BL0k9f+/A8FRCAO4P6Yq9W8h0CgJm7qpUl PhOg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Owf0ASyO; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w14si5828449ejv.112.2019.10.06.10.53.40; Sun, 06 Oct 2019 10:54:03 -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; dkim=pass header.i=@kernel.org header.s=default header.b=Owf0ASyO; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730467AbfJFRhh (ORCPT + 99 others); Sun, 6 Oct 2019 13:37:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:36590 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730459AbfJFRhf (ORCPT ); Sun, 6 Oct 2019 13:37:35 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id E8C792053B; Sun, 6 Oct 2019 17:37:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1570383454; bh=q7LE7xSjAk2WfDmqoRiEwsDQ5sKIVq8bwyqwusRYBgk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Owf0ASyOXQy7xkdhJYtyS/JB9hwKoHhB3MslZ0tdrqRFgFATsQjH+E++tna8c+LPN 35Di2Tta2L7b1Bxx8DTY+ex/fDLYYm0LebE2dFFNb4EEpiyUAjmAuj3g2hpCtHTjnh I8sTQp9HtZtqTh5CN/diWdv6CGbY72rL75t9SVuk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Heiko Stuebner , Thierry Reding , Lorenzo Pieralisi , Andrew Murray , Shawn Lin , linux-rockchip@lists.infradead.org, Sasha Levin Subject: [PATCH 5.2 110/137] PCI: rockchip: Propagate errors for optional regulators Date: Sun, 6 Oct 2019 19:21:34 +0200 Message-Id: <20191006171218.188547549@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191006171209.403038733@linuxfoundation.org> References: <20191006171209.403038733@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Thierry Reding [ Upstream commit 0e3ff0ac5f71bdb6be2a698de0ed0c7e6e738269 ] regulator_get_optional() can fail for a number of reasons besides probe deferral. It can for example return -ENOMEM if it runs out of memory as it tries to allocate data structures. Propagating only -EPROBE_DEFER is problematic because it results in these legitimately fatal errors being treated as "regulator not specified in DT". What we really want is to ignore the optional regulators only if they have not been specified in DT. regulator_get_optional() returns -ENODEV in this case, so that's the special case that we need to handle. So we propagate all errors, except -ENODEV, so that real failures will still cause the driver to fail probe. Tested-by: Heiko Stuebner Signed-off-by: Thierry Reding Signed-off-by: Lorenzo Pieralisi Reviewed-by: Andrew Murray Reviewed-by: Heiko Stuebner Acked-by: Shawn Lin Cc: Shawn Lin Cc: Heiko Stuebner Cc: linux-rockchip@lists.infradead.org Signed-off-by: Sasha Levin --- drivers/pci/controller/pcie-rockchip-host.c | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/drivers/pci/controller/pcie-rockchip-host.c b/drivers/pci/controller/pcie-rockchip-host.c index 8d20f1793a618..ef8e677ce9d11 100644 --- a/drivers/pci/controller/pcie-rockchip-host.c +++ b/drivers/pci/controller/pcie-rockchip-host.c @@ -608,29 +608,29 @@ static int rockchip_pcie_parse_host_dt(struct rockchip_pcie *rockchip) rockchip->vpcie12v = devm_regulator_get_optional(dev, "vpcie12v"); if (IS_ERR(rockchip->vpcie12v)) { - if (PTR_ERR(rockchip->vpcie12v) == -EPROBE_DEFER) - return -EPROBE_DEFER; + if (PTR_ERR(rockchip->vpcie12v) != -ENODEV) + return PTR_ERR(rockchip->vpcie12v); dev_info(dev, "no vpcie12v regulator found\n"); } rockchip->vpcie3v3 = devm_regulator_get_optional(dev, "vpcie3v3"); if (IS_ERR(rockchip->vpcie3v3)) { - if (PTR_ERR(rockchip->vpcie3v3) == -EPROBE_DEFER) - return -EPROBE_DEFER; + if (PTR_ERR(rockchip->vpcie3v3) != -ENODEV) + return PTR_ERR(rockchip->vpcie3v3); dev_info(dev, "no vpcie3v3 regulator found\n"); } rockchip->vpcie1v8 = devm_regulator_get_optional(dev, "vpcie1v8"); if (IS_ERR(rockchip->vpcie1v8)) { - if (PTR_ERR(rockchip->vpcie1v8) == -EPROBE_DEFER) - return -EPROBE_DEFER; + if (PTR_ERR(rockchip->vpcie1v8) != -ENODEV) + return PTR_ERR(rockchip->vpcie1v8); dev_info(dev, "no vpcie1v8 regulator found\n"); } rockchip->vpcie0v9 = devm_regulator_get_optional(dev, "vpcie0v9"); if (IS_ERR(rockchip->vpcie0v9)) { - if (PTR_ERR(rockchip->vpcie0v9) == -EPROBE_DEFER) - return -EPROBE_DEFER; + if (PTR_ERR(rockchip->vpcie0v9) != -ENODEV) + return PTR_ERR(rockchip->vpcie0v9); dev_info(dev, "no vpcie0v9 regulator found\n"); } -- 2.20.1