}
func BenchmarkInterfaces(b *testing.B) {
+ b.ReportAllocs()
testHookUninstaller.Do(uninstallTestHooks)
for i := 0; i < b.N; i++ {
}
func BenchmarkInterfaceByIndex(b *testing.B) {
+ b.ReportAllocs()
testHookUninstaller.Do(uninstallTestHooks)
ifi := loopbackInterface()
}
func BenchmarkInterfaceByName(b *testing.B) {
+ b.ReportAllocs()
testHookUninstaller.Do(uninstallTestHooks)
ifi := loopbackInterface()
}
func BenchmarkInterfaceAddrs(b *testing.B) {
+ b.ReportAllocs()
testHookUninstaller.Do(uninstallTestHooks)
for i := 0; i < b.N; i++ {
}
func BenchmarkInterfacesAndAddrs(b *testing.B) {
+ b.ReportAllocs()
testHookUninstaller.Do(uninstallTestHooks)
ifi := loopbackInterface()
}
func BenchmarkInterfacesAndMulticastAddrs(b *testing.B) {
+ b.ReportAllocs()
testHookUninstaller.Do(uninstallTestHooks)
ifi := loopbackInterface()
package syscall
-import "unsafe"
+import (
+ "sync"
+ "unsafe"
+)
// Round the length of a netlink message up to align it properly.
func nlmAlignOf(msglen int) int {
return rr.toWireFormat()
}
+var pageBufPool = &sync.Pool{New: func() any {
+ b := make([]byte, Getpagesize())
+ return &b
+}}
+
// NetlinkRIB returns routing information base, as known as RIB, which
// consists of network facility information, states and parameters.
func NetlinkRIB(proto, family int) ([]byte, error) {
return nil, EINVAL
}
var tab []byte
- rbNew := make([]byte, Getpagesize())
+
+ rbNew := pageBufPool.Get().(*[]byte)
+ defer pageBufPool.Put(rbNew)
done:
for {
- rb := rbNew
+ rb := *rbNew
nr, _, err := Recvfrom(s, rb, 0)
if err != nil {
return nil, err