mirror of
https://github.com/vishvananda/netlink
synced 2025-02-16 20:16:51 +00:00
add bond interface support
This commit is contained in:
parent
a57a12c1b1
commit
656c395788
284
link.go
284
link.go
@ -1,6 +1,7 @@
|
|||||||
package netlink
|
package netlink
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"syscall"
|
"syscall"
|
||||||
)
|
)
|
||||||
@ -240,6 +241,289 @@ func (ipvlan *IPVlan) Type() string {
|
|||||||
return "ipvlan"
|
return "ipvlan"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// BondMode type
|
||||||
|
type BondMode int
|
||||||
|
|
||||||
|
func (b BondMode) String() string {
|
||||||
|
s, ok := bondModeToString[b]
|
||||||
|
if !ok {
|
||||||
|
return fmt.Sprintf("BondMode(%d)", b)
|
||||||
|
}
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
|
||||||
|
// StringToBondMode returns bond mode, or uknonw is the s is invalid.
|
||||||
|
func StringToBondMode(s string) BondMode {
|
||||||
|
mode, ok := StringToBondModeMap[s]
|
||||||
|
if !ok {
|
||||||
|
return BOND_MODE_UNKNOWN
|
||||||
|
}
|
||||||
|
return mode
|
||||||
|
}
|
||||||
|
|
||||||
|
// Possible BondMode
|
||||||
|
const (
|
||||||
|
BOND_MODE_802_3AD BondMode = iota
|
||||||
|
BOND_MODE_BALANCE_RR
|
||||||
|
BOND_MODE_ACTIVE_BACKUP
|
||||||
|
BOND_MODE_BALANCE_XOR
|
||||||
|
BOND_MODE_BROADCAST
|
||||||
|
BOND_MODE_BALANCE_TLB
|
||||||
|
BOND_MODE_BALANCE_ALB
|
||||||
|
BOND_MODE_UNKNOWN
|
||||||
|
)
|
||||||
|
|
||||||
|
var bondModeToString = map[BondMode]string{
|
||||||
|
BOND_MODE_802_3AD: "802.3ad",
|
||||||
|
BOND_MODE_BALANCE_RR: "balance-rr",
|
||||||
|
BOND_MODE_ACTIVE_BACKUP: "active-backup",
|
||||||
|
BOND_MODE_BALANCE_XOR: "balance-xor",
|
||||||
|
BOND_MODE_BROADCAST: "broadcast",
|
||||||
|
BOND_MODE_BALANCE_TLB: "balance-tlb",
|
||||||
|
BOND_MODE_BALANCE_ALB: "balance-alb",
|
||||||
|
}
|
||||||
|
var StringToBondModeMap = map[string]BondMode{
|
||||||
|
"802.3ad": BOND_MODE_802_3AD,
|
||||||
|
"balance-rr": BOND_MODE_BALANCE_RR,
|
||||||
|
"active-backup": BOND_MODE_ACTIVE_BACKUP,
|
||||||
|
"balance-xor": BOND_MODE_BALANCE_XOR,
|
||||||
|
"broadcast": BOND_MODE_BROADCAST,
|
||||||
|
"balance-tlb": BOND_MODE_BALANCE_TLB,
|
||||||
|
"balance-alb": BOND_MODE_BALANCE_ALB,
|
||||||
|
}
|
||||||
|
|
||||||
|
// BondArpValidate type
|
||||||
|
type BondArpValidate int
|
||||||
|
|
||||||
|
// Possible BondArpValidate value
|
||||||
|
const (
|
||||||
|
BOND_ARP_VALIDATE_NONE BondArpValidate = iota
|
||||||
|
BOND_ARP_VALIDATE_ACTIVE
|
||||||
|
BOND_ARP_VALIDATE_BACKUP
|
||||||
|
BOND_ARP_VALIDATE_ALL
|
||||||
|
)
|
||||||
|
|
||||||
|
// BondPrimaryReselect type
|
||||||
|
type BondPrimaryReselect int
|
||||||
|
|
||||||
|
// Possible BondPrimaryReselect value
|
||||||
|
const (
|
||||||
|
BOND_PRIMARY_RESELECT_ALWAYS BondPrimaryReselect = iota
|
||||||
|
BOND_PRIMARY_RESELECT_BETTER
|
||||||
|
BOND_PRIMARY_RESELECT_FAILURE
|
||||||
|
)
|
||||||
|
|
||||||
|
// BondArpAllTargets type
|
||||||
|
type BondArpAllTargets int
|
||||||
|
|
||||||
|
// Possible BondArpAllTargets value
|
||||||
|
const (
|
||||||
|
BOND_ARP_ALL_TARGETS_ANY BondArpAllTargets = iota
|
||||||
|
BOND_ARP_ALL_TARGETS_ALL
|
||||||
|
)
|
||||||
|
|
||||||
|
// BondFailOverMac type
|
||||||
|
type BondFailOverMac int
|
||||||
|
|
||||||
|
// Possible BondFailOverMac value
|
||||||
|
const (
|
||||||
|
BOND_FAIL_OVER_MAC_NONE BondFailOverMac = iota
|
||||||
|
BOND_FAIL_OVER_MAC_ACTIVE
|
||||||
|
BOND_FAIL_OVER_MAC_FOLLOW
|
||||||
|
)
|
||||||
|
|
||||||
|
// BondXmitHashPolicy type
|
||||||
|
type BondXmitHashPolicy int
|
||||||
|
|
||||||
|
func (b BondXmitHashPolicy) String() string {
|
||||||
|
s, ok := bondXmitHashPolicyToString[b]
|
||||||
|
if !ok {
|
||||||
|
return fmt.Sprintf("XmitHashPolicy(%d)", b)
|
||||||
|
}
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
|
||||||
|
// StringToBondXmitHashPolicy returns bond lacp arte, or uknonw is the s is invalid.
|
||||||
|
func StringToBondXmitHashPolicy(s string) BondXmitHashPolicy {
|
||||||
|
lacp, ok := StringToBondXmitHashPolicyMap[s]
|
||||||
|
if !ok {
|
||||||
|
return BOND_XMIT_HASH_POLICY_UNKNOWN
|
||||||
|
}
|
||||||
|
return lacp
|
||||||
|
}
|
||||||
|
|
||||||
|
// Possible BondXmitHashPolicy value
|
||||||
|
const (
|
||||||
|
BOND_XMIT_HASH_POLICY_LAYER2 BondXmitHashPolicy = iota
|
||||||
|
BOND_XMIT_HASH_POLICY_LAYER3_4
|
||||||
|
BOND_XMIT_HASH_POLICY_LAYER2_3
|
||||||
|
BOND_XMIT_HASH_POLICY_ENCAP2_3
|
||||||
|
BOND_XMIT_HASH_POLICY_ENCAP3_4
|
||||||
|
BOND_XMIT_HASH_POLICY_UNKNOWN
|
||||||
|
)
|
||||||
|
|
||||||
|
var bondXmitHashPolicyToString = map[BondXmitHashPolicy]string{
|
||||||
|
BOND_XMIT_HASH_POLICY_LAYER2: "layer2",
|
||||||
|
BOND_XMIT_HASH_POLICY_LAYER3_4: "layer3+4",
|
||||||
|
BOND_XMIT_HASH_POLICY_LAYER2_3: "layer2+3",
|
||||||
|
BOND_XMIT_HASH_POLICY_ENCAP2_3: "encap2+3",
|
||||||
|
BOND_XMIT_HASH_POLICY_ENCAP3_4: "encap3+4",
|
||||||
|
}
|
||||||
|
var StringToBondXmitHashPolicyMap = map[string]BondXmitHashPolicy{
|
||||||
|
"layer2": BOND_XMIT_HASH_POLICY_LAYER2,
|
||||||
|
"layer3+4": BOND_XMIT_HASH_POLICY_LAYER3_4,
|
||||||
|
"layer2+3": BOND_XMIT_HASH_POLICY_LAYER2_3,
|
||||||
|
"encap2+3": BOND_XMIT_HASH_POLICY_ENCAP2_3,
|
||||||
|
"encap3+4": BOND_XMIT_HASH_POLICY_ENCAP3_4,
|
||||||
|
}
|
||||||
|
|
||||||
|
// BondLacpRate type
|
||||||
|
type BondLacpRate int
|
||||||
|
|
||||||
|
func (b BondLacpRate) String() string {
|
||||||
|
s, ok := bondLacpRateToString[b]
|
||||||
|
if !ok {
|
||||||
|
return fmt.Sprintf("LacpRate(%d)", b)
|
||||||
|
}
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
|
||||||
|
// StringToBondLacpRate returns bond lacp arte, or uknonw is the s is invalid.
|
||||||
|
func StringToBondLacpRate(s string) BondLacpRate {
|
||||||
|
lacp, ok := StringToBondLacpRateMap[s]
|
||||||
|
if !ok {
|
||||||
|
return BOND_LACP_RATE_UNKNOWN
|
||||||
|
}
|
||||||
|
return lacp
|
||||||
|
}
|
||||||
|
|
||||||
|
// Possible BondLacpRate value
|
||||||
|
const (
|
||||||
|
BOND_LACP_RATE_SLOW BondLacpRate = iota
|
||||||
|
BOND_LACP_RATE_FAST
|
||||||
|
BOND_LACP_RATE_UNKNOWN
|
||||||
|
)
|
||||||
|
|
||||||
|
var bondLacpRateToString = map[BondLacpRate]string{
|
||||||
|
BOND_LACP_RATE_SLOW: "slow",
|
||||||
|
BOND_LACP_RATE_FAST: "fast",
|
||||||
|
}
|
||||||
|
var StringToBondLacpRateMap = map[string]BondLacpRate{
|
||||||
|
"slow": BOND_LACP_RATE_SLOW,
|
||||||
|
"fast": BOND_LACP_RATE_FAST,
|
||||||
|
}
|
||||||
|
|
||||||
|
// BondAdSelect type
|
||||||
|
type BondAdSelect int
|
||||||
|
|
||||||
|
// Possible BondAdSelect value
|
||||||
|
const (
|
||||||
|
BOND_AD_SELECT_STABLE BondAdSelect = iota
|
||||||
|
BOND_AD_SELECT_BANDWIDTH
|
||||||
|
BOND_AD_SELECT_COUNT
|
||||||
|
)
|
||||||
|
|
||||||
|
// BondAdInfo
|
||||||
|
type BondAdInfo struct {
|
||||||
|
AggregatorId int
|
||||||
|
NumPorts int
|
||||||
|
ActorKey int
|
||||||
|
PartnerKey int
|
||||||
|
PartnerMac net.HardwareAddr
|
||||||
|
}
|
||||||
|
|
||||||
|
// Bond representation
|
||||||
|
type Bond struct {
|
||||||
|
LinkAttrs
|
||||||
|
Mode BondMode
|
||||||
|
ActiveSlave int
|
||||||
|
Miimon int
|
||||||
|
UpDelay int
|
||||||
|
DownDelay int
|
||||||
|
UseCarrier int
|
||||||
|
ArpInterval int
|
||||||
|
ArpIpTargets []net.IP
|
||||||
|
ArpValidate BondArpValidate
|
||||||
|
ArpAllTargets BondArpAllTargets
|
||||||
|
Primary int
|
||||||
|
PrimaryReselect BondPrimaryReselect
|
||||||
|
FailOverMac BondFailOverMac
|
||||||
|
XmitHashPolicy BondXmitHashPolicy
|
||||||
|
ResendIgmp int
|
||||||
|
NumPeerNotif int
|
||||||
|
AllSlavesActive int
|
||||||
|
MinLinks int
|
||||||
|
LpInterval int
|
||||||
|
PackersPerSlave int
|
||||||
|
LacpRate BondLacpRate
|
||||||
|
AdSelect BondAdSelect
|
||||||
|
// looking at iproute tool AdInfo can only be retrived. It can't be set.
|
||||||
|
AdInfo *BondAdInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewLinkBond(atr LinkAttrs) *Bond {
|
||||||
|
return &Bond{
|
||||||
|
LinkAttrs: atr,
|
||||||
|
Mode: -1,
|
||||||
|
ActiveSlave: -1,
|
||||||
|
Miimon: -1,
|
||||||
|
UpDelay: -1,
|
||||||
|
DownDelay: -1,
|
||||||
|
UseCarrier: -1,
|
||||||
|
ArpInterval: -1,
|
||||||
|
ArpIpTargets: nil,
|
||||||
|
ArpValidate: -1,
|
||||||
|
ArpAllTargets: -1,
|
||||||
|
Primary: -1,
|
||||||
|
PrimaryReselect: -1,
|
||||||
|
FailOverMac: -1,
|
||||||
|
XmitHashPolicy: -1,
|
||||||
|
ResendIgmp: -1,
|
||||||
|
NumPeerNotif: -1,
|
||||||
|
AllSlavesActive: -1,
|
||||||
|
MinLinks: -1,
|
||||||
|
LpInterval: -1,
|
||||||
|
PackersPerSlave: -1,
|
||||||
|
LacpRate: -1,
|
||||||
|
AdSelect: -1,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Flag mask for bond options. Bond.Flagmask must be set to on for option to work.
|
||||||
|
const (
|
||||||
|
BOND_MODE_MASK uint64 = 1 << (1 + iota)
|
||||||
|
BOND_ACTIVE_SLAVE_MASK
|
||||||
|
BOND_MIIMON_MASK
|
||||||
|
BOND_UPDELAY_MASK
|
||||||
|
BOND_DOWNDELAY_MASK
|
||||||
|
BOND_USE_CARRIER_MASK
|
||||||
|
BOND_ARP_INTERVAL_MASK
|
||||||
|
BOND_ARP_VALIDATE_MASK
|
||||||
|
BOND_ARP_ALL_TARGETS_MASK
|
||||||
|
BOND_PRIMARY_MASK
|
||||||
|
BOND_PRIMARY_RESELECT_MASK
|
||||||
|
BOND_FAIL_OVER_MAC_MASK
|
||||||
|
BOND_XMIT_HASH_POLICY_MASK
|
||||||
|
BOND_RESEND_IGMP_MASK
|
||||||
|
BOND_NUM_PEER_NOTIF_MASK
|
||||||
|
BOND_ALL_SLAVES_ACTIVE_MASK
|
||||||
|
BOND_MIN_LINKS_MASK
|
||||||
|
BOND_LP_INTERVAL_MASK
|
||||||
|
BOND_PACKETS_PER_SLAVE_MASK
|
||||||
|
BOND_LACP_RATE_MASK
|
||||||
|
BOND_AD_SELECT_MASK
|
||||||
|
)
|
||||||
|
|
||||||
|
// Attrs implementation.
|
||||||
|
func (bond *Bond) Attrs() *LinkAttrs {
|
||||||
|
return &bond.LinkAttrs
|
||||||
|
}
|
||||||
|
|
||||||
|
// Type implementation fro Vxlan.
|
||||||
|
func (bond *Bond) Type() string {
|
||||||
|
return "bond"
|
||||||
|
}
|
||||||
|
|
||||||
// iproute2 supported devices;
|
// iproute2 supported devices;
|
||||||
// vlan | veth | vcan | dummy | ifb | macvlan | macvtap |
|
// vlan | veth | vcan | dummy | ifb | macvlan | macvtap |
|
||||||
// bridge | bond | ipoib | ip6tnl | ipip | sit | vxlan |
|
// bridge | bond | ipoib | ip6tnl | ipip | sit | vxlan |
|
||||||
|
141
link_linux.go
141
link_linux.go
@ -275,6 +275,87 @@ func addVxlanAttrs(vxlan *Vxlan, linkInfo *nl.RtAttr) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func addBondAttrs(bond *Bond, linkInfo *nl.RtAttr) {
|
||||||
|
data := nl.NewRtAttrChild(linkInfo, nl.IFLA_INFO_DATA, nil)
|
||||||
|
if bond.Mode >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_MODE, nl.Uint8Attr(uint8(bond.Mode)))
|
||||||
|
}
|
||||||
|
if bond.ActiveSlave >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_ACTIVE_SLAVE, nl.Uint32Attr(uint32(bond.ActiveSlave)))
|
||||||
|
}
|
||||||
|
if bond.Miimon >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_MIIMON, nl.Uint32Attr(uint32(bond.Miimon)))
|
||||||
|
}
|
||||||
|
if bond.UpDelay >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_UPDELAY, nl.Uint32Attr(uint32(bond.UpDelay)))
|
||||||
|
}
|
||||||
|
if bond.DownDelay >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_DOWNDELAY, nl.Uint32Attr(uint32(bond.DownDelay)))
|
||||||
|
}
|
||||||
|
if bond.UseCarrier >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_USE_CARRIER, nl.Uint8Attr(uint8(bond.UseCarrier)))
|
||||||
|
}
|
||||||
|
if bond.ArpInterval >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_ARP_INTERVAL, nl.Uint32Attr(uint32(bond.ArpInterval)))
|
||||||
|
}
|
||||||
|
if bond.ArpIpTargets != nil {
|
||||||
|
msg := nl.NewRtAttrChild(data, nl.IFLA_BOND_ARP_IP_TARGET, nil)
|
||||||
|
for i := range bond.ArpIpTargets {
|
||||||
|
ip := bond.ArpIpTargets[i].To4()
|
||||||
|
if ip != nil {
|
||||||
|
nl.NewRtAttrChild(msg, i, []byte(ip))
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
ip = bond.ArpIpTargets[i].To16()
|
||||||
|
if ip != nil {
|
||||||
|
nl.NewRtAttrChild(msg, i, []byte(ip))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if bond.ArpValidate >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_ARP_VALIDATE, nl.Uint32Attr(uint32(bond.ArpValidate)))
|
||||||
|
}
|
||||||
|
if bond.ArpAllTargets >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_ARP_ALL_TARGETS, nl.Uint32Attr(uint32(bond.ArpAllTargets)))
|
||||||
|
}
|
||||||
|
if bond.Primary >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_PRIMARY, nl.Uint32Attr(uint32(bond.Primary)))
|
||||||
|
}
|
||||||
|
if bond.PrimaryReselect >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_PRIMARY_RESELECT, nl.Uint8Attr(uint8(bond.PrimaryReselect)))
|
||||||
|
}
|
||||||
|
if bond.FailOverMac >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_FAIL_OVER_MAC, nl.Uint8Attr(uint8(bond.FailOverMac)))
|
||||||
|
}
|
||||||
|
if bond.XmitHashPolicy >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_XMIT_HASH_POLICY, nl.Uint8Attr(uint8(bond.XmitHashPolicy)))
|
||||||
|
}
|
||||||
|
if bond.ResendIgmp >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_RESEND_IGMP, nl.Uint32Attr(uint32(bond.ResendIgmp)))
|
||||||
|
}
|
||||||
|
if bond.NumPeerNotif >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_NUM_PEER_NOTIF, nl.Uint8Attr(uint8(bond.NumPeerNotif)))
|
||||||
|
}
|
||||||
|
if bond.AllSlavesActive >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_ALL_SLAVES_ACTIVE, nl.Uint8Attr(uint8(bond.AllSlavesActive)))
|
||||||
|
}
|
||||||
|
if bond.MinLinks >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_MIN_LINKS, nl.Uint32Attr(uint32(bond.MinLinks)))
|
||||||
|
}
|
||||||
|
if bond.LpInterval >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_LP_INTERVAL, nl.Uint32Attr(uint32(bond.LpInterval)))
|
||||||
|
}
|
||||||
|
if bond.PackersPerSlave >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_PACKETS_PER_SLAVE, nl.Uint32Attr(uint32(bond.PackersPerSlave)))
|
||||||
|
}
|
||||||
|
if bond.LacpRate >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_AD_LACP_RATE, nl.Uint8Attr(uint8(bond.LacpRate)))
|
||||||
|
}
|
||||||
|
if bond.AdSelect >= 0 {
|
||||||
|
nl.NewRtAttrChild(data, nl.IFLA_BOND_AD_SELECT, nl.Uint8Attr(uint8(bond.AdSelect)))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// LinkAdd adds a new link device. The type and features of the device
|
// LinkAdd adds a new link device. The type and features of the device
|
||||||
// are taken fromt the parameters in the link object.
|
// are taken fromt the parameters in the link object.
|
||||||
// Equivalent to: `ip link add $link`
|
// Equivalent to: `ip link add $link`
|
||||||
@ -388,6 +469,8 @@ func LinkAdd(link Link) error {
|
|||||||
|
|
||||||
} else if vxlan, ok := link.(*Vxlan); ok {
|
} else if vxlan, ok := link.(*Vxlan); ok {
|
||||||
addVxlanAttrs(vxlan, linkInfo)
|
addVxlanAttrs(vxlan, linkInfo)
|
||||||
|
} else if bond, ok := link.(*Bond); ok {
|
||||||
|
addBondAttrs(bond, linkInfo)
|
||||||
} else if ipv, ok := link.(*IPVlan); ok {
|
} else if ipv, ok := link.(*IPVlan); ok {
|
||||||
data := nl.NewRtAttrChild(linkInfo, nl.IFLA_INFO_DATA, nil)
|
data := nl.NewRtAttrChild(linkInfo, nl.IFLA_INFO_DATA, nil)
|
||||||
nl.NewRtAttrChild(data, nl.IFLA_IPVLAN_MODE, nl.Uint16Attr(uint16(ipv.Mode)))
|
nl.NewRtAttrChild(data, nl.IFLA_IPVLAN_MODE, nl.Uint16Attr(uint16(ipv.Mode)))
|
||||||
@ -543,6 +626,8 @@ func linkDeserialize(m []byte) (Link, error) {
|
|||||||
link = &Veth{}
|
link = &Veth{}
|
||||||
case "vxlan":
|
case "vxlan":
|
||||||
link = &Vxlan{}
|
link = &Vxlan{}
|
||||||
|
case "bond":
|
||||||
|
link = &Bond{}
|
||||||
case "ipvlan":
|
case "ipvlan":
|
||||||
link = &IPVlan{}
|
link = &IPVlan{}
|
||||||
case "macvlan":
|
case "macvlan":
|
||||||
@ -562,6 +647,8 @@ func linkDeserialize(m []byte) (Link, error) {
|
|||||||
parseVlanData(link, data)
|
parseVlanData(link, data)
|
||||||
case "vxlan":
|
case "vxlan":
|
||||||
parseVxlanData(link, data)
|
parseVxlanData(link, data)
|
||||||
|
case "bond":
|
||||||
|
parseBondData(link, data)
|
||||||
case "ipvlan":
|
case "ipvlan":
|
||||||
parseIPVlanData(link, data)
|
parseIPVlanData(link, data)
|
||||||
case "macvlan":
|
case "macvlan":
|
||||||
@ -772,6 +859,60 @@ func parseVxlanData(link Link, data []syscall.NetlinkRouteAttr) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func parseBondData(link Link, data []syscall.NetlinkRouteAttr) {
|
||||||
|
bond := NewBond(LinkAttrs{})
|
||||||
|
for i := range data {
|
||||||
|
switch data[i].Attr.Type {
|
||||||
|
case nl.IFLA_BOND_MODE:
|
||||||
|
bond.Mode = BondMode(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_ACTIVE_SLAVE:
|
||||||
|
bond.ActiveSlave = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_MIIMON:
|
||||||
|
bond.Miimon = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_UPDELAY:
|
||||||
|
bond.UpDelay = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_DOWNDELAY:
|
||||||
|
bond.DownDelay = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_USE_CARRIER:
|
||||||
|
bond.UseCarrier = int(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_ARP_INTERVAL:
|
||||||
|
bond.ArpInterval = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_ARP_IP_TARGET:
|
||||||
|
// TODO: implement
|
||||||
|
case nl.IFLA_BOND_ARP_VALIDATE:
|
||||||
|
bond.ArpValidate = BondArpValidate(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_ARP_ALL_TARGETS:
|
||||||
|
bond.ArpAllTargets = BondArpAllTargets(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_PRIMARY:
|
||||||
|
bond.Primary = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_PRIMARY_RESELECT:
|
||||||
|
bond.PrimaryReselect = BondPrimaryReselect(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_FAIL_OVER_MAC:
|
||||||
|
bond.FailOverMac = BondFailOverMac(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_XMIT_HASH_POLICY:
|
||||||
|
bond.XmitHashPolicy = BondXmitHashPolicy(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_RESEND_IGMP:
|
||||||
|
bond.ResendIgmp = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_NUM_PEER_NOTIF:
|
||||||
|
bond.NumPeerNotif = int(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_ALL_SLAVES_ACTIVE:
|
||||||
|
bond.AllSlavesActive = int(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_MIN_LINKS:
|
||||||
|
bond.MinLinks = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_LP_INTERVAL:
|
||||||
|
bond.LpInterval = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_PACKETS_PER_SLAVE:
|
||||||
|
bond.PackersPerSlave = int(native.Uint32(data[i].Value[0:4]))
|
||||||
|
case nl.IFLA_BOND_AD_LACP_RATE:
|
||||||
|
bond.LacpRate = BondLacpRate(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_AD_SELECT:
|
||||||
|
bond.AdSelect = BondAdSelect(data[i].Value[0])
|
||||||
|
case nl.IFLA_BOND_AD_INFO:
|
||||||
|
// TODO: implement
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func parseIPVlanData(link Link, data []syscall.NetlinkRouteAttr) {
|
func parseIPVlanData(link Link, data []syscall.NetlinkRouteAttr) {
|
||||||
ipv := link.(*IPVlan)
|
ipv := link.(*IPVlan)
|
||||||
for _, datum := range data {
|
for _, datum := range data {
|
||||||
|
@ -262,6 +262,13 @@ func TestLinkAddDelVeth(t *testing.T) {
|
|||||||
testLinkAddDel(t, &Veth{LinkAttrs{Name: "foo", TxQLen: testTxQLen, MTU: 1400}, "bar"})
|
testLinkAddDel(t, &Veth{LinkAttrs{Name: "foo", TxQLen: testTxQLen, MTU: 1400}, "bar"})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestLinkAddDelBond(t *testing.T) {
|
||||||
|
tearDown := setUpNetlinkTest(t)
|
||||||
|
defer tearDown()
|
||||||
|
|
||||||
|
testLinkAddDel(t, NewBond(LinkAttrs{Name: "foo"}))
|
||||||
|
}
|
||||||
|
|
||||||
func TestLinkAddVethWithDefaultTxQLen(t *testing.T) {
|
func TestLinkAddVethWithDefaultTxQLen(t *testing.T) {
|
||||||
tearDown := setUpNetlinkTest(t)
|
tearDown := setUpNetlinkTest(t)
|
||||||
defer tearDown()
|
defer tearDown()
|
||||||
|
@ -102,3 +102,49 @@ const (
|
|||||||
MACVLAN_MODE_PASSTHRU = 8
|
MACVLAN_MODE_PASSTHRU = 8
|
||||||
MACVLAN_MODE_SOURCE = 16
|
MACVLAN_MODE_SOURCE = 16
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
IFLA_BOND_UNSPEC = iota
|
||||||
|
IFLA_BOND_MODE
|
||||||
|
IFLA_BOND_ACTIVE_SLAVE
|
||||||
|
IFLA_BOND_MIIMON
|
||||||
|
IFLA_BOND_UPDELAY
|
||||||
|
IFLA_BOND_DOWNDELAY
|
||||||
|
IFLA_BOND_USE_CARRIER
|
||||||
|
IFLA_BOND_ARP_INTERVAL
|
||||||
|
IFLA_BOND_ARP_IP_TARGET
|
||||||
|
IFLA_BOND_ARP_VALIDATE
|
||||||
|
IFLA_BOND_ARP_ALL_TARGETS
|
||||||
|
IFLA_BOND_PRIMARY
|
||||||
|
IFLA_BOND_PRIMARY_RESELECT
|
||||||
|
IFLA_BOND_FAIL_OVER_MAC
|
||||||
|
IFLA_BOND_XMIT_HASH_POLICY
|
||||||
|
IFLA_BOND_RESEND_IGMP
|
||||||
|
IFLA_BOND_NUM_PEER_NOTIF
|
||||||
|
IFLA_BOND_ALL_SLAVES_ACTIVE
|
||||||
|
IFLA_BOND_MIN_LINKS
|
||||||
|
IFLA_BOND_LP_INTERVAL
|
||||||
|
IFLA_BOND_PACKETS_PER_SLAVE
|
||||||
|
IFLA_BOND_AD_LACP_RATE
|
||||||
|
IFLA_BOND_AD_SELECT
|
||||||
|
IFLA_BOND_AD_INFO
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
IFLA_BOND_AD_INFO_UNSPEC = iota
|
||||||
|
IFLA_BOND_AD_INFO_AGGREGATOR
|
||||||
|
IFLA_BOND_AD_INFO_NUM_PORTS
|
||||||
|
IFLA_BOND_AD_INFO_ACTOR_KEY
|
||||||
|
IFLA_BOND_AD_INFO_PARTNER_KEY
|
||||||
|
IFLA_BOND_AD_INFO_PARTNER_MAC
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
IFLA_BOND_SLAVE_UNSPEC = iota
|
||||||
|
IFLA_BOND_SLAVE_STATE
|
||||||
|
IFLA_BOND_SLAVE_MII_STATUS
|
||||||
|
IFLA_BOND_SLAVE_LINK_FAILURE_COUNT
|
||||||
|
IFLA_BOND_SLAVE_PERM_HWADDR
|
||||||
|
IFLA_BOND_SLAVE_QUEUE_ID
|
||||||
|
IFLA_BOND_SLAVE_AD_AGGREGATOR_ID
|
||||||
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user