[U-Boot] OMAP3 i2c issues on IGEP, u-boot 2013.10

Enric Balletbo Serra eballetbo at gmail.com
Wed Nov 27 18:12:00 CET 2013


Hi all,

2013/11/27 Nikita Kiryanov <nikita at compulab.co.il>:
> On 11/27/2013 06:10 PM, Thomas Petazzoni wrote:
>>
>> Dear Nikita Kiryanov,
>>
>> On Wed, 27 Nov 2013 17:52:31 +0200, Nikita Kiryanov wrote:
>>
>>> The zeroing of the cnt register also happens in other places in the
>>> driver, and it is entirely possible that they should be removed for
>>> OMAP3s as well.
>>>
>>> In my patch I removed it only for i2c_write() because the original
>>> driver also zeroed the cnt register in I/O functions- except in
>>> i2c_write(), and I decided to follow the original driver's lead.
>>>
>>> What happens if you remove all the lines that zero the cnt register?
>>
>>
>> It works. I've removed all the writew(0, ...cnt register...), and then
>> I've done at least 20 boots of the IGEP board, and all of them were
>> successful.
>>
>> I've attached the ugly patch that comments out all of those cases. Of
>> course, it's not a patch intended for merging, just to show which
>> locations I've commented.
>>
>> Since I've absolutely no idea of the background for the problem, would
>> you mind submitting a proper patch with a good explanation? I will be
>> happy to test it, of course.
>
>
> Sure. I'm about to leave office though, so I'll prepare it tomorrow.
>
>>
>> Thanks!
>>
>> Thomas
>>
>
>
> --
> Regards,
> Nikita.


Maybe I'm wrong but I think the problem could be related to that
OMAP3430 and OMAP3630 has a different I2C revision and current code
don't handle this correctly, As I know the I2C revision on OMAP3630
and OMAP4 is the same but different than OMAP3530. If the Tom's board
uses the OMAP3530 processor this will explain why he's not affected
for the issue. Others like me and Thomas, using DM3730, have the
problem because the driver do not handle this, it supposes that we're
using an OMAP3530.

See for example the following code in drivers/i2c/omap24xx_i2c.c,

#if defined(CONFIG_OMAP243X) || defined(CONFIG_OMAP34XX)
    /*
     * Have to enable interrupts for OMAP2/3, these IPs don't have
     * an 'irqstatus_raw' register and we shall have to poll 'stat'
     */
    writew(I2C_IE_XRDY_IE | I2C_IE_RRDY_IE | I2C_IE_ARDY_IE |
           I2C_IE_NACK_IE | I2C_IE_AL_IE, &i2c_base->ie);
#endif

This is right for OMAP34/35xx but not for OMAP36xx and AM/DM37xx

As a reference see the following patch introduced in the kernel:

commit f518b482c89b3ff51804f09c14b1cedbef811b84
Author: Jon Hunter <jon-hunter at ti.com>
Date:   Thu Jun 28 20:41:31 2012 +0530

    i2c: omap: Correct I2C revision for OMAP3

    The OMAP3530 is based upon the same silicon as the OMAP3430 and so the I2C
    revision is the same for 3430 and 3530. However, the OMAP3630 device has the
    same I2C revision as OMAP4. Correct the revision definition to reflect this.

    This patch is based on work done by Jon Hunter <jon-hunter at ti.com>
    Changes from his patch
    - Update OMAP_I2C_REV_ON_3430 also to reflect that it is same as 3530

    Reviewed-by: Felipe Balbi <balbi at ti.com>
    Signed-off-by: Jon Hunter <jon-hunter at ti.com>
    Signed-off-by: Shubhrajyoti D <shubhrajyoti at ti.com>
    Signed-off-by: Wolfram Sang <w.sang at pengutronix.de>

Best regards,
   Enric


More information about the U-Boot mailing list