Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp5791592pxu; Thu, 22 Oct 2020 11:06:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxo5pA7XovifRhRGPHNGx5U54wIu7Ef4Nb5YaAt/8h9kjNPFEVN7z7cYfdyhEz3Fk5TRO5K X-Received: by 2002:a17:907:20b2:: with SMTP id pw18mr3354868ejb.159.1603390016101; Thu, 22 Oct 2020 11:06:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603390016; cv=none; d=google.com; s=arc-20160816; b=vvn8lwMWyve+jlw7C88zgoYyAfP4g8/bWm9oZT/Akhkevy8cZVgzJxSxSk9iUwLWHj ioQoGpikaizemG/QPo/HEzsjrVjCap6KWjtdKYeU1qJ0ygoKBxuo1+OwURBgZWzcqC7G uOUcDKGrzuWxxw89gfIMGYfTZUd2oD+MUk/YJEdl52Sc1QsT872k1buDzN68YWP3axT5 vNt7JEe82jMkAeNSKt69fkAFAH7mLRp1hHHcQVzKt2TEe9ks0zhHkcL95IYdg29fCDUv YPSngYxsHTZNfkVOGNmzm0qqnH1Ii/B3MHwa08g908qAg6/f3U74ajzaacFPZZSTpnm1 T9NQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=p8dXiWLqTvchtYtVMK8Bdam6TFhRSlkKg+tR4PFP9nE=; b=ncM6dEFOGgcmoZxfGlpRpZWkkTuwyBAaWRWG5lJVvgbLCpOM/TzYvBeII/U3i+KvkV c9rmPk9TvMEa1VYzOaBmyv2P5q2cVVrMGmiE/JolCTwOii67pus9OwBtM6DRvBr/iihm WIjYbVrX7qvWuyuqe2bwQcfGJwEH4+iA+Ud9RKhz1hJZDcwpSmSJTXRXW7OHTqcK++0L yLm3F0u0D25cNlNNf4tASfBdrGybTg8P4t5v3Jg+3BYmdkqgwIERPzXoUxld4v6GNuJs TLzdIdbS+pP9es/qNhiKbQC2mSD3DGMyOmWvqqM8ZQ7q+QL6+kSe3Dpzr46YFR2Yik/V lTvg== ARC-Authentication-Results: i=1; mx.google.com; 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 n10si1356635eja.436.2020.10.22.11.06.33; Thu, 22 Oct 2020 11:06:56 -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; 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 S368869AbgJVP7x (ORCPT + 99 others); Thu, 22 Oct 2020 11:59:53 -0400 Received: from mx2.suse.de ([195.135.220.15]:48562 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S368878AbgJVP7M (ORCPT ); Thu, 22 Oct 2020 11:59:12 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 41DD3AC23; Thu, 22 Oct 2020 15:59:10 +0000 (UTC) From: Nicolas Saenz Julienne To: u.kleine-koenig@pengutronix.de, linux-kernel@vger.kernel.org, Philipp Zabel Cc: f.fainelli@gmail.com, linux-pwm@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, wahrenst@gmx.net, linux-input@vger.kernel.org, dmitry.torokhov@gmail.com, gregkh@linuxfoundation.org, devel@driverdev.osuosl.org, linux-gpio@vger.kernel.org, linus.walleij@linaro.org, linux-clk@vger.kernel.org, sboyd@kernel.org, linux-rpi-kernel@lists.infradead.org, Nicolas Saenz Julienne Subject: [PATCH v2 04/10] reset: raspberrypi: Release firmware handle on unbind Date: Thu, 22 Oct 2020 17:58:51 +0200 Message-Id: <20201022155858.20867-5-nsaenzjulienne@suse.de> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201022155858.20867-1-nsaenzjulienne@suse.de> References: <20201022155858.20867-1-nsaenzjulienne@suse.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Upon unbinding the device make sure we release RPi's firmware interface. Signed-off-by: Nicolas Saenz Julienne --- drivers/reset/reset-raspberrypi.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/drivers/reset/reset-raspberrypi.c b/drivers/reset/reset-raspberrypi.c index 02f59c06f69b..29311192e2c9 100644 --- a/drivers/reset/reset-raspberrypi.c +++ b/drivers/reset/reset-raspberrypi.c @@ -99,7 +99,17 @@ static int rpi_reset_probe(struct platform_device *pdev) priv->rcdev.ops = &rpi_reset_ops; priv->rcdev.of_node = dev->of_node; - return devm_reset_controller_register(dev, &priv->rcdev); + return reset_controller_register(&priv->rcdev); +} + +static int rpi_reset_remove(struct platform_device *pdev) +{ + struct rpi_reset *priv = platform_get_drvdata(pdev); + + reset_controller_unregister(&priv->rcdev); + rpi_firmware_put(priv->fw); + + return 0; } static const struct of_device_id rpi_reset_of_match[] = { @@ -110,6 +120,7 @@ MODULE_DEVICE_TABLE(of, rpi_reset_of_match); static struct platform_driver rpi_reset_driver = { .probe = rpi_reset_probe, + .remove = rpi_reset_remove, .driver = { .name = "raspberrypi-reset", .of_match_table = rpi_reset_of_match, -- 2.28.0