[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20080331.040242.214941948.davem@davemloft.net>
Date: Mon, 31 Mar 2008 04:02:42 -0700 (PDT)
From: David Miller <davem@...emloft.net>
To: mingo@...e.hu
Cc: dada1@...mosbay.com, netdev@...r.kernel.org,
linux-kernel@...r.kernel.org, a.p.zijlstra@...llo.nl
Subject: Re: [RFC,PATCH] loopback: calls netif_receive_skb() instead of
netif_rx()
From: Ingo Molnar <mingo@...e.hu>
Date: Mon, 31 Mar 2008 12:44:03 +0200
> and it's not just about scalability, the plain algorithmic overhead is
> way too high as well:
>
> $ taskset 1 ./bw_tcp -s
> $ taskset 1 ./bw_tcp localhost
> Socket bandwidth using localhost: 2607.09 MB/sec
> $ taskset 1 ./bw_pipe
> Pipe bandwidth: 3680.44 MB/sec
Set your loopback MTU to some larger value if this result and
the locking overhead upsets you.
Also, woe be to the application that wants fast local interprocess
communication and doesn't use IPC_SHM, MAP_SHARED, pipes, or AF_UNIX
sockets. (there's not just one better facility, there are _four_!)
>From this perspective, people way-overemphasize loopback performance,
and 999 times out of 1000 they prove their points using synthetic
benchmarks.
And don't give me this garbage about the application wanting to be
generic and therefore use IP sockets for everything. Either they want
to be generic, or they want the absolute best performance. Trying
to get an "or" and have both at the same time will result in
ludicrious hacks ending up in the kernel.
--
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