From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jonathan Cameron Subject: Re: [PATCH 1/3] iio: adc: stm32: fix common clock rate Date: Sun, 23 Jul 2017 11:51:48 +0100 Message-ID: <20170723115148.07db4374@kernel.org> References: <1500381332-17086-1-git-send-email-fabrice.gasnier@st.com> <1500381332-17086-2-git-send-email-fabrice.gasnier@st.com> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <1500381332-17086-2-git-send-email-fabrice.gasnier-qxv4g6HH51o@public.gmane.org> Sender: devicetree-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: Fabrice Gasnier Cc: robh+dt-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org, linux-I+IVW8TIWO2tmTQ+vhA3Yw@public.gmane.org, mark.rutland-5wv7dgnIgG8@public.gmane.org, mcoquelin.stm32-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org, alexandre.torgue-qxv4g6HH51o@public.gmane.org, lars-Qo5EllUWu/uELgA04lAiVw@public.gmane.org, knaack.h-Mmb7MZpHnFY@public.gmane.org, pmeerw-jW+XmwGofnusTnJN9+BGXg@public.gmane.org, benjamin.gaignard-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org, benjamin.gaignard-qxv4g6HH51o@public.gmane.org, linux-iio-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org, linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org List-Id: devicetree@vger.kernel.org On Tue, 18 Jul 2017 14:35:30 +0200 Fabrice Gasnier wrote: > Fixes commit 95e339b6e85d ("iio: adc: stm32: add support for STM32H7") > > Fix common clock rate used then by stm32-adc sub-devices: take common > prescaler into account. > Fix ADC max clock rate on STM32H7 (fADC from datasheet) > > Signed-off-by: Fabrice Gasnier Patch itself is fine, but the description could do with information on what the result of this being wrong is. I have no idea if this is a patch I should be sending upstream asap or should hold for the next merge window. Thanks, Jonathan > --- > drivers/iio/adc/stm32-adc-core.c | 10 +++++----- > 1 file changed, 5 insertions(+), 5 deletions(-) > > diff --git a/drivers/iio/adc/stm32-adc-core.c b/drivers/iio/adc/stm32-adc-core.c > index e09233b..6096763 100644 > --- a/drivers/iio/adc/stm32-adc-core.c > +++ b/drivers/iio/adc/stm32-adc-core.c > @@ -64,7 +64,7 @@ > #define STM32H7_CKMODE_MASK GENMASK(17, 16) > > /* STM32 H7 maximum analog clock rate (from datasheet) */ > -#define STM32H7_ADC_MAX_CLK_RATE 72000000 > +#define STM32H7_ADC_MAX_CLK_RATE 36000000 > > /** > * stm32_adc_common_regs - stm32 common registers, compatible dependent data > @@ -148,14 +148,14 @@ static int stm32f4_adc_clk_sel(struct platform_device *pdev, > return -EINVAL; > } > > - priv->common.rate = rate; > + priv->common.rate = rate / stm32f4_pclk_div[i]; > val = readl_relaxed(priv->common.base + STM32F4_ADC_CCR); > val &= ~STM32F4_ADC_ADCPRE_MASK; > val |= i << STM32F4_ADC_ADCPRE_SHIFT; > writel_relaxed(val, priv->common.base + STM32F4_ADC_CCR); > > dev_dbg(&pdev->dev, "Using analog clock source at %ld kHz\n", > - rate / (stm32f4_pclk_div[i] * 1000)); > + priv->common.rate / 1000); > > return 0; > } > @@ -250,7 +250,7 @@ static int stm32h7_adc_clk_sel(struct platform_device *pdev, > > out: > /* rate used later by each ADC instance to control BOOST mode */ > - priv->common.rate = rate; > + priv->common.rate = rate / div; > > /* Set common clock mode and prescaler */ > val = readl_relaxed(priv->common.base + STM32H7_ADC_CCR); > @@ -260,7 +260,7 @@ static int stm32h7_adc_clk_sel(struct platform_device *pdev, > writel_relaxed(val, priv->common.base + STM32H7_ADC_CCR); > > dev_dbg(&pdev->dev, "Using %s clock/%d source at %ld kHz\n", > - ckmode ? "bus" : "adc", div, rate / (div * 1000)); > + ckmode ? "bus" : "adc", div, priv->common.rate / 1000); > > return 0; > } -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html