From: "Albrecht Dreß" <albrecht.dress@arcor.de>
To: John Bonesio <bones@secretlab.ca>
Cc: linuxppc-dev@ozlabs.org
Subject: Re: [PATCH] powerpc/5200: add LocalPlus bus FIFO device driver
Date: Thu, 01 Oct 2009 21:31:25 +0200 [thread overview]
Message-ID: <1254425492.3252.0@antares> (raw)
In-Reply-To: <1254422721.689.0.camel@riker> (from bones@secretlab.ca on Thu Oct 1 20:45:21 2009)
[-- Attachment #1: Type: text/plain, Size: 2527 bytes --]
Hi John:
Am 01.10.09 20:45 schrieb(en) John Bonesio:
> Nowhere in the text does it say 0 and 1 are the only possible values.
> And since GR is a 3 bit field instead of a 1 bit field, that implied
> that to me that other values are allowed.
>
> I can see how one could read the text as saying 0 and 1 are the only
> values allowed. However, empirical the testing I've done, seems to
> indicate that the '7' is a valid value, as it produced different
> behavior than 1.
Thanks for the clarification!
> I've put in the suggested change to set the 'flush' bit. It didn't
> seem to help. I'm not sure what else might be different between my
> system and yours.
My board is a self-designed one, roughly Icecube-based, with a 5200B.
The peripheral (actually a second processor) is attached in 16-bit mode
to the LPB. The main data flow goes to the 5200, so I have only a task
for reading data. As the block transfer is only one part (but with a
huge block size) in a transaction, I allocate only one block for the
task, i.e. I call bcom_gen_bd_rx_init(1, ...).
The transaction size is always a multiple of 4 bytes, and I use the
same value for the FIFO packet size and struct bcom_bd::status. In the
Control reg, I set CS, BPT=4, DAI, RWb and Flush. I can isolate the
code launching Bestcomm if you're interested.
I ran some further tests today, which are a little confusing...
When a Bestcomm IRQ arrives, the call to bcom_buffer_done() (in the
isr) will always return 0. If I just ignore that, and call
bcom_retrieve_buffer() anyway, the status value will also be 0.
However, the data block is transferred completely, and it is correct (I
separately transmit a crc32, which matches, and the data block itself
looks fine). Actually, I'm not really sure what this means...
BTW, I noticed that the Bestcomm IRQ arrives *before* the FIFO IRQ,
which IMHO is a little unlogical. It may be a result of setting the
granularity to 0 and the FIFO Alarm level to 4 (which should trigger
Bestcomm only if one u32 is free in the FIFO - is that correct? At
least the drawing on Pg. 11 in Freescale's AN2604 implies that.).
> We were testing using the Bestcomm on a framebuffer to refresh the
> display. Without the watermarks, the DMA was getting clogged.
I see. In my case, only the /overall/ time and cpu load for the
transaction are critical, and there I didn't notice significant
differences.
Cheers,
Albrecht.
[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
prev parent reply other threads:[~2009-10-01 19:31 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-09-29 20:43 [PATCH] powerpc/5200: add LocalPlus bus FIFO device driver John Bonesio
2009-09-30 2:25 ` Grant Likely
2009-09-30 18:34 ` Albrecht Dreß
2009-10-01 18:45 ` John Bonesio
2009-10-01 19:31 ` Albrecht Dreß [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=1254425492.3252.0@antares \
--to=albrecht.dress@arcor.de \
--cc=bones@secretlab.ca \
--cc=linuxppc-dev@ozlabs.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).