Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp3048749pxb; Tue, 24 Aug 2021 13:55:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxZB2rKao7rweSCzbRt/Gy2FhfWcugNhRGu78fXDFAeVyV69k/+ZhacZC0Tcle3Zfy3BPnC X-Received: by 2002:a5d:9b99:: with SMTP id r25mr33069610iom.104.1629838508267; Tue, 24 Aug 2021 13:55:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629838508; cv=none; d=google.com; s=arc-20160816; b=NOCGTne2h3dlSfgKseBYmjYu2zMnuSz8FMjNM2Uv3AJ6ti2JUKosOucDna+u9OOIQi ey9oyv0/TCyejHhl92IODmzrKK5JiyNt9VC9EYMFtmiRtkbIAd1y9mDFazu5l2SSkFag efY7ujuDKs9S1Q6ElLd5RPbwerkOladdvix+wjmxkIvGXSSd6OUWL5FmBWRlbZ3JhcXN wVOvRivIn1BhGWn/O62tCh8w3G2cTot3ng3p4r7daxdx9SNSBRgeZ4y2R8NKteAEe6Iv kN3AwSHlKGand09XOKQeH26HxwQNxNjWNZt106RZ5MMJ9HNVDuhJDDKw15uNSEyQfiBx HJbA== 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 :message-id:date:subject:cc:to:from; bh=YWbfSIvn5iTABgE4HQHaa1z96C9/BOIeklbBiKBKLz0=; b=IJe9n7/8plI8GSsL6hJogiQOyg5q0YkR5kvMqWmKFScCQ7HRcdFeLrQkjydpInMMH2 jWmUEc57LRDwfKLRlkjDEUMT1bwd7vRPDYGacynxPFDNTbX122QUCMUndNRITkz5YlbW vcNlVMtkxELZI8npxAwTg48rLbXcJbyrN0mCyVjXAMXqv3KvxGmIhMTH5NnARyBoC5mM ehkHt7XutHsCcN4VjijACpI+CSs9fH9khTNS9aRTm4L9wwGj3oQ8UkjZF8irpjab1xZg tK59+7oJBFOkppiwk98mOlA5u9hTTa8BwMRCnD+lNJ14ccnm0QHkD7OiqW6Ih30B+FyY 5aAA== 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 m11si19844818jaj.5.2021.08.24.13.54.49; Tue, 24 Aug 2021 13:55:08 -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 S231411AbhHXUxi (ORCPT + 99 others); Tue, 24 Aug 2021 16:53:38 -0400 Received: from smtp05.smtpout.orange.fr ([80.12.242.127]:33263 "EHLO smtp.smtpout.orange.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233289AbhHXUxh (ORCPT ); Tue, 24 Aug 2021 16:53:37 -0400 Received: from pop-os.home ([90.126.253.178]) by mwinf5d09 with ME id lYsq2500B3riaq203YsqZq; Tue, 24 Aug 2021 22:52:51 +0200 X-ME-Helo: pop-os.home X-ME-Auth: Y2hyaXN0b3BoZS5qYWlsbGV0QHdhbmFkb28uZnI= X-ME-Date: Tue, 24 Aug 2021 22:52:51 +0200 X-ME-IP: 90.126.253.178 From: Christophe JAILLET To: ardeleanalex@gmail.com, jic23@kernel.org, lars@metafoo.de, andy.shevchenko@gmail.com Cc: linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-janitors@vger.kernel.org, Christophe JAILLET Subject: [PATCH] iio: adc128s052: Simplify 'adc128_probe()' Date: Tue, 24 Aug 2021 22:52:49 +0200 Message-Id: X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Turn 'adc128_probe()' into a full resource managed function to simplify the code. This way, the .remove function can be removed. Doing so, the only 'spi_get_drvdata()' call is removed and the corresponding 'spi_set_drvdata()' can be removed as well. Suggested-by: Alexandru Ardelean Signed-off-by: Christophe JAILLET --- Compile tested only. When reviewing, pay special attention to the 'spi_set_drvdata()' call removal. I recently introduced a regression with a too aggressive cleanup like that. This patch should be applied after https://lore.kernel.org/linux-iio/f33069f0-601b-4bbb-3766-026f7a161912@wanadoo.fr/T/#meb792dcd6540f87d9ae041660ca4738a776e924a --- drivers/iio/adc/ti-adc128s052.c | 34 +++++++++++---------------------- 1 file changed, 11 insertions(+), 23 deletions(-) diff --git a/drivers/iio/adc/ti-adc128s052.c b/drivers/iio/adc/ti-adc128s052.c index 83c1ae07b3e9..e1afdb775100 100644 --- a/drivers/iio/adc/ti-adc128s052.c +++ b/drivers/iio/adc/ti-adc128s052.c @@ -132,6 +132,13 @@ static const struct iio_info adc128_info = { .read_raw = adc128_read_raw, }; +static void adc128_disable_regulator(void *data) +{ + struct regulator *reg = data; + + regulator_disable(reg); +} + static int adc128_probe(struct spi_device *spi) { struct iio_dev *indio_dev; @@ -151,8 +158,6 @@ static int adc128_probe(struct spi_device *spi) adc = iio_priv(indio_dev); adc->spi = spi; - spi_set_drvdata(spi, indio_dev); - indio_dev->name = spi_get_device_id(spi)->name; indio_dev->modes = INDIO_DIRECT_MODE; indio_dev->info = &adc128_info; @@ -167,29 +172,13 @@ static int adc128_probe(struct spi_device *spi) ret = regulator_enable(adc->reg); if (ret < 0) return ret; - - mutex_init(&adc->lock); - - ret = iio_device_register(indio_dev); + ret = devm_add_action_or_reset(&spi->dev, adc128_disable_regulator, adc->reg); if (ret) - goto err_disable_regulator; - - return 0; - -err_disable_regulator: - regulator_disable(adc->reg); - return ret; -} - -static int adc128_remove(struct spi_device *spi) -{ - struct iio_dev *indio_dev = spi_get_drvdata(spi); - struct adc128 *adc = iio_priv(indio_dev); + return ret; - iio_device_unregister(indio_dev); - regulator_disable(adc->reg); + mutex_init(&adc->lock); - return 0; + return devm_iio_device_register(&spi->dev, indio_dev); } static const struct of_device_id adc128_of_match[] = { @@ -231,7 +220,6 @@ static struct spi_driver adc128_driver = { .acpi_match_table = ACPI_PTR(adc128_acpi_match), }, .probe = adc128_probe, - .remove = adc128_remove, .id_table = adc128_id, }; module_spi_driver(adc128_driver); -- 2.30.2