Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp1122561ybe; Fri, 13 Sep 2019 11:22:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqzNXxXDzz3pnBgruk6opUqahWOBQm7xX9gLvvhIDmHPUMDbk2cWqaY618fd/tSXpOiJoMu/ X-Received: by 2002:a17:907:41e5:: with SMTP id nb5mr1952265ejb.91.1568398946979; Fri, 13 Sep 2019 11:22:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568398946; cv=none; d=google.com; s=arc-20160816; b=GH0ZVVhvxzWmHvF3ScYY1shnq5+VOWrWFjG2y6yW5tqdn2kcybtUo4zoPxyjtODu7I iqS6zp09SSTwS8rMzZfhuV/ubaTYrymfXEM5vHuDnO+OrOGh06u8iXFCV9thGd8rjPi+ /2vEqQP/tChy/Xc/gh3W0dDmNr/cwq060jkrT3tGZ5He6t0VjXE88nrq6MZEmG++RCmS RvI5fr2VQnM442U0Y/07lRIlgzXEVoxJChWDSNrXPJHQ+tmm07JfdTfzQ6O19Gv5ThMy pHb3IcWABpY38zZQyw4XAzn6NKeuCvMZJAwzXhMe3krAqUGJx1Uambv+Qj8G+I9ushP9 TY+A== 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=q71UXAOqe5yGs4lDOjuwF6zO4sq5deMQZiL0z/IaxUU=; b=ht7Zf1js7ROoecSZxSHGQ5zHAenG19tgS7u2ZRhzfGUAr6NlVMlG4XHiEgNCsSZlB0 amGLBfgTM4uZUgXa/aOn/+DP/T0irjrUK1Y+5N5nQnhTqovwLBzoeJ1486SzCudgHGis /5mF0XeLZyMMsjifRgyOPUWY1jfe/QN2SJ2vHm179L1cteAsngF95APs6DRFLUpowog4 dhz+ergRe0jqdIh+9Tz2kt6n4+kkpuZPMxQ3Oaw8JF4wkawN60JnDS/7ADJGBHTlGV7g r3t2vNUb2ok1LzC22LkYEKZBUTNjnJyvraoPWePUpIv/oNfPce8LjLvW58YTZatO2UI6 tgxQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=chSPrX7k; 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 d17si14340489edr.294.2019.09.13.11.22.03; Fri, 13 Sep 2019 11:22:26 -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=chSPrX7k; 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 S2390036AbfIMNRS (ORCPT + 99 others); Fri, 13 Sep 2019 09:17:18 -0400 Received: from mail.kernel.org ([198.145.29.99]:44400 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390017AbfIMNRP (ORCPT ); Fri, 13 Sep 2019 09:17:15 -0400 Received: from localhost (unknown [104.132.45.99]) (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 195D0206A5; Fri, 13 Sep 2019 13:17:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1568380634; bh=ZFE8+QNtXmMbENewwtTgJlgNDip9sKbdVE4+5TxJSWo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=chSPrX7kUMjVnVgNWhSnKTLfbpmFC9Tgz8rU3CTTPQChD+UvAtM6bn2/zf6qaYLn6 16OGjgof/cXZ0rJL5Z397rYC0HF3oxwadbXo3KMJa1VnqUywDM1tVZp5RBFnWUHrJ/ UVkkOxffMXNvqHXi0uGUSuIgJrSZMXrbg3KriEdE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jisheng Zhang , Lorenzo Pieralisi , Bjorn Helgaas , Gustavo Pimentel , Sasha Levin Subject: [PATCH 4.19 129/190] PCI: dwc: Use devm_pci_alloc_host_bridge() to simplify code Date: Fri, 13 Sep 2019 14:06:24 +0100 Message-Id: <20190913130610.230166835@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20190913130559.669563815@linuxfoundation.org> References: <20190913130559.669563815@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 [ Upstream commit e6fdd3bf5aecd8615f31a5128775b9abcf3e0d86 ] Use devm_pci_alloc_host_bridge() to simplify the error code path. This also fixes a leak in the dw_pcie_host_init() error path. Signed-off-by: Jisheng Zhang Signed-off-by: Lorenzo Pieralisi Signed-off-by: Bjorn Helgaas Acked-by: Gustavo Pimentel CC: stable@vger.kernel.org # v4.13+ Signed-off-by: Sasha Levin --- .../pci/controller/dwc/pcie-designware-host.c | 21 +++++++------------ 1 file changed, 8 insertions(+), 13 deletions(-) diff --git a/drivers/pci/controller/dwc/pcie-designware-host.c b/drivers/pci/controller/dwc/pcie-designware-host.c index acd50920c2ffd..b57ee79f6d699 100644 --- a/drivers/pci/controller/dwc/pcie-designware-host.c +++ b/drivers/pci/controller/dwc/pcie-designware-host.c @@ -356,7 +356,7 @@ int dw_pcie_host_init(struct pcie_port *pp) dev_err(dev, "Missing *config* reg space\n"); } - bridge = pci_alloc_host_bridge(0); + bridge = devm_pci_alloc_host_bridge(dev, 0); if (!bridge) return -ENOMEM; @@ -367,7 +367,7 @@ int dw_pcie_host_init(struct pcie_port *pp) ret = devm_request_pci_bus_resources(dev, &bridge->windows); if (ret) - goto error; + return ret; /* Get the I/O and memory ranges from DT */ resource_list_for_each_entry_safe(win, tmp, &bridge->windows) { @@ -411,8 +411,7 @@ int dw_pcie_host_init(struct pcie_port *pp) resource_size(pp->cfg)); if (!pci->dbi_base) { dev_err(dev, "Error with ioremap\n"); - ret = -ENOMEM; - goto error; + return -ENOMEM; } } @@ -423,8 +422,7 @@ int dw_pcie_host_init(struct pcie_port *pp) pp->cfg0_base, pp->cfg0_size); if (!pp->va_cfg0_base) { dev_err(dev, "Error with ioremap in function\n"); - ret = -ENOMEM; - goto error; + return -ENOMEM; } } @@ -434,8 +432,7 @@ int dw_pcie_host_init(struct pcie_port *pp) pp->cfg1_size); if (!pp->va_cfg1_base) { dev_err(dev, "Error with ioremap\n"); - ret = -ENOMEM; - goto error; + return -ENOMEM; } } @@ -458,14 +455,14 @@ int dw_pcie_host_init(struct pcie_port *pp) pp->num_vectors == 0) { dev_err(dev, "Invalid number of vectors\n"); - goto error; + return -EINVAL; } } if (!pp->ops->msi_host_init) { ret = dw_pcie_allocate_domains(pp); if (ret) - goto error; + return ret; if (pp->msi_irq) irq_set_chained_handler_and_data(pp->msi_irq, @@ -474,7 +471,7 @@ int dw_pcie_host_init(struct pcie_port *pp) } else { ret = pp->ops->msi_host_init(pp); if (ret < 0) - goto error; + return ret; } } @@ -514,8 +511,6 @@ int dw_pcie_host_init(struct pcie_port *pp) err_free_msi: if (pci_msi_enabled() && !pp->ops->msi_host_init) dw_pcie_free_msi(pp); -error: - pci_free_host_bridge(bridge); return ret; } -- 2.20.1