[PATCH] fix mpc83xx spi prescale modulus calculate

Anton Vorontsov avorontsov at ru.mvista.com
Fri Jun 20 22:28:20 EST 2008


On Fri, Jun 20, 2008 at 05:38:17PM +0800, Chen Gong wrote:
> Signed-off-by: Chen Gong <g.chen at freescale.com>

The patch lacks any description. E.g. at which frequencies the current
math breaks, and why?

> ---
>  drivers/spi/spi_mpc83xx.c |   29 ++++++++++++++++-------------
>  1 files changed, 16 insertions(+), 13 deletions(-)
> 
> diff --git a/drivers/spi/spi_mpc83xx.c b/drivers/spi/spi_mpc83xx.c
> index 6832da6..070c621 100644
> --- a/drivers/spi/spi_mpc83xx.c
> +++ b/drivers/spi/spi_mpc83xx.c
> @@ -266,21 +266,24 @@ int mpc83xx_spi_setup_transfer(struct spi_device *spi, struct spi_transfer *t)
>  
>  	cs->hw_mode |= SPMODE_LEN(bits_per_word);
>  
> -	if ((mpc83xx_spi->spibrg / hz) >= 64) {
> -		pm = mpc83xx_spi->spibrg / (hz * 64) - 1;
> -		if (pm > 0x0f) {
> -			dev_err(&spi->dev, "Requested speed is too "
> -				"low: %d Hz. Will use %d Hz instead.\n",
> -				hz, mpc83xx_spi->spibrg / 1024);
> -			pm = 0x0f;
> +	if ((mpc83xx_spi->spibrg / hz) > 64) {
> +		pm = mpc83xx_spi->spibrg / (hz * 64);
> +		if (pm > 16) {

Suppose this didn't happen. So we calculated:
pm = mpc83xx_spi->spibrg / (hz * 64);
And we didn't set any hw flag.

> +			cs->hw_mode |= SPMODE_DIV16;
> +			pm /= 16;
> +			if (pm > 16) {
> +				dev_err(&spi->dev, "Requested speed is too "
> +					"low: %d Hz. Will use %d Hz instead.\n",
> +					hz, mpc83xx_spi->spibrg / 1024);
> +				pm = 16;
> +			}
>  		}
> -		cs->hw_mode |= SPMODE_PM(pm) | SPMODE_DIV16;
> -	} else {
> +	} else
>  		pm = mpc83xx_spi->spibrg / (hz * 4);

Now suppose this did happen. So we calculated:
pm = mpc83xx_spi->spibrg / (hz * 4);
And we didn't set any hw flag either.

So, we used two different formulas with the same hw flags.

Maybe I'm missing something, but this looks quite wrong.

> -		if (pm)
> -			pm--;
> -		cs->hw_mode |= SPMODE_PM(pm);
> -	}
> +	if (pm)
> +		pm--;
> +
> +	cs->hw_mode |= SPMODE_PM(pm);
>  	regval =  mpc83xx_spi_read_reg(&mpc83xx_spi->base->mode);
>  	if (cs->hw_mode != regval) {
>  		unsigned long flags;
> -- 
> 1.5.4

-- 
Anton Vorontsov
email: cbouatmailru at gmail.com
irc://irc.freenode.net/bd2



More information about the Linuxppc-dev mailing list