Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp5735656ybi; Wed, 31 Jul 2019 02:31:02 -0700 (PDT) X-Google-Smtp-Source: APXvYqwBU7uq93oA6Hg2Gp2slnMk4vaYaIp+JHxoi2KxdAWArlx3zJAsBvh0EKl6dT29a49JlMdw X-Received: by 2002:a17:90a:3724:: with SMTP id u33mr1941677pjb.19.1564565461960; Wed, 31 Jul 2019 02:31:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564565461; cv=none; d=google.com; s=arc-20160816; b=BDqbT9M7II2y2hts5wdJhD1YcPKo08FGNzlCAgjn3gMJUK/+6hHOuhMbkLZWPy1/lX hoyb1TPw7BlVo6fyjNvhYjBCc57mR8ku8sJZDcx80HQ5/fU+DcjXZaZ5Lo3pLmjBGcYD BDiZukOE0KEzo1RVCOO4SrQf7tGiS3nLJFaSesGB9qk906/0ozQOW0OMq0lqUqkjikzM S79IgQqODntR/bkxUAZIbdN9UnLqFd22TASml0ETS6rQlVzkHgProEa9Pst5k4rHmlo5 44BsQJX0rL8evD7RYue1FatjcXFjr4iYKcGM5h1E0wCdFeauVe+yTT00RxWiHkA/ZWnH wXQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=dDGsJDiO11h7XHHU7rJdwPKBuK7odBXhzzst07dvwtg=; b=H7yDRej1RrVVstxQ/Q/kIWXLqBNoIMfIWzl47sHupYotsolZyhBP3HVfcaAzpeEH2Q ix889Tb85iA0MZPK0WUm7+jr98jHD00gyUrEQyXMruSQpN0K2aFJmSWb9PTy9Jjd9fUQ X60m7z74ZpfUXjmi+cuIDcio8eMBdeVy9gcHwluuawRZa9XtO1qeIrhJsJYrCvFD5qWG 6iDc4DYt2PoAHzCWXriU0D1NcnRKj7JmyR9XQJJJwzxZone9QjH+46i1TEWt82Frnu45 XVnIzJ8hr2X97XNaCQRCiEogsIng5pkvHGGp4/Pwd1BIYRK361SVMNgf5LPwo1AQoyt2 017Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@onstation.org header.s=default header.b=RA4VY+hy; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i9si29948496plt.387.2019.07.31.02.30.47; Wed, 31 Jul 2019 02:31:01 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@onstation.org header.s=default header.b=RA4VY+hy; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728425AbfGaJ25 (ORCPT + 99 others); Wed, 31 Jul 2019 05:28:57 -0400 Received: from onstation.org ([52.200.56.107]:45234 "EHLO onstation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727209AbfGaJ24 (ORCPT ); Wed, 31 Jul 2019 05:28:56 -0400 Received: from localhost (c-98-239-145-235.hsd1.wv.comcast.net [98.239.145.235]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: masneyb) by onstation.org (Postfix) with ESMTPSA id 608933E910; Wed, 31 Jul 2019 09:28:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=onstation.org; s=default; t=1564565335; bh=u/qIdrUUjq1FaYIdEEDKhkEXHmOBKALGw9ffBDa0lkM=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=RA4VY+hyr3qzD6yMvR7wssWRi28SHeHBC7t26nv2NbPOD7GH5QCyHx6h4se+vYRKO w/TU5JH7IGc2PWeIlZ2QsSnq57tKmEbFpvHjQtMNntRMW0iSGB9AzhW6Q5dwiJ1Om/ sMmA4tiuqWG7T3AtLMpOZUdKWpvADzYZb6wkLuqY= Date: Wed, 31 Jul 2019 05:28:54 -0400 From: Brian Masney To: Chuhong Yuan Cc: Jonathan Cameron , Hartmut Knaack , Lars-Peter Clausen , Peter Meerwald-Stadler , linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3 1/2] iio: tsl2772: Use device-managed API Message-ID: <20190731092854.GA19501@onstation.org> References: <20190731030415.8062-1-hslester96@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190731030415.8062-1-hslester96@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Chuhong, On Wed, Jul 31, 2019 at 11:04:15AM +0800, Chuhong Yuan wrote: > Use devm_() APIs to simplify the code. > > Signed-off-by: Chuhong Yuan There needs to be more of a changelog associated with this patch since this doesn't describe what all is done below. I see the following distinct three things that are done with this patch: - Use devm_add_action_or_reset to remove the call to tsl2772_disable_regulators_action to simplify the error path. - Use devm_add_action_or_reset to call tsl2772_chip_off when the device is removed. The changelog should also mention that this fixes an issue where the chip is turned off before the device is unregistered from the IIO subsystem. There should also be a Fixes tag and you can reference my patch that moved the driver out of staging as the commit that was fixed to make it easier for the folks that maintain the stable kernels. This issue most likely has been present since the driver was first introduced into mainline in 2012, however there were a large number commits that were needed in order to get this out of staging. - Use devm_iio_device_register, which removes the tsl2772_remove function. I would break this up further into three patches that are described above. The patches will be small but it makes it much easier on the maintainers who see a large number of patches come through. It helps to keep the git history in the kernel clean, which is very helpful to other developers. Brian > --- > Changes in v3: > - Split v2 into two patches. > > drivers/iio/light/tsl2772.c | 36 +++++++++++++++--------------------- > 1 file changed, 15 insertions(+), 21 deletions(-) > > diff --git a/drivers/iio/light/tsl2772.c b/drivers/iio/light/tsl2772.c > index 83cece921843..f1134f183be7 100644 > --- a/drivers/iio/light/tsl2772.c > +++ b/drivers/iio/light/tsl2772.c > @@ -860,6 +860,13 @@ static int tsl2772_chip_off(struct iio_dev *indio_dev) > return tsl2772_write_control_reg(chip, 0x00); > } > > +static void tsl2772_chip_off_action(void *data) > +{ > + struct iio_dev *indio_dev = data; > + > + tsl2772_chip_off(indio_dev); > +} > + > /** > * tsl2772_invoke_change - power cycle the device to implement the user > * parameters > @@ -1807,10 +1814,10 @@ static int tsl2772_probe(struct i2c_client *clientp, > return PTR_ERR(chip->vdd_supply); > } > > - ret = devm_add_action(&clientp->dev, tsl2772_disable_regulators_action, > + ret = devm_add_action_or_reset(&clientp->dev, > + tsl2772_disable_regulators_action, > chip); > if (ret < 0) { > - tsl2772_disable_regulators_action(chip); > dev_err(&clientp->dev, "Failed to setup regulator cleanup action %d\n", > ret); > return ret; > @@ -1877,15 +1884,14 @@ static int tsl2772_probe(struct i2c_client *clientp, > if (ret < 0) > return ret; > > - ret = iio_device_register(indio_dev); > - if (ret) { > - tsl2772_chip_off(indio_dev); > - dev_err(&clientp->dev, > - "%s: iio registration failed\n", __func__); > + ret = devm_add_action_or_reset(&clientp->dev, > + tsl2772_chip_off_action, > + indio_dev); > + > + if (ret < 0) > return ret; > - } > > - return 0; > + return devm_iio_device_register(&clientp->dev, indio_dev); > } > > static int tsl2772_suspend(struct device *dev) > @@ -1922,17 +1928,6 @@ static int tsl2772_resume(struct device *dev) > return tsl2772_chip_on(indio_dev); > } > > -static int tsl2772_remove(struct i2c_client *client) > -{ > - struct iio_dev *indio_dev = i2c_get_clientdata(client); > - > - tsl2772_chip_off(indio_dev); > - > - iio_device_unregister(indio_dev); > - > - return 0; > -} > - > static const struct i2c_device_id tsl2772_idtable[] = { > { "tsl2571", tsl2571 }, > { "tsl2671", tsl2671 }, > @@ -1979,7 +1974,6 @@ static struct i2c_driver tsl2772_driver = { > }, > .id_table = tsl2772_idtable, > .probe = tsl2772_probe, > - .remove = tsl2772_remove, > }; > > module_i2c_driver(tsl2772_driver); > -- > 2.20.1