RE: [ofa-general] Re: [PATCH RFC] RDMA/CMA: Allocate PS_TCPportsfrom the host TCP port space.
- From: "Felix Marti" <felix@xxxxxxxxxxx>
- Date: Mon, 20 Aug 2007 09:53:00 -0700
-----Original Message-----Yes, the app will take the cache hits when accessing the data. However,
From: Evgeniy Polyakov [mailto:johnpol@xxxxxxxxxxx]
Sent: Monday, August 20, 2007 2:43 AM
To: Felix Marti
Cc: David Miller; sean.hefty@xxxxxxxxx; netdev@xxxxxxxxxxxxxxx;
rdreier@xxxxxxxxx; general@xxxxxxxxxxxxxxxxxxxxx; linux-
kernel@xxxxxxxxxxxxxxx; jeff@xxxxxxxxxx
Subject: Re: [ofa-general] Re: [PATCH RFC] RDMA/CMA: Allocate
PS_TCPportsfrom the host TCP port space.
On Sun, Aug 19, 2007 at 05:47:59PM -0700, Felix Marti
(felix@xxxxxxxxxxx) wrote:
[Felix Marti] David and Herbert, so you agree that the user<>kernel
space memory copy overhead is a significant overhead and we want to
enable zero-copy in both the receive and transmit path? - Yes, copy
It depends. If you need to access that data after received, you will
get
cache miss and performance will not be much better (if any) that with
copy.
the fact remains that if there is a copy in the receive path, you
require and additional 3x memory BW (which is very significant at these
high rates and most likely the bottleneck for most current systems)...
and somebody always has to take the cache miss be it the copy_to_user or
the app.
used
avoidance is mainly an API issue and unfortunately the so widely
will(synchronous) sockets API doesn't make copy avoidance easy, which isone
area where protocol offload can help. Yes, some apps can resort toswitching
sendfile() but there are many apps which seem to have trouble
to that API... and what about the receive path?
There is number of implementations, and all they are suitable for is
to have recvfile(), since this is likely the only case, which can work
without cache.
And actually RDMA stack exist and no one said it should be thrown away
_until_ it messes with main stack. It started to speal ports. What
happen when it gest all port space and no new legal network conectionYes, RDMA support is there... but we could make it better and easier to
can be opened, although there is no way to show to user who got it?
What will happen if hardware RDMA connection got terminated and
software
could not free the port? Will RDMA request to export connection reset
functions out of stack to drop network connections which are on the
ports
which are supposed to be used by new RDMA connections?
use. We have a problem today with port sharing and there was a proposal
to address the issue by tighter integration (see the beginning of the
thread) but the proposal got shot down immediately... because it is RDMA
and not for technical reasons. I believe this email threads shows in
detail how RDMA (a network technology) is treated as *** child by
the network folks, well at least by one of them.
By no means did I want to imply that others do bad work; are you
RDMA is not a problem, but how it influence to the network stack is.
Let's better think about how to work correctly with network stack
(since
we already have that cr^Wdifferent hardware) instead of saying that
others do bad work and do not allow shiny new feature to exist.
referring to me using TSO implementation issues as an example? - If so,
let me clarify: I understand that the TSO implementation took some time
to get right. What I was referring to is that TSO(/LRO) have their own
issues, some eluded to by Roland and me. In fact, customers working on
the LSR couldn't use TSO due to the burstiness it introduces and had to
fall-back to our fine grained packet scheduling done in the offload
device. I am for variety, let us support new technologies that solve
real problems (lots of folks are buying this stuff for a reason) instead
of the 'ah, its brain-dead and has no future' attitude... there is
precedence for offloading the host CPUs: have a look at graphics.
Graphics used to be done by the host CPU and now we have dedicated
graphics adapters that do a much better job... so, why is it so
farfetched that offload devices can do a better job at a data-flow
problem?
-
--
Evgeniy Polyakov
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
- Follow-Ups:
- References:
- Re: [ofa-general] Re: [PATCH RFC] RDMA/CMA: Allocate PS_TCPportsfrom the host TCP port space.
- From: David Miller
- RE: [ofa-general] Re: [PATCH RFC] RDMA/CMA: Allocate PS_TCPportsfrom the host TCP port space.
- From: Felix Marti
- Re: [ofa-general] Re: [PATCH RFC] RDMA/CMA: Allocate PS_TCPportsfrom the host TCP port space.
- From: Evgeniy Polyakov
- Re: [ofa-general] Re: [PATCH RFC] RDMA/CMA: Allocate PS_TCPportsfrom the host TCP port space.
- Prev by Date: Re: Panic with XFS on RHEL5 (2.6.18-8.1.8.el5)
- Next by Date: [PATCH] kexec: reenable HPET before kexec
- Previous by thread: Re: [ofa-general] Re: [PATCH RFC] RDMA/CMA: Allocate PS_TCPportsfrom the host TCP port space.
- Next by thread: Re: [ofa-general] Re: [PATCH RFC] RDMA/CMA: Allocate PS_TCPportsfrom the host TCP port space.
- Index(es):