Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1002391ybt; Fri, 19 Jun 2020 21:13:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzWm84AvL7/G7WW4VvvXSy7wIK+K0kafNirI0NTvWa/erAv5+XKUkrqdZmL3llMfdAe4Gyl X-Received: by 2002:aa7:c71a:: with SMTP id i26mr6385809edq.149.1592626439725; Fri, 19 Jun 2020 21:13:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592626439; cv=none; d=google.com; s=arc-20160816; b=gpc+RTNXnkYcNQC91UtKQ3Q7bKuyZ7ekGqMj1Ozjm7YJfKgfpWP3BqLe4W+ZBWSrQ9 G1oEASw6nD6gaYnrAlm/oxCz1C6TiJ+J/dHvvYQVDkABSiCVOW7apqjcj9kPOlwKY3AK j1PuL/sSbfTp2ywFBfZJ8Xtev+hRiQQmDJPP4HRLkUMLAhy0xr8KcvHz+nWhGqguAp8k /Q70eC1vHvimsAnKHDirj0FztIyl9FUl08xwSCggYqQy6TCc4dOuUdm7anqh8GUMWXmA Uw7xm57i0ZNSJA8q0Y1VH54VGwxHHrVTP0opgoXtZdam29YDvWonuNhhzLRvIcDk9mfR leuA== 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=yRPCYkETV44Vh83W3oZIYCzFOpGqqORvXXyWG4G+xq8=; b=WZzFSB8KNFNAwFmjVVozoBUcWw+yYQwRKL3HALh625MKW/Xit0z56l6PVh8cwiCZfT RF3vHRGC0XTP7H6ygssBCQZV7Qdxrp8k5Cn3QXVYwlnEYyuEfJj1y2KjSc2ENSMzyaTH 8NXGXIOOrcaexniNgvsq2cHetngC262t7SnKvy1NyFUfeVh07uDmOE5Ll2fdFM+xWbEB 5Lu3KbaumV53w0tkpBYRaOTJ8M30H2XiCRSj72+tkjIwo/P+qoRReF5k6usr5fKubO3e Hkak+hIa/Ia/tVzfEKJwa4KgOlr4C0HpNstdNhHc4miQSPK9nzNNS4OVoE9LAG7ahbcm FCPg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="E/El0ifL"; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dm20si6502382ejc.159.2020.06.19.21.13.37; Fri, 19 Jun 2020 21:13:59 -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=@kernel.org header.s=default header.b="E/El0ifL"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2436590AbgFSQyo (ORCPT + 99 others); Fri, 19 Jun 2020 12:54:44 -0400 Received: from mail.kernel.org ([198.145.29.99]:52790 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387501AbgFSOgV (ORCPT ); Fri, 19 Jun 2020 10:36:21 -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 052FE21548; Fri, 19 Jun 2020 14:36:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592577380; bh=bSRmDGhM4dZBYCO1zM4PBGWuGwbULiqHak2p8noiIKY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=E/El0ifLcBrz1zFjVsBc7NbiQ2hkG1MbIXHSldWq9ULnJv8yGnP5hNr+abYVJnqEd IsXLbrqFPgQhNFpcbPBr5ldL26Vjc93Wt+ZGBbkcbJd1zY4GtrvUooiPxjuJUwUrAo teaAPqw0+eSN6v5RE9msrkpIeBM2tyy3eX7g+oNY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lukas Wunner , Andy Shevchenko , Baruch Siach , Mark Brown , Sasha Levin Subject: [PATCH 4.4 027/101] spi: dw: Fix controller unregister order Date: Fri, 19 Jun 2020 16:32:16 +0200 Message-Id: <20200619141615.502676171@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200619141614.001544111@linuxfoundation.org> References: <20200619141614.001544111@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: Lukas Wunner [ Upstream commit ca8b19d61e3fce5d2d7790cde27a0b57bcb3f341 ] The Designware SPI driver uses devm_spi_register_controller() on bind. As a consequence, on unbind, __device_release_driver() first invokes dw_spi_remove_host() before unregistering the SPI controller via devres_release_all(). This order is incorrect: dw_spi_remove_host() shuts down the chip, rendering the SPI bus inaccessible even though the SPI controller is still registered. When the SPI controller is subsequently unregistered, it unbinds all its slave devices. Because their drivers cannot access the SPI bus, e.g. to quiesce interrupts, the slave devices may be left in an improper state. As a rule, devm_spi_register_controller() must not be used if the ->remove() hook performs teardown steps which shall be performed after unregistering the controller and specifically after unbinding of slaves. Fix by reverting to the non-devm variant of spi_register_controller(). An alternative approach would be to use device-managed functions for all steps in dw_spi_remove_host(), e.g. by calling devm_add_action_or_reset() on probe. However that approach would add more LoC to the driver and it wouldn't lend itself as well to backporting to stable. Fixes: 04f421e7b0b1 ("spi: dw: use managed resources") Signed-off-by: Lukas Wunner Reviewed-by: Andy Shevchenko Cc: stable@vger.kernel.org # v3.14+ Cc: Baruch Siach Link: https://lore.kernel.org/r/3fff8cb8ae44a9893840d0688be15bb88c090a14.1590408496.git.lukas@wunner.de Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- drivers/spi/spi-dw.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/spi/spi-dw.c b/drivers/spi/spi-dw.c index 61a951549eba..295249843e7c 100644 --- a/drivers/spi/spi-dw.c +++ b/drivers/spi/spi-dw.c @@ -534,7 +534,7 @@ int dw_spi_add_host(struct device *dev, struct dw_spi *dws) } } - ret = devm_spi_register_master(dev, master); + ret = spi_register_master(master); if (ret) { dev_err(&master->dev, "problem registering spi master\n"); goto err_dma_exit; @@ -558,6 +558,8 @@ void dw_spi_remove_host(struct dw_spi *dws) { dw_spi_debugfs_remove(dws); + spi_unregister_master(dws->master); + if (dws->dma_ops && dws->dma_ops->dma_exit) dws->dma_ops->dma_exit(dws); -- 2.25.1