From 0c6581cc25e95b554d810b1fbbb912390f235afe Mon Sep 17 00:00:00 2001 From: Mikio Hara Date: Wed, 31 Aug 2011 13:05:49 -0400 Subject: [PATCH] syscall: handle routing entry in ParseRoutingSockaddr on BSD variants R=golang-dev, rsc CC=golang-dev https://golang.org/cl/4972053 --- src/pkg/syscall/route_bsd.go | 49 +++++++++++++++++++++++++++++++++--- 1 file changed, 46 insertions(+), 3 deletions(-) diff --git a/src/pkg/syscall/route_bsd.go b/src/pkg/syscall/route_bsd.go index 93e345d717..22a0a4f80e 100644 --- a/src/pkg/syscall/route_bsd.go +++ b/src/pkg/syscall/route_bsd.go @@ -72,9 +72,52 @@ type RouteMessage struct { Data []byte } -func (m *RouteMessage) sockaddr() (sas []Sockaddr) { - // TODO: implement this in the near future - return nil +const rtaRtMask = RTA_DST | RTA_GATEWAY | RTA_NETMASK | RTA_GENMASK + +func (m *RouteMessage) sockaddr() []Sockaddr { + var ( + af int + sas [4]Sockaddr + ) + + buf := m.Data[:] + for i := uint(0); i < RTAX_MAX; i++ { + if m.Header.Addrs&rtaRtMask&(1< 0 && j < int(rsa4.Len)-int(unsafe.Offsetof(rsa4.Addr)); j++ { + sa.Addr[j] = rsa4.Addr[j] + } + sas[i] = sa + case AF_INET6: + rsa6 := (*RawSockaddrInet6)(unsafe.Pointer(&buf[0])) + sa := new(SockaddrInet6) + for j := 0; rsa6.Len > 0 && j < int(rsa6.Len)-int(unsafe.Offsetof(rsa6.Addr)); j++ { + sa.Addr[j] = rsa6.Addr[j] + } + sas[i] = sa + } + } + buf = buf[rsaAlignOf(int(rsa.Len)):] + } + + return sas[:] } // InterfaceMessage represents a routing message containing