All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Sudhakar Rajashekhara" <sudhakar.raj-l0cyMroinI0@public.gmane.org>
To: 'Jon Povey' <jon.povey-Ean/AyPsLtfkYMGBc/C6ZA@public.gmane.org>,
	linux-i2c-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	davinci-linux-open-source-VycZQUHpC/PFrsHnngEfi1aTQe2KTcn/@public.gmane.org
Subject: RE: [PATCH v3] i2c: davinci: Fix race when setting up for TX
Date: Fri, 17 Sep 2010 18:39:56 +0530	[thread overview]
Message-ID: <12552.912758156$1284729382@news.gmane.org> (raw)
In-Reply-To: <1284692531-10100-1-git-send-email-jon.povey-Ean/AyPsLtfkYMGBc/C6ZA@public.gmane.org>

Hi,

On Fri, Sep 17, 2010 at 08:32:11, Jon Povey wrote:
> When setting up to transmit, a race exists between the ISR and
> i2c_davinci_xfer_msg() trying to load the first byte and adjust counters.
> This is mostly visible for transmits > 1 byte long.
> 
> The hardware starts sending immediately that MDR is loaded. IMR trickery
> doesn't work because if we start sending, finish the first byte and an
> XRDY event occurs before we load IMR to unmask it, we never get an
> interrupt, and we timeout.
> 
> Move the MDR load after DXR,IMR loads to avoid this race without locking.
> 
> Tested on DM355 connected to Techwell TW2836 and Wolfson WM8985
> 

I remember I had some issues on OMAP-L138 with this fix, that's when I
reverted to configuring ICMDR before writing to DXR (Please see here:
https://patchwork.kernel.org/patch/75262/). I checked the BIOS I2C
driver code for OMAP-L138 and there also we are configuring MDR before
accessing DXR.

Regards,
Sudhakar

  parent reply	other threads:[~2010-09-17 13:09 UTC|newest]

Thread overview: 22+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-09-17  2:46 [PATCH v2] i2c: davinci: Fix race when setting up for TX Jon Povey
     [not found] ` <1284691607-9697-1-git-send-email-jon.povey-Ean/AyPsLtfkYMGBc/C6ZA@public.gmane.org>
2010-09-17  3:02   ` [PATCH v3] " Jon Povey
     [not found]     ` <1284692531-10100-1-git-send-email-jon.povey-Ean/AyPsLtfkYMGBc/C6ZA@public.gmane.org>
2010-09-17 13:09       ` Sudhakar Rajashekhara [this message]
     [not found]     ` <001201cb5669$a0200940$e0601bc0$@raj@ti.com>
     [not found]       ` <001201cb5669$a0200940$e0601bc0$@raj-l0cyMroinI0@public.gmane.org>
2010-09-17 19:15         ` Troy Kisky
     [not found]           ` <4C93BE5B.6090701-Q5RJGjKts06CY9SHAMCTRUEOCMrvLtNR@public.gmane.org>
2010-09-20  4:40             ` Jon Povey
     [not found]               ` <70E876B0EA86DD4BAF101844BC814DFE093ED5F50E-lPJtnb2sqtq44ywRPIzf9A@public.gmane.org>
2010-09-20 21:14                 ` Troy Kisky
     [not found]                   ` <4C97CEC9.8060602-Q5RJGjKts06CY9SHAMCTRUEOCMrvLtNR@public.gmane.org>
2010-09-21  4:13                     ` [PATCH v4] " Jon Povey
     [not found]                       ` <1285042408-13200-1-git-send-email-jon.povey-Ean/AyPsLtfkYMGBc/C6ZA@public.gmane.org>
2010-09-21 11:24                         ` Sudhakar Rajashekhara
2010-09-24  4:42                         ` Sudhakar Rajashekhara
     [not found]                       ` <026901cb597f$86fa9980$94efcc80$@raj@ti.com>
     [not found]                         ` <026901cb597f$86fa9980$94efcc80$@raj-l0cyMroinI0@public.gmane.org>
2010-09-21 19:17                           ` Troy Kisky
     [not found]                             ` <4C9904E6.7070608-Q5RJGjKts06CY9SHAMCTRUEOCMrvLtNR@public.gmane.org>
2010-09-22  0:09                               ` Ben Dooks
     [not found]                                 ` <20100922000916.GH7494-SMNkleLxa3Z6Wcw2j4pizdi2O/JbrIOy@public.gmane.org>
2010-09-22 10:50                                   ` Sudhakar Rajashekhara
2010-09-30 13:10                                   ` Kevin Hilman
     [not found]                                     ` <87wrq3l6m0.fsf-1D3HCaltpLuhEniVeURVKkEOCMrvLtNR@public.gmane.org>
2010-10-07  8:39                                       ` Jon Povey
     [not found]                                         ` <70E876B0EA86DD4BAF101844BC814DFE093EE3EA57-lPJtnb2sqtq44ywRPIzf9A@public.gmane.org>
2010-10-07 17:01                                           ` Kevin Hilman
     [not found]                                             ` <87wrpu9bsu.fsf-1D3HCaltpLuhEniVeURVKkEOCMrvLtNR@public.gmane.org>
2010-10-07 17:20                                               ` Kevin Hilman
     [not found]                                                 ` <87hbgxapig.fsf-1D3HCaltpLuhEniVeURVKkEOCMrvLtNR@public.gmane.org>
2010-10-12  4:48                                                   ` Jon Povey
2010-09-23 14:27                               ` Kevin Hilman
     [not found]                                 ` <87d3s47cx1.fsf-1D3HCaltpLuhEniVeURVKkEOCMrvLtNR@public.gmane.org>
2010-09-23 20:27                                   ` Troy Kisky
     [not found]                       ` <022501cb5ba2$d801d760$88058620$@raj@ti.com>
     [not found]                         ` <022501cb5ba2$d801d760$88058620$@raj-l0cyMroinI0@public.gmane.org>
2010-09-24 14:37                           ` Kevin Hilman
     [not found]                             ` <87sk0zky28.fsf-1D3HCaltpLuhEniVeURVKkEOCMrvLtNR@public.gmane.org>
2010-09-24 16:37                               ` Ben Dooks
     [not found]                                 ` <20100924163754.GH27885-SMNkleLxa3Z6Wcw2j4pizdi2O/JbrIOy@public.gmane.org>
2010-09-27 14:16                                   ` Kevin Hilman

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='12552.912758156$1284729382@news.gmane.org' \
    --to=sudhakar.raj-l0cymroini0@public.gmane.org \
    --cc=davinci-linux-open-source-VycZQUHpC/PFrsHnngEfi1aTQe2KTcn/@public.gmane.org \
    --cc=jon.povey-Ean/AyPsLtfkYMGBc/C6ZA@public.gmane.org \
    --cc=linux-i2c-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.