From: Cristian Staretu Date: Wed, 9 Jul 2014 08:50:38 +0000 (+1000) Subject: syscall: NetlinkRIB, avoid allocation in loop X-Git-Tag: go1.4beta1~1142 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=8aea9a00a838736189d4a9e381f916b0c3ceaf1d;p=gostls13.git syscall: NetlinkRIB, avoid allocation in loop NetlinkRIB is currently allocating a page sized slice of bytes in a for loop and it's also calling Getpagesize() in the same for loop. This CL changes NetlinkRIB to preallocate the page sized slice of bytes before reaching the for loop. This reduces memory allocations and lowers the number of calls to Getpagesize() to 1 per NetlinkRIB call. This CL reduces the allocated memory from 141.5 MB down to 52 MB in a test. LGTM=crawshaw, dave R=dave, dsymonds, crawshaw CC=bradfitz, dsymonds, golang-codereviews https://golang.org/cl/110920043 --- diff --git a/src/pkg/syscall/netlink_linux.go b/src/pkg/syscall/netlink_linux.go index 49550ea2f0..1b73dce827 100644 --- a/src/pkg/syscall/netlink_linux.go +++ b/src/pkg/syscall/netlink_linux.go @@ -64,9 +64,10 @@ func NetlinkRIB(proto, family int) ([]byte, error) { return nil, err } var tab []byte + rbNew := make([]byte, Getpagesize()) done: for { - rb := make([]byte, Getpagesize()) + rb := rbNew nr, _, err := Recvfrom(s, rb, 0) if err != nil { return nil, err