From: Joel Sing Date: Tue, 10 Dec 2013 13:03:46 +0000 (+1100) Subject: syscall: skip routing messages with mismatched version X-Git-Tag: go1.3beta1~1275 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=517e49eb290a454791034eb692b696c347f7d74e;p=gostls13.git syscall: skip routing messages with mismatched version Skip routing messages with a mismatched version, rather than failing and returning EINVAL. Only return EINVAL if we were unable to parse any of the routing messages (presumably due to a version mismatch). R=golang-dev, bradfitz CC=golang-dev https://golang.org/cl/30340043 --- diff --git a/src/pkg/syscall/route_bsd.go b/src/pkg/syscall/route_bsd.go index 638073592d..48af587450 100644 --- a/src/pkg/syscall/route_bsd.go +++ b/src/pkg/syscall/route_bsd.go @@ -199,14 +199,21 @@ func (m *InterfaceAddrMessage) sockaddr() (sas []Sockaddr) { // ParseRoutingMessage parses b as routing messages and returns the // slice containing the RoutingMessage interfaces. func ParseRoutingMessage(b []byte) (msgs []RoutingMessage, err error) { + msgCount := 0 for len(b) >= anyMessageLen { + msgCount++ any := (*anyMessage)(unsafe.Pointer(&b[0])) if any.Version != RTM_VERSION { - return nil, EINVAL + b = b[any.Msglen:] + continue } msgs = append(msgs, any.toRoutingMessage(b)) b = b[any.Msglen:] } + // We failed to parse any of the messages - version mismatch? + if msgCount > 0 && len(msgs) == 0 { + return nil, EINVAL + } return msgs, nil }