blob: 0e181038555ccb787c9eb069f10d50564f9f1464 [file] [log] [blame]
Mikio Haradc7f8252011-08-04 00:22:48 -04001// Copyright 2011 The Go Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style
3// license that can be found in the LICENSE file.
4
Mikio Haradc7f8252011-08-04 00:22:48 -04005package syscall
6
Mikio Harac5f5df42013-02-24 12:36:44 +09007import "unsafe"
Mikio Haradc7f8252011-08-04 00:22:48 -04008
Mikio Hara25668b92014-03-04 09:26:56 +09009// See http://www.freebsd.org/doc/en/books/porters-handbook/freebsd-versions.html.
10var freebsdVersion uint32
11
12func init() {
13 freebsdVersion, _ = SysctlUint32("kern.osreldate")
Mikio Hara69275ee2015-02-10 12:24:11 +090014 conf, _ := Sysctl("kern.conftxt")
15 for i, j := 0, 0; j < len(conf); j++ {
16 if conf[j] != '\n' {
17 continue
18 }
19 s := conf[i:j]
20 i = j + 1
21 if len(s) > len("machine") && s[:len("machine")] == "machine" {
22 s = s[len("machine"):]
23 for k := 0; k < len(s); k++ {
24 if s[k] == ' ' || s[k] == '\t' {
25 s = s[1:]
26 }
27 break
28 }
29 freebsdConfArch = s
30 break
31 }
32 }
Mikio Hara25668b92014-03-04 09:26:56 +090033}
34
Mikio Harac5f5df42013-02-24 12:36:44 +090035func (any *anyMessage) toRoutingMessage(b []byte) RoutingMessage {
Mikio Haradc7f8252011-08-04 00:22:48 -040036 switch any.Type {
37 case RTM_ADD, RTM_DELETE, RTM_CHANGE, RTM_GET, RTM_LOSING, RTM_REDIRECT, RTM_MISS, RTM_LOCK, RTM_RESOLVE:
Mikio Hara69275ee2015-02-10 12:24:11 +090038 return any.parseRouteMessage(b)
Mikio Haradc7f8252011-08-04 00:22:48 -040039 case RTM_IFINFO:
Mikio Hara25668b92014-03-04 09:26:56 +090040 return any.parseInterfaceMessage(b)
Mikio Harac5f5df42013-02-24 12:36:44 +090041 case RTM_IFANNOUNCE:
42 p := (*InterfaceAnnounceMessage)(unsafe.Pointer(any))
43 return &InterfaceAnnounceMessage{Header: p.Header}
Mikio Haradc7f8252011-08-04 00:22:48 -040044 case RTM_NEWADDR, RTM_DELADDR:
45 p := (*InterfaceAddrMessage)(unsafe.Pointer(any))
Mikio Harac5f5df42013-02-24 12:36:44 +090046 return &InterfaceAddrMessage{Header: p.Header, Data: b[SizeofIfaMsghdr:any.Msglen]}
Mikio Haradc7f8252011-08-04 00:22:48 -040047 case RTM_NEWMADDR, RTM_DELMADDR:
48 p := (*InterfaceMulticastAddrMessage)(unsafe.Pointer(any))
Mikio Harac5f5df42013-02-24 12:36:44 +090049 return &InterfaceMulticastAddrMessage{Header: p.Header, Data: b[SizeofIfmaMsghdr:any.Msglen]}
Mikio Haradc7f8252011-08-04 00:22:48 -040050 }
51 return nil
52}
53
Mikio Harac5f5df42013-02-24 12:36:44 +090054// InterfaceAnnounceMessage represents a routing message containing
Robert Griesemerf3913622014-05-02 13:17:55 -070055// network interface arrival and departure information.
Mikio Harac5f5df42013-02-24 12:36:44 +090056type InterfaceAnnounceMessage struct {
57 Header IfAnnounceMsghdr
58}
59
Mikio Hara69275ee2015-02-10 12:24:11 +090060func (m *InterfaceAnnounceMessage) sockaddr() ([]Sockaddr, error) { return nil, nil }
Mikio Harac5f5df42013-02-24 12:36:44 +090061
Mikio Haradc7f8252011-08-04 00:22:48 -040062// InterfaceMulticastAddrMessage represents a routing message
63// containing network interface address entries.
64type InterfaceMulticastAddrMessage struct {
65 Header IfmaMsghdr
66 Data []byte
67}
Joel Sing1bc24512011-08-16 17:26:51 -040068
Mikio Hara69275ee2015-02-10 12:24:11 +090069func (m *InterfaceMulticastAddrMessage) sockaddr() ([]Sockaddr, error) {
70 var sas [RTAX_MAX]Sockaddr
Mikio Harac5f5df42013-02-24 12:36:44 +090071 b := m.Data[:]
Mikio Hara69275ee2015-02-10 12:24:11 +090072 for i := uint(0); i < RTAX_MAX && len(b) >= minRoutingSockaddrLen; i++ {
73 if m.Header.Addrs&(1<<i) == 0 {
Joel Sing1bc24512011-08-16 17:26:51 -040074 continue
75 }
Mikio Harac5f5df42013-02-24 12:36:44 +090076 rsa := (*RawSockaddr)(unsafe.Pointer(&b[0]))
Mikio Hara69275ee2015-02-10 12:24:11 +090077 switch rsa.Family {
78 case AF_LINK:
79 sa, err := parseSockaddrLink(b)
80 if err != nil {
81 return nil, err
Joel Sing1bc24512011-08-16 17:26:51 -040082 }
Mikio Hara69275ee2015-02-10 12:24:11 +090083 sas[i] = sa
84 b = b[rsaAlignOf(int(rsa.Len)):]
85 case AF_INET, AF_INET6:
86 sa, err := parseSockaddrInet(b, rsa.Family)
87 if err != nil {
88 return nil, err
89 }
90 sas[i] = sa
91 b = b[rsaAlignOf(int(rsa.Len)):]
92 default:
93 sa, l, err := parseLinkLayerAddr(b)
94 if err != nil {
95 return nil, err
96 }
97 sas[i] = sa
98 b = b[l:]
Joel Sing1bc24512011-08-16 17:26:51 -040099 }
Joel Sing1bc24512011-08-16 17:26:51 -0400100 }
Mikio Hara69275ee2015-02-10 12:24:11 +0900101 return sas[:], nil
Joel Sing1bc24512011-08-16 17:26:51 -0400102}