From: Sergii Kovalchuk <sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
To: Grant Likely <grant.likely-s3s/WqlpOiPyB63q8FvJNQ@public.gmane.org>
Cc: spi-devel-general-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org
Subject: Re: Assert CS, wait for IRQ, write data sequence
Date: Tue, 12 Oct 2010 20:29:51 +0300 [thread overview]
Message-ID: <201010122029.51617.sentinelofsetch@gmail.com> (raw)
In-Reply-To: <AANLkTi=PfdvuGrLth6wnptMvGDb47qQv4Dec4FZb2oxU-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
On Tuesday 12 October 2010 19:34:58 Grant Likely wrote:
> On Tue, Oct 12, 2010 at 10:22 AM, Sergii Kovalchuk
>
> <sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote:
> > On Tuesday 12 October 2010 03:51:10 Jassi Brar wrote:
> >> On Tue, Oct 12, 2010 at 1:22 AM, Sergii Kovalchuk
> >>
> >> <sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote:
> >> > On Thursday 07 October 2010 19:36:18 Grant Likely wrote:
> >> >> On Wed, Oct 6, 2010 at 7:49 AM, Sergii Kovalchuk
> >> >>
> >> >> > I'm implementing an SPI protocol driver for TI WL12xx combo chip.
> >> >> > According to the spec, for write transaction I should complete the
> >> >> > following sequence:
> >> >> >
> >> >> > 1. Assert CS
> >> >> > 2. Wait until chip will trigger IRQ
> >> >> > 3. Write data
> >> >> >
> >> >> > Looking at spi_transfer structure I wondering, how I can implement
> >> >> > such logic - there is no explicit ways to implement "wait for an
> >> >> > event" within single spi_message processing.
> >> >> >
> >> >> > As current workarround I use a simple delay in 5 us, but for sleep
> >> >> > states it might be not sufficient, since wake-up time are ususally
> >> >> > greater.
> >> >>
> >> >> Wow. That's nasty. The SPI layer really doesn't have a mechanism
> >> >> for handling that. What you *could* do is lock the spi bus; assert
> >> >> CS manually; wait for the irq, and then issue the transfer. Not
> >> >> exactly pretty, but it would work within the existing
> >> >> infrastructure.
> >> >>
> >> >> g.
> >> >
> >> > Yes, seems to be nasty. This is what I'm doing now - locking the bus
> >> > and waiting for IRQ, but this is really ugly. Just wondered, if there
> >> > is some hidden way.
> >> >
> >> > Not sure, if it more or less common situation. If so, may be it will
> >> > be worth to extend spi_tranfer to handle "timed wait for IRQ/event"
> >> > in some kind of busy loop or completion - depending of context?
> >>
> >> By constraints of your bus controller, you can't possibly do anything
> >> more useful than
> >> waiting 'decently'. After all, only one CS can be active at any time
> >> on the bus and
> >> your h/w expects that while it prepares to send/recv data.
> >> Or am I being naive?
> >
> > Almost certainly, there is no way to do something more useful. If I can
> > manually assert CS (and prevent controller from serving others), then
> > wait for IRQ, continue transfer and manually deassert CS (and unlock
> > controller) - it will work. But this moves some controller functionality
> > into protocol layer and probably needs some "improuvements" into
> > controller driver - to lock it.
>
> There is a new API for exclusively locking the SPI bus. Search for
> spi_bus_lock and spi_bus_unlock in Linus' current tree. It should do
> what you need. You'll still need to manually assert CS, and make sure
> that CS doesn't toggle when the transfer is initiated, but otherwise
> it should be good. The best thing might be to manage the CS as a
> simple gpio under the control of your driver and not let the bus touch
> it at all. As long as your driver holds the bus lock it should all be
> okay.
>
> g.
Thanks, I will look into it. Probably this is good answer on all these
questions, at least temporary.
--
Best regards,
Sergii Kovalchuk
------------------------------------------------------------------------------
Beautiful is writing same markup. Internet Explorer 9 supports
standards for HTML5, CSS3, SVG 1.1, ECMAScript5, and DOM L2 & L3.
Spend less time writing and rewriting code and more time creating great
experiences on the web. Be a part of the beta today.
http://p.sf.net/sfu/beautyoftheweb
prev parent reply other threads:[~2010-10-12 17:29 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-10-06 13:49 Assert CS, wait for IRQ, write data sequence Sergii Kovalchuk
[not found] ` <201010061649.45237.sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2010-10-07 16:36 ` Grant Likely
[not found] ` <AANLkTi=-v_fEX+TkBw8HA_KM2CPQUqbOzRy8vb3k6EAc-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-10-11 16:22 ` Sergii Kovalchuk
[not found] ` <201010111922.23952.sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2010-10-12 0:51 ` Jassi Brar
[not found] ` <AANLkTi=sognho1_nuZw2xJmOTXQ4MMudVwktX6CniM+w-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-10-12 16:22 ` Sergii Kovalchuk
[not found] ` <201010121922.36420.sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2010-10-12 16:34 ` Grant Likely
[not found] ` <AANLkTi=PfdvuGrLth6wnptMvGDb47qQv4Dec4FZb2oxU-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-10-12 17:29 ` Sergii Kovalchuk [this message]
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=201010122029.51617.sentinelofsetch@gmail.com \
--to=sentinelofsetch-re5jqeeqqe8avxtiumwx3w@public.gmane.org \
--cc=grant.likely-s3s/WqlpOiPyB63q8FvJNQ@public.gmane.org \
--cc=spi-devel-general-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@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.