2021-06-16 16:19:45 -04:00
|
|
|
// Copyright 2016 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package route
|
|
|
|
|
2022-11-04 09:57:20 -04:00
|
|
|
import "syscall"
|
|
|
|
|
2021-06-16 16:19:45 -04:00
|
|
|
func (typ RIBType) parseable() bool {
|
|
|
|
switch typ {
|
2022-11-04 09:57:20 -04:00
|
|
|
case syscall.NET_RT_STAT, syscall.NET_RT_TRASH:
|
2021-06-16 16:19:45 -04:00
|
|
|
return false
|
|
|
|
default:
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// RouteMetrics represents route metrics.
|
|
|
|
type RouteMetrics struct {
|
|
|
|
PathMTU int // path maximum transmission unit
|
|
|
|
}
|
|
|
|
|
|
|
|
// SysType implements the SysType method of Sys interface.
|
|
|
|
func (rmx *RouteMetrics) SysType() SysType { return SysMetrics }
|
|
|
|
|
|
|
|
// Sys implements the Sys method of Message interface.
|
|
|
|
func (m *RouteMessage) Sys() []Sys {
|
|
|
|
return []Sys{
|
|
|
|
&RouteMetrics{
|
|
|
|
PathMTU: int(nativeEndian.Uint32(m.raw[m.extOff+4 : m.extOff+8])),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// InterfaceMetrics represents interface metrics.
|
|
|
|
type InterfaceMetrics struct {
|
|
|
|
Type int // interface type
|
|
|
|
MTU int // maximum transmission unit
|
|
|
|
}
|
|
|
|
|
|
|
|
// SysType implements the SysType method of Sys interface.
|
|
|
|
func (imx *InterfaceMetrics) SysType() SysType { return SysMetrics }
|
|
|
|
|
|
|
|
// Sys implements the Sys method of Message interface.
|
|
|
|
func (m *InterfaceMessage) Sys() []Sys {
|
|
|
|
return []Sys{
|
|
|
|
&InterfaceMetrics{
|
|
|
|
Type: int(m.raw[m.extOff]),
|
|
|
|
MTU: int(nativeEndian.Uint32(m.raw[m.extOff+8 : m.extOff+12])),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func probeRoutingStack() (int, map[int]*wireFormat) {
|
|
|
|
rtm := &wireFormat{extOff: 36, bodyOff: sizeofRtMsghdrDarwin15}
|
|
|
|
rtm.parse = rtm.parseRouteMessage
|
|
|
|
rtm2 := &wireFormat{extOff: 36, bodyOff: sizeofRtMsghdr2Darwin15}
|
|
|
|
rtm2.parse = rtm2.parseRouteMessage
|
|
|
|
ifm := &wireFormat{extOff: 16, bodyOff: sizeofIfMsghdrDarwin15}
|
|
|
|
ifm.parse = ifm.parseInterfaceMessage
|
|
|
|
ifm2 := &wireFormat{extOff: 32, bodyOff: sizeofIfMsghdr2Darwin15}
|
|
|
|
ifm2.parse = ifm2.parseInterfaceMessage
|
|
|
|
ifam := &wireFormat{extOff: sizeofIfaMsghdrDarwin15, bodyOff: sizeofIfaMsghdrDarwin15}
|
|
|
|
ifam.parse = ifam.parseInterfaceAddrMessage
|
|
|
|
ifmam := &wireFormat{extOff: sizeofIfmaMsghdrDarwin15, bodyOff: sizeofIfmaMsghdrDarwin15}
|
|
|
|
ifmam.parse = ifmam.parseInterfaceMulticastAddrMessage
|
|
|
|
ifmam2 := &wireFormat{extOff: sizeofIfmaMsghdr2Darwin15, bodyOff: sizeofIfmaMsghdr2Darwin15}
|
|
|
|
ifmam2.parse = ifmam2.parseInterfaceMulticastAddrMessage
|
|
|
|
// Darwin kernels require 32-bit aligned access to routing facilities.
|
|
|
|
return 4, map[int]*wireFormat{
|
2022-11-04 09:57:20 -04:00
|
|
|
syscall.RTM_ADD: rtm,
|
|
|
|
syscall.RTM_DELETE: rtm,
|
|
|
|
syscall.RTM_CHANGE: rtm,
|
|
|
|
syscall.RTM_GET: rtm,
|
|
|
|
syscall.RTM_LOSING: rtm,
|
|
|
|
syscall.RTM_REDIRECT: rtm,
|
|
|
|
syscall.RTM_MISS: rtm,
|
|
|
|
syscall.RTM_LOCK: rtm,
|
|
|
|
syscall.RTM_RESOLVE: rtm,
|
|
|
|
syscall.RTM_NEWADDR: ifam,
|
|
|
|
syscall.RTM_DELADDR: ifam,
|
|
|
|
syscall.RTM_IFINFO: ifm,
|
|
|
|
syscall.RTM_NEWMADDR: ifmam,
|
|
|
|
syscall.RTM_DELMADDR: ifmam,
|
|
|
|
syscall.RTM_IFINFO2: ifm2,
|
|
|
|
syscall.RTM_NEWMADDR2: ifmam2,
|
|
|
|
syscall.RTM_GET2: rtm2,
|
2021-06-16 16:19:45 -04:00
|
|
|
}
|
|
|
|
}
|