Received: by 10.223.176.5 with SMTP id f5csp4024280wra; Tue, 30 Jan 2018 00:37:36 -0800 (PST) X-Google-Smtp-Source: AH8x224gb71vaSbSUWzyC1/rj/GLF+B2UClslduGEJ50W3Bi6vKWRmNgnCAcPp9IUfrZCdJ338qR X-Received: by 2002:a17:902:b496:: with SMTP id y22-v6mr4372879plr.206.1517301456500; Tue, 30 Jan 2018 00:37:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517301456; cv=none; d=google.com; s=arc-20160816; b=ulRAoybmZueXAH3wsJF95nuUr/r9/xx69FOWjWH4pVdaIPbD4g/BQNryQbJpQtGdqm 0KJ6DV4TSHxc2KlTU9e0h2W0EjC2/nvR59///uXSLJjX0vz2Qz9CJVP0tzTUcK/yMcfj jy+PfGb+u+Lax7PahFHjQnca2tvojUbpjD/XaL1sydzcxeiNU2CbdmRXzkjd6ostd64B eMvTTMWVDhk+QBmKP5C4fGvIgAtFcMz5ywtZtP6UTb0eOuHe0LLZ7UgfMtg8b4mFWE06 BCpElotNFqVewEjvtO0tXVf6HukTMI29NwZ4gXgLtd1LFm2eJhnFgtm4d64jbgnsrnZ/ Tfcw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=dVuM5+Q+TiRNTqfFT/Rw3VAjwKSt93bDBMhgV+at1IY=; b=MXp6arKWoc9HVaqOkoEsPwZJnphgKiWUCZI5DoC4BcCFKAdC2DzT0Kwj21xp9l7XZe jwS5X3iME6BQ2mr3RvkgfhkImuuseiQtKiB62aZTvwU+oVn47SEsMGLTS8peDDtcAHqW Byl9Ljssd7DU9dIMniGHxFQuWnfdxfTZlLgOROO/kCJOQLjwfAAnE3Pxe0iOVsGNy2M2 jVlO0F9GHYIP1t1QA+XWLpGO77dIkv1lr/LHz6zAWxD/iEDeaXlU9DaT/xrojTyKuach nYcCCd4bQ46XedrRbq8XmqVf8PCI5PWaiPlgdbUCp/xxGFJpxYFhual70jybfRPfw0s/ im3A== ARC-Authentication-Results: i=1; mx.google.com; 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 z20-v6si1338692plo.73.2018.01.30.00.37.21; Tue, 30 Jan 2018 00:37:36 -0800 (PST) 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; 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 S1751931AbeA3Ig4 (ORCPT + 99 others); Tue, 30 Jan 2018 03:36:56 -0500 Received: from mail.free-electrons.com ([62.4.15.54]:33169 "EHLO mail.free-electrons.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751511AbeA3Igz (ORCPT ); Tue, 30 Jan 2018 03:36:55 -0500 Received: by mail.free-electrons.com (Postfix, from userid 110) id 1DA722198F; Tue, 30 Jan 2018 09:36:53 +0100 (CET) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.free-electrons.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT, URIBL_BLOCKED shortcircuit=ham autolearn=disabled version=3.4.0 Received: from localhost (LStLambert-657-1-97-87.w90-63.abo.wanadoo.fr [90.63.216.87]) by mail.free-electrons.com (Postfix) with ESMTPSA id D3AC320EB9; Tue, 30 Jan 2018 09:36:42 +0100 (CET) Date: Tue, 30 Jan 2018 09:36:43 +0100 From: Maxime Ripard To: Philipp Rossak Cc: lee.jones@linaro.org, robh+dt@kernel.org, mark.rutland@arm.com, wens@csie.org, linux@armlinux.org.uk, jic23@kernel.org, knaack.h@gmx.de, lars@metafoo.de, pmeerw@pmeerw.net, davem@davemloft.net, hans.verkuil@cisco.com, mchehab@kernel.org, rask@formelder.dk, clabbe.montjoie@gmail.com, sean@mess.org, krzk@kernel.org, quentin.schulz@free-electrons.com, icenowy@aosc.io, edu.molinas@gmail.com, singhalsimran0@gmail.com, linux-iio@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-sunxi@googlegroups.com Subject: Re: [PATCH v2 07/16] iio: adc: sun4i-gpadc-iio: rework: support nvmem calibration data Message-ID: <20180130083642.cdpd7jnthkdrrk5r@flea.lan> References: <20180128232919.12639-1-embed3d@gmail.com> <20180128232919.12639-8-embed3d@gmail.com> <20180129094045.sagz2dnzvdadd4yx@flea.lan> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha256; protocol="application/pgp-signature"; boundary="6u2ivkblyv2lastj" Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20171215 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --6u2ivkblyv2lastj Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Mon, Jan 29, 2018 at 01:33:12PM +0100, Philipp Rossak wrote: > > > static const struct gpadc_data sun4i_gpadc_data =3D { > > > @@ -87,6 +89,7 @@ static const struct gpadc_data sun4i_gpadc_data =3D= { > > > .sample_start =3D sun4i_gpadc_sample_start, > > > .sample_end =3D sun4i_gpadc_sample_end, > > > .sensor_count =3D 1, > > > + .supports_nvmem =3D false, > >=20 > > That's already its value if you leave it out. > >=20 > > > }; > > > static const struct gpadc_data sun5i_gpadc_data =3D { > > > @@ -100,6 +103,7 @@ static const struct gpadc_data sun5i_gpadc_data = =3D { > > > .sample_start =3D sun4i_gpadc_sample_start, > > > .sample_end =3D sun4i_gpadc_sample_end, > > > .sensor_count =3D 1, > > > + .supports_nvmem =3D false, > > > }; > > > static const struct gpadc_data sun6i_gpadc_data =3D { > > > @@ -113,6 +117,7 @@ static const struct gpadc_data sun6i_gpadc_data = =3D { > > > .sample_start =3D sun4i_gpadc_sample_start, > > > .sample_end =3D sun4i_gpadc_sample_end, > > > .sensor_count =3D 1, > > > + .supports_nvmem =3D false, > > > }; > > > static const struct gpadc_data sun8i_a33_gpadc_data =3D { > > > @@ -123,6 +128,7 @@ static const struct gpadc_data sun8i_a33_gpadc_da= ta =3D { > > > .sample_start =3D sun4i_gpadc_sample_start, > > > .sample_end =3D sun4i_gpadc_sample_end, > > > .sensor_count =3D 1, > > > + .supports_nvmem =3D false, > > > }; > > > struct sun4i_gpadc_iio { > > > @@ -141,6 +147,8 @@ struct sun4i_gpadc_iio { > > > struct clk *mod_clk; > > > struct reset_control *reset; > > > int sensor_id; > > > + u32 calibration_data[2]; > > > + bool has_calibration_data[2]; > >=20 > > Why do you have two different values here? >=20 > I think my idea was too complex! I thought it would be better to check if > calibration data was read, and is able to be written to hardware. those > information were split per register. >=20 > I think a u64 should be fine for calibration_data. When I write the > calibration data I can check on the sensor count and write only the lower= 32 > bits if there are less than 3 sensors. >=20 > Is this ok for you? I'd need to see the implementation, but make sure that this is documented in your driver :) >=20 > > > /* prevents concurrent reads of temperature and ADC */ > > > struct mutex mutex; > > > struct thermal_zone_device *tzd; > > > @@ -561,6 +569,9 @@ static int sun4i_gpadc_probe_dt(struct platform_d= evice *pdev, > > > struct resource *mem; > > > void __iomem *base; > > > int ret; > > > + struct nvmem_cell *cell; > > > + ssize_t cell_size; > > > + u64 *cell_data; > > > info->data =3D of_device_get_match_data(&pdev->dev); > > > if (!info->data) > > > @@ -575,6 +586,39 @@ static int sun4i_gpadc_probe_dt(struct platform_= device *pdev, > > > if (IS_ERR(base)) > > > return PTR_ERR(base); > > > + info->has_calibration_data[0] =3D false; > > > + info->has_calibration_data[1] =3D false; > > > + > > > + if (!info->data->supports_nvmem) > > > + goto no_nvmem; > > > + > > > + cell =3D nvmem_cell_get(&pdev->dev, "calibration"); > > > + if (IS_ERR(cell)) { > > > + if (PTR_ERR(cell) =3D=3D -EPROBE_DEFER) > > > + return PTR_ERR(cell); > > > + goto no_nvmem; > >=20 > > goto considered evil ? :) >=20 > this was a suggestion from Jonatan in version one, to make the code better > readable. Isn't if (info->data->supports_nvmem && IS_ERR(cell =3D nvmem_cell_get())) pretty much the same thing? Maxime --=20 Maxime Ripard, Free Electrons Embedded Linux and Kernel engineering http://free-electrons.com --6u2ivkblyv2lastj Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEE0VqZU19dR2zEVaqr0rTAlCFNr3QFAlpwLpoACgkQ0rTAlCFN r3QLSBAAjLwO1WgXEafxyjZ1raD52wYT6bCKca9SN7NRbNNAmWedkHabwdrhTOMH FJ8TrkYaZGYI7dK3cMCHrs6tNc1iaXCyGJsB1HYLO1quYLMI03qcSTJ88jI+gSFM 0EBtgsa+PWx7QrbCIfWt4UmVtF9c+MdQJSLFfiz3b2SaIf2Ut2lpnCKEPFRCYWID CF2N60cUuxTcbUtUvuHyOsxTrWxCt8fq1L0OOdYL2vhsfUAgZaMI9q69cWxEbKK1 c6BnCfe+/Ld4P37J3ptPcpsK5sa5sP99Ek0nbABvxSQrHqx3WxWBqYsl3NaBzr6L yyuPbjVH5Cd6pladYr2wohiuY4/0vMwSsC2y9GxhD6CgSJ7xVd+AoMES6KJUHZY0 okd+cwKF4xEOCJj55TORVUjiuYPO7xOXoy/w4YWJqXHUA8apueHonYpt4fe3bhgn 6/93z400uEgyjh246FOvehEz7aH+oX/ZPUa2MIOrBMUPSCtPuwQSNkpvaehl913r JJJ5vY3kJMoWQtBJVe9big5Pln2PZYoztPS/UrXjVmTQBSPoCsdCWk7/wX/LtdAw w39OVaWV4zL7HZFpYaOYBNJjlc/h3w9zzXmxQruuP10rp7yrSUnAw1XYYLVu0t4v jlfjeyTlqPaz3LcKcOE0yn+MmgmXSt0OM13oTRu1O4sqVFGTTXQ= =nsrh -----END PGP SIGNATURE----- --6u2ivkblyv2lastj--