devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Matti Vaittinen <mazziesaccount@gmail.com>
To: Subhajit Ghosh <subhajit.ghosh@tweaklogic.com>,
	Jonathan Cameron <jic23@kernel.org>,
	Lars-Peter Clausen <lars@metafoo.de>,
	Andy Shevchenko <andriy.shevchenko@linux.intel.com>,
	Rob Herring <robh+dt@kernel.org>,
	Krzysztof Kozlowski <krzysztof.kozlowski+dt@linaro.org>
Cc: linux-iio@vger.kernel.org, devicetree@vger.kernel.org,
	linux-kernel@vger.kernel.org, Paul Gazzillo <paul@pgazz.com>,
	Conor Dooley <conor+dt@kernel.org>,
	Stefan Windfeldt-Prytz <stefan.windfeldt-prytz@axis.com>
Subject: Re: [PATCH 2/2] iio: light: Add support for APDS9306 Light Sensor
Date: Tue, 10 Oct 2023 12:45:15 +0300	[thread overview]
Message-ID: <ae210957-4a72-24b3-2f11-8d5824041e85@gmail.com> (raw)
In-Reply-To: <20231008154857.24162-3-subhajit.ghosh@tweaklogic.com>

On 10/8/23 18:48, Subhajit Ghosh wrote:
> Driver support for Avago (Broadcom) APDS9306
> Ambient Light Sensor with als and clear channels.
> This driver exposes raw values for both the channels and
> processed(lux) values for the als channel.
> Support for both with or without hardware interrupt
> configurations are provided.
> 
> Datasheet at https://docs.broadcom.com/doc/AV02-4755EN
> 
> Signed-off-by: Subhajit Ghosh <subhajit.ghosh@tweaklogic.com>

Hi Subhajit,

To my eyes this driver looks nice. Just spotted two minor things.

> ---
>   drivers/iio/light/Kconfig    |   12 +
>   drivers/iio/light/Makefile   |    1 +
>   drivers/iio/light/apds9306.c | 1381 ++++++++++++++++++++++++++++++++++
>   3 files changed, 1394 insertions(+)
>   create mode 100644 drivers/iio/light/apds9306.c
> 
...

> +
> +static int apds9306_intg_time_set(struct apds9306_data *data, int val2)
> +{
> +	struct device *dev = data->dev;
> +	int ret, intg_old, gain_old, gain_new, gain_new_closest;
> +	bool ok;
> +
> +	if (!iio_gts_valid_time(&data->gts, val2)) {
> +		dev_err(dev, "Unsupported integration time %u\n", val2);
> +		return ret;
> +	}
> +
> +	intg_old = iio_gts_find_int_time_by_sel(&data->gts,
> +						data->intg_time_idx);
> +	if (ret < 0)
> +		return ret;
> +
> +	if (intg_old == val2)
> +		return 0;
> +
> +	gain_old = iio_gts_find_gain_by_sel(&data->gts, data->gain_idx);
> +	if (gain_old < 0)
> +		return gain_old;
> +
> +	ret = iio_gts_find_new_gain_by_old_gain_time(&data->gts, gain_old,
> +				intg_old, val2, &gain_new);
> +	if (gain_new < 0) {
> +		dev_err(dev, "Unsupported gain with time\n");
> +		return gain_new;
> +	}
> +
> +	gain_new_closest = iio_find_closest_gain_low(&data->gts, gain_new, &ok);
> +	if (gain_new_closest < 0) {
> +		gain_new_closest = iio_gts_get_min_gain(&data->gts);
> +		if (gain_new_closest < 0)
> +			return gain_new_closest < 0;

Returning the truth value on purpose? :)

> +	}
> +	if (!ok)
> +		dev_dbg(dev, "Unable to find optimum gain, setting minimum");
> +
> +	ret = iio_gts_find_sel_by_int_time(&data->gts, val2);
> +	if (ret < 0)
> +		return ret;
> +
> +	ret = apds9306_intg_time_set_hw(data, ret);
> +	if (ret)
> +		return ret;
> +
> +	ret = iio_gts_find_sel_by_gain(&data->gts, gain_new_closest);
> +	if (ret < 0)
> +		return ret;
> +
> +	return apds9306_gain_set_hw(data, ret);
> +}

