diff options
Diffstat (limited to 'libgo/go/syscall/route_darwin.go')
-rw-r--r-- | libgo/go/syscall/route_darwin.go | 34 |
1 files changed, 9 insertions, 25 deletions
diff --git a/libgo/go/syscall/route_darwin.go b/libgo/go/syscall/route_darwin.go index 410e70a138a..ad279072305 100644 --- a/libgo/go/syscall/route_darwin.go +++ b/libgo/go/syscall/route_darwin.go @@ -6,36 +6,22 @@ package syscall -import ( - "unsafe" -) +import "unsafe" -func (any *anyMessage) toRoutingMessage(buf []byte) RoutingMessage { +func (any *anyMessage) toRoutingMessage(b []byte) RoutingMessage { switch any.Type { case RTM_ADD, RTM_DELETE, RTM_CHANGE, RTM_GET, RTM_LOSING, RTM_REDIRECT, RTM_MISS, RTM_LOCK, RTM_RESOLVE: p := (*RouteMessage)(unsafe.Pointer(any)) - rtm := &RouteMessage{} - rtm.Header = p.Header - rtm.Data = buf[SizeofRtMsghdr:any.Msglen] - return rtm + return &RouteMessage{Header: p.Header, Data: b[SizeofRtMsghdr:any.Msglen]} case RTM_IFINFO: p := (*InterfaceMessage)(unsafe.Pointer(any)) - ifm := &InterfaceMessage{} - ifm.Header = p.Header - ifm.Data = buf[SizeofIfMsghdr:any.Msglen] - return ifm + return &InterfaceMessage{Header: p.Header, Data: b[SizeofIfMsghdr:any.Msglen]} case RTM_NEWADDR, RTM_DELADDR: p := (*InterfaceAddrMessage)(unsafe.Pointer(any)) - ifam := &InterfaceAddrMessage{} - ifam.Header = p.Header - ifam.Data = buf[SizeofIfaMsghdr:any.Msglen] - return ifam + return &InterfaceAddrMessage{Header: p.Header, Data: b[SizeofIfaMsghdr:any.Msglen]} case RTM_NEWMADDR2, RTM_DELMADDR: p := (*InterfaceMulticastAddrMessage)(unsafe.Pointer(any)) - ifmam := &InterfaceMulticastAddrMessage{} - ifmam.Header = p.Header - ifmam.Data = buf[SizeofIfmaMsghdr2:any.Msglen] - return ifmam + return &InterfaceMulticastAddrMessage{Header: p.Header, Data: b[SizeofIfmaMsghdr2:any.Msglen]} } return nil } @@ -53,13 +39,12 @@ func (m *InterfaceMulticastAddrMessage) sockaddr() (sas []Sockaddr) { if m.Header.Addrs&rtaIfmaMask == 0 { return nil } - - buf := m.Data[:] + b := m.Data[:] for i := uint(0); i < RTAX_MAX; i++ { if m.Header.Addrs&rtaIfmaMask&(1<<i) == 0 { continue } - rsa := (*RawSockaddr)(unsafe.Pointer(&buf[0])) + rsa := (*RawSockaddr)(unsafe.Pointer(&b[0])) switch i { case RTAX_IFA: sa, e := anyToSockaddr((*RawSockaddrAny)(unsafe.Pointer(rsa))) @@ -70,8 +55,7 @@ func (m *InterfaceMulticastAddrMessage) sockaddr() (sas []Sockaddr) { case RTAX_GATEWAY, RTAX_IFP: // nothing to do } - buf = buf[rsaAlignOf(int(rsa.Len)):] + b = b[rsaAlignOf(int(rsa.Len)):] } - return sas } |