Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1000413ybt; Fri, 19 Jun 2020 21:09:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxP9jtUgDT6+vK6M7VZl7bmwBrvOTDAP9yScb6HXDN0EYxxzE30vf7o5UIWjI8N8zIJc8ku X-Received: by 2002:a05:6402:148d:: with SMTP id e13mr6584506edv.200.1592626185426; Fri, 19 Jun 2020 21:09:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592626185; cv=none; d=google.com; s=arc-20160816; b=UKjNxz4Qq1VAKVdI3gGPPSdYrZJUKH8AvGa4rpLdvh7WI1rpI5W9Rm6nb6Vg5qUaW/ Wu8qyX/JH+C6GMiohOJ/i1/wnm90OZ6LQr7XYrsjrVu2XwHM0b4wLoRB3I4p+mFIYBGO 0GohfYadlVlS5Xmo1jxlweBStKUPZQdnE5sFo0qbZjrhJdV1XXGEuDU0A0P/asQpBJjY YPpfaFgm3DQ8vaBmqiuBEDu0LgxZAoyqZE5E85Wye3C+kEhFlUEIlVIlr88Y494a7tSZ A+znYhWFUvoqCPwLIHWr+LanUMbP7gp4VfXSF0ujxzoIrT3ZIsJZrLUUuKF0o0rOFj+e 8Gzw== 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=iih0oN3HSjWDFDPW7B6afwOACOTnsM5eP6c/6pY6SqY=; b=xiW5WKaLx2v/HxudYjMVy+ZCyCOpTXDJAS8FQYLCWCRiUzr7RMC6RRILzra819FNAU 9FrttnGzM3aYG6eOaOFPFZTfo6jCPsRsN/j/OcHAZQxaeAde2QXHjqHekZ05a0MxT+p8 ptP2V2LTZ9tZSq53z5gkgHAMDTZNX0KpZrCIaHn+nyOjXccKMluywMcNpsepISMebvhT mSjwFyLtUrI/k6NMbUliR+mW0vdcKfa7f/cz8paJ3HIwcXNTQ6oGkFRQZ4Wi742y2vHC 0iFvHZYu1PVjanPemtlL2Q/oFZojwWCG414yrRUadXkjtq9f7ajtfYi/HgTngMq/kUqe BAkw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=LGznwckh; 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 bs24si5171709edb.4.2020.06.19.21.09.23; Fri, 19 Jun 2020 21:09:45 -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=LGznwckh; 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 S2405745AbgFSQsF (ORCPT + 99 others); Fri, 19 Jun 2020 12:48:05 -0400 Received: from mail.kernel.org ([198.145.29.99]:59002 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387803AbgFSOkv (ORCPT ); Fri, 19 Jun 2020 10:40:51 -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 2FFF620A8B; Fri, 19 Jun 2020 14:40:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592577650; bh=zl0ACyDj7vFcEaBdi95zIaIux1rc3z6IveIFcj/66R8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LGznwckhDwgdHD8JLIuTwkYx+sJPbiVKFoAY06xV4xbOoNHqChEtfF4J+13L47P0b QbDpaPtqyYtcJVN8J0cEqozUsWmKrr4oFSivZtKuadtjgMRHZRhSUD52qW+/FAxfxQ UicuoPip1N3hyMD6/60gmCVIaHsN0C20W6uuqMFs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lukas Wunner , Mark Brown , Sasha Levin Subject: [PATCH 4.9 034/128] spi: bcm2835: Fix controller unregister order Date: Fri, 19 Jun 2020 16:32:08 +0200 Message-Id: <20200619141621.988992893@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200619141620.148019466@linuxfoundation.org> References: <20200619141620.148019466@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 9dd277ff92d06f6aa95b39936ad83981d781f49b ] The BCM2835 SPI driver uses devm_spi_register_controller() on bind. As a consequence, on unbind, __device_release_driver() first invokes bcm2835_spi_remove() before unregistering the SPI controller via devres_release_all(). This order is incorrect: bcm2835_spi_remove() tears down the DMA channels and turns off the SPI controller, including its interrupts and clock. The SPI controller is thus no longer usable. When the SPI controller is subsequently unregistered, it unbinds all its slave devices. If their drivers need to access the SPI bus, e.g. to quiesce their interrupts, unbinding will fail. As a rule, devm_spi_register_controller() must not be used if the ->remove() hook performs teardown steps which shall be performed after unbinding of slaves. Fix by using the non-devm variant spi_register_controller(). Note that the struct spi_controller as well as the driver-private data are not freed until after bcm2835_spi_remove() has finished, so accessing them is safe. Fixes: 247263dba208 ("spi: bcm2835: use devm_spi_register_master()") Signed-off-by: Lukas Wunner Cc: stable@vger.kernel.org # v3.13+ Link: https://lore.kernel.org/r/2397dd70cdbe95e0bc4da2b9fca0f31cb94e5aed.1589557526.git.lukas@wunner.de Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- drivers/spi/spi-bcm2835.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/spi/spi-bcm2835.c b/drivers/spi/spi-bcm2835.c index eab27d41ba83..df6abc75bc16 100644 --- a/drivers/spi/spi-bcm2835.c +++ b/drivers/spi/spi-bcm2835.c @@ -793,7 +793,7 @@ static int bcm2835_spi_probe(struct platform_device *pdev) goto out_clk_disable; } - err = devm_spi_register_master(&pdev->dev, master); + err = spi_register_master(master); if (err) { dev_err(&pdev->dev, "could not register SPI master: %d\n", err); goto out_clk_disable; @@ -813,6 +813,8 @@ static int bcm2835_spi_remove(struct platform_device *pdev) struct spi_master *master = platform_get_drvdata(pdev); struct bcm2835_spi *bs = spi_master_get_devdata(master); + spi_unregister_master(master); + /* Clear FIFOs, and disable the HW block */ bcm2835_wr(bs, BCM2835_SPI_CS, BCM2835_SPI_CS_CLEAR_RX | BCM2835_SPI_CS_CLEAR_TX); -- 2.25.1