Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp537870ybt; Fri, 19 Jun 2020 07:45:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz1o5iA1k2G0tZ5daSdHf0wXg++N8Em37JU32Q81zOsO0/AVLxNERiAgk5QEJ0GiES3LBPr X-Received: by 2002:a05:6402:b87:: with SMTP id cf7mr3885517edb.282.1592577929906; Fri, 19 Jun 2020 07:45:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592577929; cv=none; d=google.com; s=arc-20160816; b=r8ISGawxKrBaVdPVl1MikxZnArf3EK2ZVPxuEXQRb68tN8R0aPdJ9swuIb24dBI9sH DnhtQe5mBunyd2pQN9uispZwdqaQufRNYHZ+ljqRwYlYODD7eiCg8rs/QNVIydvjpMtx 8DFwfUQwLI/Mn87afnd1weBooQTB0Pb7jp8CjJ2m9jAqQkmnK+OzMIlVWIGXlZtVcY9d 1Lo0HnKv6oFTGVIDrImY/JoRRIQdUTv6GikwJ+lnOyORUYCsyZabcnU2PEaHtixIhy2j HYJtGayvP6AKf5kvukFlTLnHxlUIKbot7x2NmI8yn1+tNOKmCT2xmqUjPaxdyOQs+s4y lYYg== 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=LZj4XPL82ck1ce+pJBR8uKWTbrvKDp29KQ6PZG1+DsE=; b=ib3TI79L9VFoMRfsaWx9HfSrWU9op8i6BHAgsQELwOPXu/0CipymVuQJl2c1Te9A6o q6x24UKG6sQ1L4QreFK2i5NlPpr+QnA3leuExdJHtnlr5Llo5WKpF2/KuV2rbC/IcxEo FkjGtPfypFbIk51vUDt+s2fgIqzB8AX3D0OWvDbah1cE0d27LPhy8+aY4bVfzXfwrOjb pAidMyUqxk7KpIc9VKcra2KY3ymfZabB8CbKuBdkj4pKbV7WubQF/E6E/MhLAjPeKqGe yp9tG7g0udCOyiNsbMP+keKgrR9nsHwuhuUkov7Q6tvhNp/GbOTpfMA2JScQaCYEqOpy v/kw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="E/pJjACZ"; 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 dn7si4360925edb.219.2020.06.19.07.45.07; Fri, 19 Jun 2020 07:45:29 -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/pJjACZ"; 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 S2388336AbgFSOmM (ORCPT + 99 others); Fri, 19 Jun 2020 10:42:12 -0400 Received: from mail.kernel.org ([198.145.29.99]:60798 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388315AbgFSOmB (ORCPT ); Fri, 19 Jun 2020 10:42:01 -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 DED3220A8B; Fri, 19 Jun 2020 14:42:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592577721; bh=4GDj40YMC236QJ/h4DC1Ce/InFlHhNvYDg8ll0+BQsg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=E/pJjACZzjtE2pue+j0aMOz4oC2wu1EzwOD1a34OlApGPHzC6nPj5tX5WeidJnJNb LwszwCWn0yIixpxGGk2CDmkqC8MKCodBWhvBrFUTa/RRHdFyt2TRhV/t9mWo0Sh4H9 KXxUuH7+pXfFc0ZcKCmDTe2SHhlq50FamotqzC6c= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lukas Wunner , Martin Sperl , Mark Brown Subject: [PATCH 4.9 022/128] spi: bcm2835aux: Fix controller unregister order Date: Fri, 19 Jun 2020 16:31:56 +0200 Message-Id: <20200619141621.339552116@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 commit b9dd3f6d417258ad0beeb292a1bc74200149f15d upstream. The BCM2835aux SPI driver uses devm_spi_register_master() on bind. As a consequence, on unbind, __device_release_driver() first invokes bcm2835aux_spi_remove() before unregistering the SPI controller via devres_release_all(). This order is incorrect: bcm2835aux_spi_remove() 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_master() 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_master(). Note that the struct spi_master as well as the driver-private data are not freed until after bcm2835aux_spi_remove() has finished, so accessing them is safe. Fixes: 1ea29b39f4c8 ("spi: bcm2835aux: add bcm2835 auxiliary spi device driver") Signed-off-by: Lukas Wunner Cc: stable@vger.kernel.org # v4.4+ Cc: Martin Sperl Link: https://lore.kernel.org/r/32f27f4d8242e4d75f9a53f7e8f1f77483b08669.1589557526.git.lukas@wunner.de Signed-off-by: Mark Brown Signed-off-by: Greg Kroah-Hartman --- drivers/spi/spi-bcm2835aux.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) --- a/drivers/spi/spi-bcm2835aux.c +++ b/drivers/spi/spi-bcm2835aux.c @@ -485,7 +485,7 @@ static int bcm2835aux_spi_probe(struct p 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; @@ -505,6 +505,8 @@ static int bcm2835aux_spi_remove(struct struct spi_master *master = platform_get_drvdata(pdev); struct bcm2835aux_spi *bs = spi_master_get_devdata(master); + spi_unregister_master(master); + bcm2835aux_spi_reset_hw(bs); /* disable the HW block by releasing the clock */