From: Grant Likely <grant.likely-s3s/WqlpOiPyB63q8FvJNQ@public.gmane.org>
To: Sergii Kovalchuk
<sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@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 10:34:58 -0600 [thread overview]
Message-ID: <AANLkTi=PfdvuGrLth6wnptMvGDb47qQv4Dec4FZb2oxU@mail.gmail.com> (raw)
In-Reply-To: <201010121922.36420.sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
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.
------------------------------------------------------------------------------
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
next prev parent reply other threads:[~2010-10-12 16:34 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 [this message]
[not found] ` <AANLkTi=PfdvuGrLth6wnptMvGDb47qQv4Dec4FZb2oxU-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-10-12 17:29 ` Sergii Kovalchuk
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='AANLkTi=PfdvuGrLth6wnptMvGDb47qQv4Dec4FZb2oxU@mail.gmail.com' \
--to=grant.likely-s3s/wqlpoipyb63q8fvjnq@public.gmane.org \
--cc=sentinelofsetch-Re5JQEeQqe8AvxtiuMwx3w@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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).