Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp2327689pxb; Sun, 17 Oct 2021 11:41:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyOo5cA9R8ZjL3v9gGjDk2ktau5P8zTLDM05zKPeuL5AXukKVFWj9FOLbR9NDjw5+0c2BsI X-Received: by 2002:a65:5082:: with SMTP id r2mr19229020pgp.353.1634496079965; Sun, 17 Oct 2021 11:41:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634496079; cv=none; d=google.com; s=arc-20160816; b=OOz5QYX80qw7+31duGuW7IzMBLDVOvFHaTQVDzsOzi3a7EziixxRgl/SCoohfoLIIY YulzrB196VydXd1r/tY33yKajgRsc/l/k3+gICP8GVqGKhcms1zP3DXDf8DrWY1EKYUg vbxJRbIfuaDX6CA7WqdEmluItblR88rsGh01TlhjjFkLB4gCqxxKYlGzcPc+mv5Jjzoi 5nVm9rWyBLxYG8s341BOGkwG19Vo5eatl+FFFzopBKspRDLwNGd+8Mobwl64ilJJjMuL MaKR9TqjvbXlJX6d4OgzQT7F3pKg2XsY+1BwF30WJsQNY8NCmpMMNwRZOi/kwNRRix6b 845w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-disposition :mime-version:message-id:subject:cc:to:from:date:dkim-signature; bh=LPuZL7++oiK3AKTEYNGUGNnkKUKEOaVSI1la1HbR00o=; b=aRu4M2fiA8WnESwGofIjtLvpEJS7tOmQEcYsWZpD9aCyBgnFHa7NEc/66cs/VgscPn bqt1yyo2JxDhK3MPB8wCMS50rVPiUFQpM+qNemMrUAEKMyjXcpKixeDCry4cWqzBBUJ3 BFjgqJ5ttQsF7kHoVf5XO3wGFx5euLyjvdBF0ZvId6lz+7wtN6RleUYBuEJHsnhqoyhW 5XzcBn9kp/88ACB/GWSoQDrTGu6glfIj2tWwbcog/iK3z4AbylJWbLLmbX/IZ6CAWj8T GD7HngmFQWFyHBTwNCkd0RvpQwF7I15U0Dd40q/NFhuY44mKSDgTxZk1zm7HMBEJ4emQ AmTA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@usp.br header.s=usp-google header.b=fka0ul0B; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=usp.br Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h5si17053820pgp.537.2021.10.17.11.41.01; Sun, 17 Oct 2021 11:41:19 -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=@usp.br header.s=usp-google header.b=fka0ul0B; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=usp.br Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241261AbhJOStZ (ORCPT + 99 others); Fri, 15 Oct 2021 14:49:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59614 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237973AbhJOStZ (ORCPT ); Fri, 15 Oct 2021 14:49:25 -0400 Received: from mail-ua1-x929.google.com (mail-ua1-x929.google.com [IPv6:2607:f8b0:4864:20::929]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4AD8CC061570 for ; Fri, 15 Oct 2021 11:47:18 -0700 (PDT) Received: by mail-ua1-x929.google.com with SMTP id u5so19813786uao.13 for ; Fri, 15 Oct 2021 11:47:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=usp.br; s=usp-google; h=date:from:to:cc:subject:message-id:mime-version:content-disposition :content-transfer-encoding; bh=LPuZL7++oiK3AKTEYNGUGNnkKUKEOaVSI1la1HbR00o=; b=fka0ul0BUfdhnVcBo1ENmq87Cad2QyqOfAPSd1MhKesS67N7GYB5RP4RW7muabK00X EfKWc4Dz8dE9UCAk9i5cRKFIES59lAm+6HS/Kp/6werbFT1eEkjjAQtNCasprLrdE5zX bUrA40WoTf5Mcis8WZ1sXspWdWUtLspbEzmfyKuSDiktjWlvbhyyza/tYSbqwi1HhGrG Bx+DlqiPKTGUD4DNVq4BZ5xsoC2qXcDypsha9S9oi6KLmOWE0BvwGyfEAJ1uei27NOtp VRHDZ1BbhBvx0NS7ltYwRI2rBl8TMmMZUBl4e2ZFmjQimY56ipdBOEkXCT6jdR+X7gFP HPRg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:from:to:cc:subject:message-id:mime-version :content-disposition:content-transfer-encoding; bh=LPuZL7++oiK3AKTEYNGUGNnkKUKEOaVSI1la1HbR00o=; b=Hr1irhOUQpuYzo1rKiEEKA12qSLknzWMqc9E/m7VVkoEqzSDhya7YQvCJjGvuxeVKG mODZWVNoPlowNqQsLDT2MqNGS2ONavBXl4LYSFVqdm8aHbBPPMTNgXF2siA/SQKiBYWk /KxckA/r2N5SVbWG9TOOM8T3IRnX3UEmehBOFm2soxE1i/grDa52uKaNsNbd31fIVjsF /82O+y2Qm0UhDIr+HrRM5/i7yw7rOerb+nQu/i6DRUXjLhVba6bDbLBM+KKbKZ5T4w/1 iB5HdWZn3NX3jE3jX+7MiGldWeR8TLIm/1sCXWVcWMUVS6V/TmqVdWAdINssRDr6xY8q +4NQ== X-Gm-Message-State: AOAM533XWDZ205P9NFyYvp4YmAS6dIlAFZk+CaRKo71G5uJjRmN0qilk VGTzHQBDxjhwimh60XZzP8+/Jg== X-Received: by 2002:a67:fc1a:: with SMTP id o26mr15817278vsq.23.1634323637365; Fri, 15 Oct 2021 11:47:17 -0700 (PDT) Received: from Andryuu.br ([2804:431:c7fd:7238:7ee3:38a1:5467:1c06]) by smtp.gmail.com with ESMTPSA id w27sm4256133vsi.25.2021.10.15.11.47.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Oct 2021 11:47:17 -0700 (PDT) Date: Fri, 15 Oct 2021 15:47:12 -0300 From: =?iso-8859-1?Q?Andr=E9?= Gustavo Nakagomi Lopez To: jic23@kernel.org, lars@metafoo.de, vz@mleia.com Cc: linux-iio@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, andregnl@usp.br Subject: [PATCH v2] iio: adc: lpc18xx_adc: Convert probe to device managed version Message-ID: MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The remove function and the goto sections are not necessary if devm functions are used. Convert device register to devm version. Add hook functions to release device resources, and use them inside probe with devm_add_action, which will release resources on driver detach. To maintain the order of which device resources were released/reseted, register the hook functions as soon as resources are obtained/initialized. Since devres actions are called on driver detach, the remove function and the error-handling goto sections are no longer necessary. Signed-off-by: Andr? Gustavo Nakagomi Lopez --- Change log V1 -> V2: -Renamed lpc18xx_clk_disable_unprepare function -Removed platform_set_drvdata(pdev, indio_dev) -Renamed lpc18xx_writel to lpc18xx_clear_cr_reg -devm_iio_device_register now returns directly in the end of probe function drivers/iio/adc/lpc18xx_adc.c | 61 ++++++++++++++++++----------------- 1 file changed, 31 insertions(+), 30 deletions(-) diff --git a/drivers/iio/adc/lpc18xx_adc.c b/drivers/iio/adc/lpc18xx_adc.c index 3566990ae87d..7d50107427ac 100644 --- a/drivers/iio/adc/lpc18xx_adc.c +++ b/drivers/iio/adc/lpc18xx_adc.c @@ -115,6 +115,23 @@ static const struct iio_info lpc18xx_adc_info = { .read_raw = lpc18xx_adc_read_raw, }; +static void lpc18xx_clear_cr_reg(void *data) +{ + struct lpc18xx_adc *adc = data; + + writel(0, adc->base + LPC18XX_ADC_CR); +} + +static void lpc18xx_clk_disable(void *clk) +{ + clk_disable_unprepare(clk); +} + +static void lpc18xx_regulator_disable(void *vref) +{ + regulator_disable(vref); +} + static int lpc18xx_adc_probe(struct platform_device *pdev) { struct iio_dev *indio_dev; @@ -127,7 +144,6 @@ static int lpc18xx_adc_probe(struct platform_device *pdev) if (!indio_dev) return -ENOMEM; - platform_set_drvdata(pdev, indio_dev); adc = iio_priv(indio_dev); adc->dev = &pdev->dev; mutex_init(&adc->lock); @@ -163,44 +179,30 @@ static int lpc18xx_adc_probe(struct platform_device *pdev) return ret; } + ret = devm_add_action_or_reset(&pdev->dev, lpc18xx_regulator_disable, adc->vref); + if (ret) + return ret; + ret = clk_prepare_enable(adc->clk); if (ret) { dev_err(&pdev->dev, "unable to enable clock\n"); - goto dis_reg; + return ret; } + ret = devm_add_action_or_reset(&pdev->dev, lpc18xx_clk_disable, + adc->clk); + if (ret) + return ret; + adc->cr_reg = (clkdiv << LPC18XX_ADC_CR_CLKDIV_SHIFT) | LPC18XX_ADC_CR_PDN; writel(adc->cr_reg, adc->base + LPC18XX_ADC_CR); - ret = iio_device_register(indio_dev); - if (ret) { - dev_err(&pdev->dev, "unable to register device\n"); - goto dis_clk; - } - - return 0; - -dis_clk: - writel(0, adc->base + LPC18XX_ADC_CR); - clk_disable_unprepare(adc->clk); -dis_reg: - regulator_disable(adc->vref); - return ret; -} - -static int lpc18xx_adc_remove(struct platform_device *pdev) -{ - struct iio_dev *indio_dev = platform_get_drvdata(pdev); - struct lpc18xx_adc *adc = iio_priv(indio_dev); - - iio_device_unregister(indio_dev); - - writel(0, adc->base + LPC18XX_ADC_CR); - clk_disable_unprepare(adc->clk); - regulator_disable(adc->vref); + ret = devm_add_action_or_reset(&pdev->dev, lpc18xx_clear_cr_reg, adc); + if (ret) + return ret; - return 0; + return devm_iio_device_register(&pdev->dev, indio_dev); } static const struct of_device_id lpc18xx_adc_match[] = { @@ -211,7 +213,6 @@ MODULE_DEVICE_TABLE(of, lpc18xx_adc_match); static struct platform_driver lpc18xx_adc_driver = { .probe = lpc18xx_adc_probe, - .remove = lpc18xx_adc_remove, .driver = { .name = "lpc18xx-adc", .of_match_table = lpc18xx_adc_match, -- 2.33.0