Thread (9 messages) 9 messages, 4 authors, 2009-07-01

Re: RapidIO - general questions

From: Jan Neskudla <hidden>
Date: 2009-05-15 07:33:52
Also in: lkml

On Wed, 2009-05-13 at 18:57 +0800, ext Li Yang wrote:
cc'ed LKML

On Tue, May 12, 2009 at 5:17 PM, Jan Neskudla [off-list ref] wrote:
quoted
Hallo

we'd likes to use a RapidIO as a general communication bus on our new
product, and so I have some questions about general design of Linux RIO
subsystem. I did not find any better mailing list for RapidIO
discussion.

[1] - we'd like to implement following features
   * Hot-plug (hot-insert/hot-remove) of devices
   * Error handling (port-write packets - configuration, handling of
them)
   * Static ID configuration based on port numbers
   * Aux driver - basic driver, for sending messages over different
mboxes, handling ranges of doorbells

   Is it here anyone who is working on any improvement, or anyone who
knows the development plans for RapidIO subsystem?
AFAIK, there is no one currently working on these features for Linux.
It will be good if you can add these useful features.
Yes it looks like that, currently we are analyzing current rapidIO
system, and how we can add these features. 
quoted
[2] - I have a following problem with a current implementation of
loading drivers. The driver probe-function call is based on comparison
of VendorID (VID) and DeviceID (DID) only. Thus if I have 3 devices with
same DID and VID connected to the same network (bus), the driver is
loaded 3times, instead only once for the actual device Master port.
This should be the correct way as you actually have 3 instances of the device.
quoted
Rionet driver solved this by enabling to call initialization function
just once, and it expect that this is the Master port.
Rionet is kind of special.  It's not working like a simple device
driver, but more like a customized protocol stack to support multiple
ethernet over rio links.
quoted
Is it this correct behavior  ? It looks to me that RapidIO is handled
like a local bus (like PCI)
This is correct behavior.  All of them are using Linux device/driver
infrastructure, but rionet is a special device.
But I do not have a 3 devices on one silicon. I am talking about 3
devices (3 x EP8548 boards + IDT switch) connected over rapidIO through
the switch. And in this case I'd like to have only one driver siting on
the top of Linux RapidIO subsystem. I don't see the advantage of loading
a driver locally for remote device. Am I missing something  ?

And one more think, I am getting so much Bus errors OOPSes. Whenever
there is a problem with a comunication over Rio I get such a kernel OPS.
I had to add some delays into some function to be able to finish the
enum+discovery process. Did you have some experience with some bigger
rio network running under linux ? 


                Jan 
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help