From: Stefan Roese <sr@denx.de>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH] i2c: mvtwsi: Fix problem with baud rate calculation
Date: Tue, 17 Mar 2015 12:25:19 +0100 [thread overview]
Message-ID: <55080F1F.9030803@denx.de> (raw)
In-Reply-To: <55080CD7.8040301@redhat.com>
Hi Hans,
On 17.03.2015 12:15, Hans de Goede wrote:
> On 17-03-15 11:08, Stefan Roese wrote:
>> The current implementation for baudrate calculation is incorrect.
>> This part from the formula:
>>
>> "2 ^ (n + 1)" is not equivalent to (1 << n) but to (2 << n)!
>>
>> This patch fixes this and moves this calculation to a function instead
>> of using a macro.
>
> Hmm, this does not match with what the Allwinner datasheets say:
> https://github.com/allwinner-zh/documents/blob/master/A20/A20%20user%20manual%20v1.3%2020141010.pdf
>
>
> They say:
>
> Fsamp = F 0 = Fin / 2^CLK_N
> F1 = F0 / (CLK_M + 1)
> Foscl = F1 / 10 = Fin / (2^CLK_N * (CLK_M + 1)*10)
>
> With Foscl being the ultimate i2c speed. Notice that they are talking about
> 2 ^ CLK_N not 2 ^ (CLK_N + 1)
>
> And they have a few examples which match this. Now it could be that a
> register value of 0 means CLK_N = 1, reg 1 CLK_N = 2, etc. this is not
> clearly
> specified ...
>
>> This new function is taken from the Linux kernel.
>
> Interesting, because on Allwinnner / sunxi devices we are using the kernel
> driver formula unmodified, and things seem to work fine despite this. Could
> be tolerances allowing this, could be the Allwinner datasheet being
> unclear.
>
> I've send allwinner a mail asking them to clarify this.
Good.
Here the complete formula from the A38x manual:
F_SCL = F_TCLK / (10 * (M + 1) * 2 ^ (N + 1))
>> This was detected and tested on the Marvell Armada A38x DB-88F6820-GP
>> eval board.
>
> So I take it you connected a memory oscilloscope to the i2c wires ?
No. I noticed that I2C doesn't work on this board with the current code.
And checked for differences to the Linux code. And with this change, I2C
does work on this board.
Thanks,
Stefan
next prev parent reply other threads:[~2015-03-17 11:25 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-03-17 10:08 [U-Boot] [PATCH] i2c: mvtwsi: Fix problem with baud rate calculation Stefan Roese
2015-03-17 11:15 ` Hans de Goede
2015-03-17 11:25 ` Stefan Roese [this message]
2015-03-17 12:20 ` Hans de Goede
2015-03-18 8:20 ` Hans de Goede
2015-03-18 8:21 ` Hans de Goede
2015-03-18 8:26 ` Stefan Roese
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=55080F1F.9030803@denx.de \
--to=sr@denx.de \
--cc=u-boot@lists.denx.de \
/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