...

> +static int get_device_id_lux_per_count(struct apds9306_data *data)
> +{
> +	int ret, part_id;
> +
> +	ret = regmap_read(data->regmap, APDS9306_PART_ID, &part_id);
> +	if (ret)
> +		return ret;
> +
> +	if (part_id == apds9306_part_id_nlux_per_count[0].part_id)
> +		data->nlux_per_count =
> +			apds9306_part_id_nlux_per_count[0].nlux_per_count;
> +	else if (part_id == apds9306_part_id_nlux_per_count[1].part_id)
> +		data->nlux_per_count =
> +			apds9306_part_id_nlux_per_count[1].nlux_per_count;
> +	else
> +		return -ENXIO;

I think we should be able to differentiate between the IC variants by DT 
compatible. (Commented that on bindings patch). Not sure if we need to 
support cases where the sensor is instantiated without device-tree. I am 
not super happy when code requires the part-id to be known if we have 
separate compatibles for variants. Can we in dt-case just print a 
warning if the part-ID is not what we expect - and proceed assuming the 
nlux_per_count based on the DT information? (Sometimes we see new 
variants with same part-IDs - or many part-IDs with no SW changes 
needed. Hence maintaining the part-ID lists may be tedious). This is 
just some pondering though, no strong requirements from my side

> +
> +	return 0;
> +}
> +

Yours,
	-- Matti

-- 
Matti Vaittinen
Linux kernel developer at ROHM Semiconductors
Oulu Finland

~~ When things go utterly wrong vim users can always type :help! ~~


  reply	other threads:[~2023-10-10  9:45 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-10-08 15:48 [PATCH 0/2] Support for Avago APDS9306 Ambient Light Sensor Subhajit Ghosh
2023-10-08 15:48 ` [PATCH 1/2] dt-bindings: iio: light: Avago APDS9306 Subhajit Ghosh
2023-10-09  8:36   ` Krzysztof Kozlowski
2023-10-09 11:25     ` Subhajit Ghosh
2023-10-10  8:52   ` Matti Vaittinen
2023-10-10 12:18     ` Subhajit Ghosh
2023-10-10 14:49       ` Jonathan Cameron
2023-10-10 16:19     ` Rob Herring
2023-10-11 13:04       ` Subhajit Ghosh
2023-10-10 13:51   ` Jonathan Cameron
2023-10-11 13:10     ` Subhajit Ghosh
2023-10-08 15:48 ` [PATCH 2/2] iio: light: Add support for APDS9306 Light Sensor Subhajit Ghosh
2023-10-10  9:45   ` Matti Vaittinen [this message]
2023-10-10 12:17     ` Subhajit Ghosh
2023-10-10 14:38   ` Jonathan Cameron
2023-10-11 14:37     ` Subhajit Ghosh
2023-10-12  7:54       ` Jonathan Cameron
2023-10-12 12:37         ` Subhajit Ghosh

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=ae210957-4a72-24b3-2f11-8d5824041e85@gmail.com \
    --to=mazziesaccount@gmail.com \
    --cc=andriy.shevchenko@linux.intel.com \
    --cc=conor+dt@kernel.org \
    --cc=devicetree@vger.kernel.org \
    --cc=jic23@kernel.org \
    --cc=krzysztof.kozlowski+dt@linaro.org \
    --cc=lars@metafoo.de \
    --cc=linux-iio@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=paul@pgazz.com \
    --cc=robh+dt@kernel.org \
    --cc=stefan.windfeldt-prytz@axis.com \
    --cc=subhajit.ghosh@tweaklogic.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).