From: Matthew Wilcox <matthew@wil.cx>
To: Greg KH <greg@kroah.com>
Cc: linux-usb@vger.kernel.org, bgmerrell@novell.com,
hirofuchi@users.sourceforge.net, linux-kernel@vger.kernel.org,
usbip-devel@lists.sourceforge.net
Subject: Re: USBIP protocol
Date: Fri, 29 Aug 2008 09:36:25 -0600 [thread overview]
Message-ID: <20080829153625.GF1968@parisc-linux.org> (raw)
In-Reply-To: <20080829145407.GB18423@kroah.com>
On Fri, Aug 29, 2008 at 07:54:07AM -0700, Greg KH wrote:
> On Fri, Aug 29, 2008 at 08:43:54AM -0600, Matthew Wilcox wrote:
> > On Fri, Aug 29, 2008 at 07:30:17AM -0700, Greg KH wrote:
> > > On Fri, Aug 29, 2008 at 08:02:24AM -0600, Matthew Wilcox wrote:
> > > >
> > > > I'm in the middle of implementing a userspace client for usbip and I
> > > > strongly feel that the protocol needs to be changed before it is merged.
> > > >
> > > > - I'm unconvinced that TCP is the correct protocol to be running this over.
> > > > I understand the reluctance to use UDP, but the protocol is fundamentally
> > > > packet-based. If TCP is used, the delimitation of packets within the
> > > > stream needs to be much more robust. I've managed to wedge the VHCI driver
> > > > a number of times in ways that just wouldn't be possible if we were using
> > > > a packet protocol instead of a stream protocol.
> > >
> > > USB is fundamentally packet-based, so it kind of fits very well.
> >
> > Erm, did you not read what I wrote? USB is packet based. TCP isn't.
> > We shouldn't be using TCP here.
>
> Sorry, early morning, no coffee yet...
>
> I think in the end, we should still use TCP otherwise you just end up
> reinventing it with UDP :)
Which brings us to the alternate -- that we need better framing in the
protocol.
> Ok, switch it all to be little endian, not a bit deal.
No, but it does need agreement ;-)
> > > > - There are actually two completely different protocols in use. First,
> > > > the usbipd daemon listens on port 3240, and handles device discovery.
> > > > When usbip successfully attaches to usbipd, both sides of the connection
> > > > pass the socket fd into the kernel and the protocol changes.
> > > > - The protocol sends a 48-byte packet header for every command (and every
> > > > response). It's cunningly hidden as a union.
> > >
> > > Is that a real problem?
> >
> > Yes, it really is. It complicates the protocol, complicates the
> > implementation, introduces unnecessary state, and makes it impossible to
> > renegotiate on the same connection.
>
> Fair enough, patches welcome :)
Patches don't seem appropriate for a design discussion. I'm more than
happy to make suggestions about how to unify the two protocols. I'll
send a followup to this with some ideas.
> > Even if we don't go through the RFC process, just writing down the
> > on-wire protocol should be mandatory for taking this kind of thing into
> > the kernel.
>
> Why, isn't the actual implementation better than a document? :)
Surely you know that writing things down forces you to understand it
better?
--
Matthew Wilcox Intel Open Source Technology Centre
"Bill, look, we understand that you're interested in selling us this
operating system, but compare it to ours. We can't possibly take such
a retrograde step."
next prev parent reply other threads:[~2008-08-29 15:36 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-08-29 14:02 USBIP protocol Matthew Wilcox
2008-08-29 14:06 ` Andi Kleen
2008-08-29 22:31 ` Marcel Holtmann
2008-08-29 20:46 ` Matthew Wilcox
2008-08-29 20:51 ` Willy Tarreau
2008-08-29 14:30 ` Greg KH
2008-08-29 14:43 ` Matthew Wilcox
2008-08-29 14:54 ` Greg KH
2008-08-29 15:36 ` Matthew Wilcox [this message]
2008-08-29 15:53 ` Dave Higton
2008-09-03 4:25 ` Matthew Wilcox
2008-09-03 15:40 ` Alan Stern
2008-09-03 19:10 ` Matthew Wilcox
2008-09-03 20:15 ` Alan Stern
2008-09-04 21:48 ` Matthew Wilcox
2008-09-04 22:15 ` Greg KH
2008-09-05 3:26 ` Pete Zaitcev
2008-09-05 11:37 ` Tilman Schmidt
2008-09-05 15:05 ` Alan Stern
2008-09-09 0:53 ` Matthew Wilcox
2008-09-09 7:12 ` Steve Calfee
2008-09-09 7:33 ` Greg KH
2008-09-09 8:04 ` Greg KH
2008-09-09 15:21 ` Alan Stern
2008-09-03 15:57 ` Greg KH
2008-09-03 19:43 ` Matthew Wilcox
2008-09-04 2:41 ` Greg KH
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=20080829153625.GF1968@parisc-linux.org \
--to=matthew@wil.cx \
--cc=bgmerrell@novell.com \
--cc=greg@kroah.com \
--cc=hirofuchi@users.sourceforge.net \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-usb@vger.kernel.org \
--cc=usbip-devel@lists.sourceforge.net \
/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