net: Add sendmmsg socket system call
authorAnton Blanchard <anton@samba.org>
Mon, 2 May 2011 20:21:35 +0000 (20:21 +0000)
committerDavid S. Miller <davem@davemloft.net>
Thu, 5 May 2011 18:10:14 +0000 (11:10 -0700)
commit228e548e602061b08ee8e8966f567c12aa079682
tree4c79ecf071d6174d42da1557812a4646d0aaa5af
parent1c5cae815d19ffe02bdfda1260949ef2b1806171
net: Add sendmmsg socket system call

This patch adds a multiple message send syscall and is the send
version of the existing recvmmsg syscall. This is heavily
based on the patch by Arnaldo that added recvmmsg.

I wrote a microbenchmark to test the performance gains of using
this new syscall:

http://ozlabs.org/~anton/junkcode/sendmmsg_test.c

The test was run on a ppc64 box with a 10 Gbit network card. The
benchmark can send both UDP and RAW ethernet packets.

64B UDP

batch   pkts/sec
1       804570
2       872800 (+ 8 %)
4       916556 (+14 %)
8       939712 (+17 %)
16      952688 (+18 %)
32      956448 (+19 %)
64      964800 (+20 %)

64B raw socket

batch   pkts/sec
1       1201449
2       1350028 (+12 %)
4       1461416 (+22 %)
8       1513080 (+26 %)
16      1541216 (+28 %)
32      1553440 (+29 %)
64      1557888 (+30 %)

We see a 20% improvement in throughput on UDP send and 30%
on raw socket send.

[ Add sparc syscall entries. -DaveM ]

Signed-off-by: Anton Blanchard <anton@samba.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
16 files changed:
arch/powerpc/include/asm/systbl.h
arch/powerpc/include/asm/unistd.h
arch/sparc/include/asm/unistd.h
arch/sparc/kernel/systbls_32.S
arch/sparc/kernel/systbls_64.S
arch/x86/ia32/ia32entry.S
arch/x86/include/asm/unistd_32.h
arch/x86/include/asm/unistd_64.h
arch/x86/kernel/syscall_table_32.S
include/linux/net.h
include/linux/socket.h
include/linux/syscalls.h
include/net/compat.h
kernel/sys_ni.c
net/compat.c
net/socket.c