mirror of
https://github.com/golang/net.git
synced 2026-03-31 18:37:08 +09:00
This reverts CL 632816. Reason for revert: This CL causes x/net to depend on x/sys. We have a policy that prevents us from vendoring x/sys into std, but x/net needs to be vendored. Change-Id: I0fe3bc9861d559d888db6fa7febd48a201f060b8 Reviewed-on: https://go-review.googlesource.com/c/net/+/634196 Auto-Submit: Michael Knyszek <mknyszek@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
46 lines
940 B
Go
46 lines
940 B
Go
// 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.
|
|
|
|
//go:build darwin || dragonfly || freebsd || netbsd || openbsd
|
|
|
|
package route
|
|
|
|
import (
|
|
"syscall"
|
|
"unsafe"
|
|
)
|
|
|
|
var (
|
|
nativeEndian binaryByteOrder
|
|
kernelAlign int
|
|
rtmVersion byte
|
|
wireFormats map[int]*wireFormat
|
|
)
|
|
|
|
func init() {
|
|
i := uint32(1)
|
|
b := (*[4]byte)(unsafe.Pointer(&i))
|
|
if b[0] == 1 {
|
|
nativeEndian = littleEndian
|
|
} else {
|
|
nativeEndian = bigEndian
|
|
}
|
|
// might get overridden in probeRoutingStack
|
|
rtmVersion = syscall.RTM_VERSION
|
|
kernelAlign, wireFormats = probeRoutingStack()
|
|
}
|
|
|
|
func roundup(l int) int {
|
|
if l == 0 {
|
|
return kernelAlign
|
|
}
|
|
return (l + kernelAlign - 1) &^ (kernelAlign - 1)
|
|
}
|
|
|
|
type wireFormat struct {
|
|
extOff int // offset of header extension
|
|
bodyOff int // offset of message body
|
|
parse func(RIBType, []byte) (Message, error)
|
|
}
|