[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <201511021916.18117.marex@denx.de>
Date: Mon, 2 Nov 2015 19:16:18 +0100
From: Marek Vasut <marex@...x.de>
To: Oliver Hartkopp <socketcan@...tkopp.net>
Cc: "Marc Kleine-Budde" <mkl@...gutronix.de>, netdev@...r.kernel.org,
"David S. Miller" <davem@...emloft.net>,
Wolfgang Grandegger <wg@...ndegger.com>,
Andrew Lunn <andrew@...n.ch>,
Andrey Vostrikov <andrey.vostrikov@...entembedded.com>
Subject: Re: [RFC][PATCH] net: arinc429: Add ARINC-429 stack
On Monday, November 02, 2015 at 12:14:27 PM, Oliver Hartkopp wrote:
> On 02.11.2015 10:47, Marc Kleine-Budde wrote:
> > On 11/02/2015 12:16 AM, Marek Vasut wrote:
> >> The ARINC-429 is a technical standard, which describes, among others,
> >> a data bus used by airplanes. The standard contains much more, since
> >> it is based off the ISO/OSI model, but this patch implements just the
> >> data bus protocol.
> >>
> >> This stack is derived from the SocketCAN implementation, already present
> >> in the kernel and thus behaves in a very similar fashion. Thus far, we
> >> support sending RAW ARINC-429 datagrams, configuration of the RX and TX
> >> clock speed and filtering.
> >>
> >> The ARINC-429 datagram is four-byte long. The first byte is always the
> >> LABEL, the function of remaining three bytes can vary, so we handle it
> >> as an opaque PAYLOAD. The userspace tools can send these datagrams via
> >> a standard socket.
> >>
> >> A LABEL-based filtering can be configured on each socket separately in
> >> a way comparable to CAN -- user uses setsockopt() to push a list of
> >> label,mask tuples into the kernel and the kernel will deliver a datagram
> >> to the socket if (<received_label> & mask) == (label & mask), otherwise
> >> the datagram is not delivered.
> >
> > What's difference compared to CAN besides a different MTU? The CAN stack
> > is already capable to handle CAN and CAN-FD frames. Would it make sense
> > to integrate the ARINC-429 into the existing CAN stack?
>
> That was my first impression too.
Hi!
> What about defining some overlay data structure to map ARINC-429 frames
> into CAN frames?
I agree about the code reuse, it was stupid to do such a blatant copy of the
code all right. I don't think it's such a great idea to outright place ARINC
support into the CAN stack though. They're two different busses after all.
Please see below.
> E.g. we could write the ARINC 32 bit data completely into data[0..3] and
> additionally copy the 8 bit label information (or should it better be 10
> bit including the Source/Destination Identifiers?) additionally into the
> can_id.
>
> From what I can see the filtering by label is similar to filtering by
> can_id. And you would be able to use the can-gw functionality too.
This is correct.
> The only real difference is the bitrate configuration of the ARINC
> interface.
There might be additional ARINC-specific configuration bits involved,
but thus far, that's correct.
> I wonder if a similar approach would fit here as we discussed with the
> University of Prague for a LIN implementation using the PF_CAN
> infrastructure:
OT: Hey, there is no "University of Prague", there are two universities in
Prague to boot -- Charles University and Czech Technical University -- you
mean the later ;-)
> http://rtime.felk.cvut.cz/can/lin-bus/
>
> It could probably boil down to a 'CAN interface' that is named arinc0 which
> implements the serial driver like in slcan.c or sllin.c ...
I was thinking about this and I mostly agree with you. Obviously, copying the
code this way was dumb. On the other hand, ARINC and CAN are two different sort
of busses, so I'd propose something slightly different here to avoid confusion
and prevent the future extensions (or protocols) from adding unrelated cruft
into the CAN stack.
I would propose we (read: me) create some sort of "common" core, which would
contain the following:
- drivers/net/: big part of the device interface here is common
big part of the virtual interface here is common
-> CAN or ARINC can just add their own specific callbacks and
be done with it
- net/: there's a lot of common parts as well, like the filtering can be
unified such that it can be used by both. A big part of the socket
handling is also similar.
This would also let the slcan or sllin or whatever stuff they made at CVUT just
plug into this "common" core part.
Now I wonder if we should introduce AF_ARINC or stick to AF_CAN for both. I'd
be much happier to keep those two separate, again, to avoid confusion.
What do you think please ?
Best regards,
Marek Vasut
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists