diff options
Diffstat (limited to 'internal/testbinapi/binapi2001/mpls/mpls.ba.go')
-rw-r--r-- | internal/testbinapi/binapi2001/mpls/mpls.ba.go | 2056 |
1 files changed, 0 insertions, 2056 deletions
diff --git a/internal/testbinapi/binapi2001/mpls/mpls.ba.go b/internal/testbinapi/binapi2001/mpls/mpls.ba.go deleted file mode 100644 index 15c1f46..0000000 --- a/internal/testbinapi/binapi2001/mpls/mpls.ba.go +++ /dev/null @@ -1,2056 +0,0 @@ -// Code generated by GoVPP's binapi-generator. DO NOT EDIT. -// versions: -// binapi-generator: v0.5.0-dev -// VPP: 20.01 -// source: .vppapi/core/mpls.api.json - -// Package mpls contains generated bindings for API file mpls.api. -// -// Contents: -// 6 aliases -// 13 enums -// 12 structs -// 1 union -// 16 messages -// -package mpls - -import ( - "fmt" - "net" - "strconv" - "strings" - - api "git.fd.io/govpp.git/api" - codec "git.fd.io/govpp.git/codec" -) - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the GoVPP api package it is being compiled against. -// A compilation error at this line likely means your copy of the -// GoVPP api package needs to be updated. -const _ = api.GoVppAPIPackageIsVersion2 - -const ( - APIFile = "mpls" - APIVersion = "1.1.1" - VersionCrc = 0xfe593e14 -) - -// AddressFamily defines enum 'address_family'. -type AddressFamily uint32 - -const ( - ADDRESS_IP4 AddressFamily = 0 - ADDRESS_IP6 AddressFamily = 1 -) - -var ( - AddressFamily_name = map[uint32]string{ - 0: "ADDRESS_IP4", - 1: "ADDRESS_IP6", - } - AddressFamily_value = map[string]uint32{ - "ADDRESS_IP4": 0, - "ADDRESS_IP6": 1, - } -) - -func (x AddressFamily) String() string { - s, ok := AddressFamily_name[uint32(x)] - if ok { - return s - } - return "AddressFamily(" + strconv.Itoa(int(x)) + ")" -} - -// FibPathFlags defines enum 'fib_path_flags'. -type FibPathFlags uint32 - -const ( - FIB_API_PATH_FLAG_NONE FibPathFlags = 0 - FIB_API_PATH_FLAG_RESOLVE_VIA_ATTACHED FibPathFlags = 1 - FIB_API_PATH_FLAG_RESOLVE_VIA_HOST FibPathFlags = 2 - FIB_API_PATH_FLAG_POP_PW_CW FibPathFlags = 4 -) - -var ( - FibPathFlags_name = map[uint32]string{ - 0: "FIB_API_PATH_FLAG_NONE", - 1: "FIB_API_PATH_FLAG_RESOLVE_VIA_ATTACHED", - 2: "FIB_API_PATH_FLAG_RESOLVE_VIA_HOST", - 4: "FIB_API_PATH_FLAG_POP_PW_CW", - } - FibPathFlags_value = map[string]uint32{ - "FIB_API_PATH_FLAG_NONE": 0, - "FIB_API_PATH_FLAG_RESOLVE_VIA_ATTACHED": 1, - "FIB_API_PATH_FLAG_RESOLVE_VIA_HOST": 2, - "FIB_API_PATH_FLAG_POP_PW_CW": 4, - } -) - -func (x FibPathFlags) String() string { - s, ok := FibPathFlags_name[uint32(x)] - if ok { - return s - } - str := func(n uint32) string { - s, ok := FibPathFlags_name[uint32(n)] - if ok { - return s - } - return "FibPathFlags(" + strconv.Itoa(int(n)) + ")" - } - for i := uint32(0); i <= 32; i++ { - val := uint32(x) - if val&(1<<i) != 0 { - if s != "" { - s += "|" - } - s += str(1 << i) - } - } - if s == "" { - return str(uint32(x)) - } - return s -} - -// FibPathNhProto defines enum 'fib_path_nh_proto'. -type FibPathNhProto uint32 - -const ( - FIB_API_PATH_NH_PROTO_IP4 FibPathNhProto = 0 - FIB_API_PATH_NH_PROTO_IP6 FibPathNhProto = 1 - FIB_API_PATH_NH_PROTO_MPLS FibPathNhProto = 2 - FIB_API_PATH_NH_PROTO_ETHERNET FibPathNhProto = 3 - FIB_API_PATH_NH_PROTO_BIER FibPathNhProto = 4 -) - -var ( - FibPathNhProto_name = map[uint32]string{ - 0: "FIB_API_PATH_NH_PROTO_IP4", - 1: "FIB_API_PATH_NH_PROTO_IP6", - 2: "FIB_API_PATH_NH_PROTO_MPLS", - 3: "FIB_API_PATH_NH_PROTO_ETHERNET", - 4: "FIB_API_PATH_NH_PROTO_BIER", - } - FibPathNhProto_value = map[string]uint32{ - "FIB_API_PATH_NH_PROTO_IP4": 0, - "FIB_API_PATH_NH_PROTO_IP6": 1, - "FIB_API_PATH_NH_PROTO_MPLS": 2, - "FIB_API_PATH_NH_PROTO_ETHERNET": 3, - "FIB_API_PATH_NH_PROTO_BIER": 4, - } -) - -func (x FibPathNhProto) String() string { - s, ok := FibPathNhProto_name[uint32(x)] - if ok { - return s - } - return "FibPathNhProto(" + strconv.Itoa(int(x)) + ")" -} - -// FibPathType defines enum 'fib_path_type'. -type FibPathType uint32 - -const ( - FIB_API_PATH_TYPE_NORMAL FibPathType = 0 - FIB_API_PATH_TYPE_LOCAL FibPathType = 1 - FIB_API_PATH_TYPE_DROP FibPathType = 2 - FIB_API_PATH_TYPE_UDP_ENCAP FibPathType = 3 - FIB_API_PATH_TYPE_BIER_IMP FibPathType = 4 - FIB_API_PATH_TYPE_ICMP_UNREACH FibPathType = 5 - FIB_API_PATH_TYPE_ICMP_PROHIBIT FibPathType = 6 - FIB_API_PATH_TYPE_SOURCE_LOOKUP FibPathType = 7 - FIB_API_PATH_TYPE_DVR FibPathType = 8 - FIB_API_PATH_TYPE_INTERFACE_RX FibPathType = 9 - FIB_API_PATH_TYPE_CLASSIFY FibPathType = 10 -) - -var ( - FibPathType_name = map[uint32]string{ - 0: "FIB_API_PATH_TYPE_NORMAL", - 1: "FIB_API_PATH_TYPE_LOCAL", - 2: "FIB_API_PATH_TYPE_DROP", - 3: "FIB_API_PATH_TYPE_UDP_ENCAP", - 4: "FIB_API_PATH_TYPE_BIER_IMP", - 5: "FIB_API_PATH_TYPE_ICMP_UNREACH", - 6: "FIB_API_PATH_TYPE_ICMP_PROHIBIT", - 7: "FIB_API_PATH_TYPE_SOURCE_LOOKUP", - 8: "FIB_API_PATH_TYPE_DVR", - 9: "FIB_API_PATH_TYPE_INTERFACE_RX", - 10: "FIB_API_PATH_TYPE_CLASSIFY", - } - FibPathType_value = map[string]uint32{ - "FIB_API_PATH_TYPE_NORMAL": 0, - "FIB_API_PATH_TYPE_LOCAL": 1, - "FIB_API_PATH_TYPE_DROP": 2, - "FIB_API_PATH_TYPE_UDP_ENCAP": 3, - "FIB_API_PATH_TYPE_BIER_IMP": 4, - "FIB_API_PATH_TYPE_ICMP_UNREACH": 5, - "FIB_API_PATH_TYPE_ICMP_PROHIBIT": 6, - "FIB_API_PATH_TYPE_SOURCE_LOOKUP": 7, - "FIB_API_PATH_TYPE_DVR": 8, - "FIB_API_PATH_TYPE_INTERFACE_RX": 9, - "FIB_API_PATH_TYPE_CLASSIFY": 10, - } -) - -func (x FibPathType) String() string { - s, ok := FibPathType_name[uint32(x)] - if ok { - return s - } - return "FibPathType(" + strconv.Itoa(int(x)) + ")" -} - -// IfStatusFlags defines enum 'if_status_flags'. -type IfStatusFlags uint32 - -const ( - IF_STATUS_API_FLAG_ADMIN_UP IfStatusFlags = 1 - IF_STATUS_API_FLAG_LINK_UP IfStatusFlags = 2 -) - -var ( - IfStatusFlags_name = map[uint32]string{ - 1: "IF_STATUS_API_FLAG_ADMIN_UP", - 2: "IF_STATUS_API_FLAG_LINK_UP", - } - IfStatusFlags_value = map[string]uint32{ - "IF_STATUS_API_FLAG_ADMIN_UP": 1, - "IF_STATUS_API_FLAG_LINK_UP": 2, - } -) - -func (x IfStatusFlags) String() string { - s, ok := IfStatusFlags_name[uint32(x)] - if ok { - return s - } - str := func(n uint32) string { - s, ok := IfStatusFlags_name[uint32(n)] - if ok { - return s - } - return "IfStatusFlags(" + strconv.Itoa(int(n)) + ")" - } - for i := uint32(0); i <= 32; i++ { - val := uint32(x) - if val&(1<<i) != 0 { - if s != "" { - s += "|" - } - s += str(1 << i) - } - } - if s == "" { - return str(uint32(x)) - } - return s -} - -// IfType defines enum 'if_type'. -type IfType uint32 - -const ( - IF_API_TYPE_HARDWARE IfType = 1 - IF_API_TYPE_SUB IfType = 2 - IF_API_TYPE_P2P IfType = 3 - IF_API_TYPE_PIPE IfType = 4 -) - -var ( - IfType_name = map[uint32]string{ - 1: "IF_API_TYPE_HARDWARE", - 2: "IF_API_TYPE_SUB", - 3: "IF_API_TYPE_P2P", - 4: "IF_API_TYPE_PIPE", - } - IfType_value = map[string]uint32{ - "IF_API_TYPE_HARDWARE": 1, - "IF_API_TYPE_SUB": 2, - "IF_API_TYPE_P2P": 3, - "IF_API_TYPE_PIPE": 4, - } -) - -func (x IfType) String() string { - s, ok := IfType_name[uint32(x)] - if ok { - return s - } - return "IfType(" + strconv.Itoa(int(x)) + ")" -} - -// IPDscp defines enum 'ip_dscp'. -type IPDscp uint8 - -const ( - IP_API_DSCP_CS0 IPDscp = 0 - IP_API_DSCP_CS1 IPDscp = 8 - IP_API_DSCP_AF11 IPDscp = 10 - IP_API_DSCP_AF12 IPDscp = 12 - IP_API_DSCP_AF13 IPDscp = 14 - IP_API_DSCP_CS2 IPDscp = 16 - IP_API_DSCP_AF21 IPDscp = 18 - IP_API_DSCP_AF22 IPDscp = 20 - IP_API_DSCP_AF23 IPDscp = 22 - IP_API_DSCP_CS3 IPDscp = 24 - IP_API_DSCP_AF31 IPDscp = 26 - IP_API_DSCP_AF32 IPDscp = 28 - IP_API_DSCP_AF33 IPDscp = 30 - IP_API_DSCP_CS4 IPDscp = 32 - IP_API_DSCP_AF41 IPDscp = 34 - IP_API_DSCP_AF42 IPDscp = 36 - IP_API_DSCP_AF43 IPDscp = 38 - IP_API_DSCP_CS5 IPDscp = 40 - IP_API_DSCP_EF IPDscp = 46 - IP_API_DSCP_CS6 IPDscp = 48 - IP_API_DSCP_CS7 IPDscp = 50 -) - -var ( - IPDscp_name = map[uint8]string{ - 0: "IP_API_DSCP_CS0", - 8: "IP_API_DSCP_CS1", - 10: "IP_API_DSCP_AF11", - 12: "IP_API_DSCP_AF12", - 14: "IP_API_DSCP_AF13", - 16: "IP_API_DSCP_CS2", - 18: "IP_API_DSCP_AF21", - 20: "IP_API_DSCP_AF22", - 22: "IP_API_DSCP_AF23", - 24: "IP_API_DSCP_CS3", - 26: "IP_API_DSCP_AF31", - 28: "IP_API_DSCP_AF32", - 30: "IP_API_DSCP_AF33", - 32: "IP_API_DSCP_CS4", - 34: "IP_API_DSCP_AF41", - 36: "IP_API_DSCP_AF42", - 38: "IP_API_DSCP_AF43", - 40: "IP_API_DSCP_CS5", - 46: "IP_API_DSCP_EF", - 48: "IP_API_DSCP_CS6", - 50: "IP_API_DSCP_CS7", - } - IPDscp_value = map[string]uint8{ - "IP_API_DSCP_CS0": 0, - "IP_API_DSCP_CS1": 8, - "IP_API_DSCP_AF11": 10, - "IP_API_DSCP_AF12": 12, - "IP_API_DSCP_AF13": 14, - "IP_API_DSCP_CS2": 16, - "IP_API_DSCP_AF21": 18, - "IP_API_DSCP_AF22": 20, - "IP_API_DSCP_AF23": 22, - "IP_API_DSCP_CS3": 24, - "IP_API_DSCP_AF31": 26, - "IP_API_DSCP_AF32": 28, - "IP_API_DSCP_AF33": 30, - "IP_API_DSCP_CS4": 32, - "IP_API_DSCP_AF41": 34, - "IP_API_DSCP_AF42": 36, - "IP_API_DSCP_AF43": 38, - "IP_API_DSCP_CS5": 40, - "IP_API_DSCP_EF": 46, - "IP_API_DSCP_CS6": 48, - "IP_API_DSCP_CS7": 50, - } -) - -func (x IPDscp) String() string { - s, ok := IPDscp_name[uint8(x)] - if ok { - return s - } - return "IPDscp(" + strconv.Itoa(int(x)) + ")" -} - -// IPEcn defines enum 'ip_ecn'. -type IPEcn uint8 - -const ( - IP_API_ECN_NONE IPEcn = 0 - IP_API_ECN_ECT0 IPEcn = 1 - IP_API_ECN_ECT1 IPEcn = 2 - IP_API_ECN_CE IPEcn = 3 -) - -var ( - IPEcn_name = map[uint8]string{ - 0: "IP_API_ECN_NONE", - 1: "IP_API_ECN_ECT0", - 2: "IP_API_ECN_ECT1", - 3: "IP_API_ECN_CE", - } - IPEcn_value = map[string]uint8{ - "IP_API_ECN_NONE": 0, - "IP_API_ECN_ECT0": 1, - "IP_API_ECN_ECT1": 2, - "IP_API_ECN_CE": 3, - } -) - -func (x IPEcn) String() string { - s, ok := IPEcn_name[uint8(x)] - if ok { - return s - } - return "IPEcn(" + strconv.Itoa(int(x)) + ")" -} - -// IPProto defines enum 'ip_proto'. -type IPProto uint32 - -const ( - IP_API_PROTO_HOPOPT IPProto = 0 - IP_API_PROTO_ICMP IPProto = 1 - IP_API_PROTO_IGMP IPProto = 2 - IP_API_PROTO_TCP IPProto = 6 - IP_API_PROTO_UDP IPProto = 17 - IP_API_PROTO_GRE IPProto = 47 - IP_API_PROTO_AH IPProto = 50 - IP_API_PROTO_ESP IPProto = 51 - IP_API_PROTO_EIGRP IPProto = 88 - IP_API_PROTO_OSPF IPProto = 89 - IP_API_PROTO_SCTP IPProto = 132 - IP_API_PROTO_RESERVED IPProto = 255 -) - -var ( - IPProto_name = map[uint32]string{ - 0: "IP_API_PROTO_HOPOPT", - 1: "IP_API_PROTO_ICMP", - 2: "IP_API_PROTO_IGMP", - 6: "IP_API_PROTO_TCP", - 17: "IP_API_PROTO_UDP", - 47: "IP_API_PROTO_GRE", - 50: "IP_API_PROTO_AH", - 51: "IP_API_PROTO_ESP", - 88: "IP_API_PROTO_EIGRP", - 89: "IP_API_PROTO_OSPF", - 132: "IP_API_PROTO_SCTP", - 255: "IP_API_PROTO_RESERVED", - } - IPProto_value = map[string]uint32{ - "IP_API_PROTO_HOPOPT": 0, - "IP_API_PROTO_ICMP": 1, - "IP_API_PROTO_IGMP": 2, - "IP_API_PROTO_TCP": 6, - "IP_API_PROTO_UDP": 17, - "IP_API_PROTO_GRE": 47, - "IP_API_PROTO_AH": 50, - "IP_API_PROTO_ESP": 51, - "IP_API_PROTO_EIGRP": 88, - "IP_API_PROTO_OSPF": 89, - "IP_API_PROTO_SCTP": 132, - "IP_API_PROTO_RESERVED": 255, - } -) - -func (x IPProto) String() string { - s, ok := IPProto_name[uint32(x)] - if ok { - return s - } - return "IPProto(" + strconv.Itoa(int(x)) + ")" -} - -// LinkDuplex defines enum 'link_duplex'. -type LinkDuplex uint32 - -const ( - LINK_DUPLEX_API_UNKNOWN LinkDuplex = 0 - LINK_DUPLEX_API_HALF LinkDuplex = 1 - LINK_DUPLEX_API_FULL LinkDuplex = 2 -) - -var ( - LinkDuplex_name = map[uint32]string{ - 0: "LINK_DUPLEX_API_UNKNOWN", - 1: "LINK_DUPLEX_API_HALF", - 2: "LINK_DUPLEX_API_FULL", - } - LinkDuplex_value = map[string]uint32{ - "LINK_DUPLEX_API_UNKNOWN": 0, - "LINK_DUPLEX_API_HALF": 1, - "LINK_DUPLEX_API_FULL": 2, - } -) - -func (x LinkDuplex) String() string { - s, ok := LinkDuplex_name[uint32(x)] - if ok { - return s - } - return "LinkDuplex(" + strconv.Itoa(int(x)) + ")" -} - -// MtuProto defines enum 'mtu_proto'. -type MtuProto uint32 - -const ( - MTU_PROTO_API_L3 MtuProto = 1 - MTU_PROTO_API_IP4 MtuProto = 2 - MTU_PROTO_API_IP6 MtuProto = 3 - MTU_PROTO_API_MPLS MtuProto = 4 - MTU_PROTO_API_N MtuProto = 5 -) - -var ( - MtuProto_name = map[uint32]string{ - 1: "MTU_PROTO_API_L3", - 2: "MTU_PROTO_API_IP4", - 3: "MTU_PROTO_API_IP6", - 4: "MTU_PROTO_API_MPLS", - 5: "MTU_PROTO_API_N", - } - MtuProto_value = map[string]uint32{ - "MTU_PROTO_API_L3": 1, - "MTU_PROTO_API_IP4": 2, - "MTU_PROTO_API_IP6": 3, - "MTU_PROTO_API_MPLS": 4, - "MTU_PROTO_API_N": 5, - } -) - -func (x MtuProto) String() string { - s, ok := MtuProto_name[uint32(x)] - if ok { - return s - } - return "MtuProto(" + strconv.Itoa(int(x)) + ")" -} - -// RxMode defines enum 'rx_mode'. -type RxMode uint32 - -const ( - RX_MODE_API_UNKNOWN RxMode = 0 - RX_MODE_API_POLLING RxMode = 1 - RX_MODE_API_INTERRUPT RxMode = 2 - RX_MODE_API_ADAPTIVE RxMode = 3 - RX_MODE_API_DEFAULT RxMode = 4 -) - -var ( - RxMode_name = map[uint32]string{ - 0: "RX_MODE_API_UNKNOWN", - 1: "RX_MODE_API_POLLING", - 2: "RX_MODE_API_INTERRUPT", - 3: "RX_MODE_API_ADAPTIVE", - 4: "RX_MODE_API_DEFAULT", - } - RxMode_value = map[string]uint32{ - "RX_MODE_API_UNKNOWN": 0, - "RX_MODE_API_POLLING": 1, - "RX_MODE_API_INTERRUPT": 2, - "RX_MODE_API_ADAPTIVE": 3, - "RX_MODE_API_DEFAULT": 4, - } -) - -func (x RxMode) String() string { - s, ok := RxMode_name[uint32(x)] - if ok { - return s - } - return "RxMode(" + strconv.Itoa(int(x)) + ")" -} - -// SubIfFlags defines enum 'sub_if_flags'. -type SubIfFlags uint32 - -const ( - SUB_IF_API_FLAG_NO_TAGS SubIfFlags = 1 - SUB_IF_API_FLAG_ONE_TAG SubIfFlags = 2 - SUB_IF_API_FLAG_TWO_TAGS SubIfFlags = 4 - SUB_IF_API_FLAG_DOT1AD SubIfFlags = 8 - SUB_IF_API_FLAG_EXACT_MATCH SubIfFlags = 16 - SUB_IF_API_FLAG_DEFAULT SubIfFlags = 32 - SUB_IF_API_FLAG_OUTER_VLAN_ID_ANY SubIfFlags = 64 - SUB_IF_API_FLAG_INNER_VLAN_ID_ANY SubIfFlags = 128 - SUB_IF_API_FLAG_MASK_VNET SubIfFlags = 254 - SUB_IF_API_FLAG_DOT1AH SubIfFlags = 256 -) - -var ( - SubIfFlags_name = map[uint32]string{ - 1: "SUB_IF_API_FLAG_NO_TAGS", - 2: "SUB_IF_API_FLAG_ONE_TAG", - 4: "SUB_IF_API_FLAG_TWO_TAGS", - 8: "SUB_IF_API_FLAG_DOT1AD", - 16: "SUB_IF_API_FLAG_EXACT_MATCH", - 32: "SUB_IF_API_FLAG_DEFAULT", - 64: "SUB_IF_API_FLAG_OUTER_VLAN_ID_ANY", - 128: "SUB_IF_API_FLAG_INNER_VLAN_ID_ANY", - 254: "SUB_IF_API_FLAG_MASK_VNET", - 256: "SUB_IF_API_FLAG_DOT1AH", - } - SubIfFlags_value = map[string]uint32{ - "SUB_IF_API_FLAG_NO_TAGS": 1, - "SUB_IF_API_FLAG_ONE_TAG": 2, - "SUB_IF_API_FLAG_TWO_TAGS": 4, - "SUB_IF_API_FLAG_DOT1AD": 8, - "SUB_IF_API_FLAG_EXACT_MATCH": 16, - "SUB_IF_API_FLAG_DEFAULT": 32, - "SUB_IF_API_FLAG_OUTER_VLAN_ID_ANY": 64, - "SUB_IF_API_FLAG_INNER_VLAN_ID_ANY": 128, - "SUB_IF_API_FLAG_MASK_VNET": 254, - "SUB_IF_API_FLAG_DOT1AH": 256, - } -) - -func (x SubIfFlags) String() string { - s, ok := SubIfFlags_name[uint32(x)] - if ok { - return s - } - str := func(n uint32) string { - s, ok := SubIfFlags_name[uint32(n)] - if ok { - return s - } - return "SubIfFlags(" + strconv.Itoa(int(n)) + ")" - } - for i := uint32(0); i <= 32; i++ { - val := uint32(x) - if val&(1<<i) != 0 { - if s != "" { - s += "|" - } - s += str(1 << i) - } - } - if s == "" { - return str(uint32(x)) - } - return s -} - -// AddressWithPrefix defines alias 'address_with_prefix'. -type AddressWithPrefix Prefix - -func ParseAddressWithPrefix(s string) (AddressWithPrefix, error) { - prefix, err := ParsePrefix(s) - if err != nil { - return AddressWithPrefix{}, err - } - return AddressWithPrefix(prefix), nil -} - -func (x AddressWithPrefix) String() string { - return Prefix(x).String() -} - -func (x *AddressWithPrefix) MarshalText() ([]byte, error) { - return []byte(x.String()), nil -} - -func (x *AddressWithPrefix) UnmarshalText(text []byte) error { - prefix, err := ParseAddressWithPrefix(string(text)) - if err != nil { - return err - } - *x = prefix - return nil -} - -// InterfaceIndex defines alias 'interface_index'. -type InterfaceIndex uint32 - -// IP4Address defines alias 'ip4_address'. -type IP4Address [4]uint8 - -func ParseIP4Address(s string) (IP4Address, error) { - ip := net.ParseIP(s).To4() - if ip == nil { - return IP4Address{}, fmt.Errorf("invalid IP address: %s", s) - } - var ipaddr IP4Address - copy(ipaddr[:], ip.To4()) - return ipaddr, nil -} - -func (x IP4Address) ToIP() net.IP { - return net.IP(x[:]).To4() -} - -func (x IP4Address) String() string { - return x.ToIP().String() -} - -func (x *IP4Address) MarshalText() ([]byte, error) { - return []byte(x.String()), nil -} - -func (x *IP4Address) UnmarshalText(text []byte) error { - ipaddr, err := ParseIP4Address(string(text)) - if err != nil { - return err - } - *x = ipaddr - return nil -} - -// IP4AddressWithPrefix defines alias 'ip4_address_with_prefix'. -type IP4AddressWithPrefix IP4Prefix - -// IP6Address defines alias 'ip6_address'. -type IP6Address [16]uint8 - -func ParseIP6Address(s string) (IP6Address, error) { - ip := net.ParseIP(s).To16() - if ip == nil { - return IP6Address{}, fmt.Errorf("invalid IP address: %s", s) - } - var ipaddr IP6Address - copy(ipaddr[:], ip.To16()) - return ipaddr, nil -} - -func (x IP6Address) ToIP() net.IP { - return net.IP(x[:]).To16() -} - -func (x IP6Address) String() string { - return x.ToIP().String() -} - -func (x *IP6Address) MarshalText() ([]byte, error) { - return []byte(x.String()), nil -} - -func (x *IP6Address) UnmarshalText(text []byte) error { - ipaddr, err := ParseIP6Address(string(text)) - if err != nil { - return err - } - *x = ipaddr - return nil -} - -// IP6AddressWithPrefix defines alias 'ip6_address_with_prefix'. -type IP6AddressWithPrefix IP6Prefix - -// Address defines type 'address'. -type Address struct { - Af AddressFamily `binapi:"address_family,name=af" json:"af,omitempty"` - Un AddressUnion `binapi:"address_union,name=un" json:"un,omitempty"` -} - -func ParseAddress(s string) (Address, error) { - ip := net.ParseIP(s) - if ip == nil { - return Address{}, fmt.Errorf("invalid address: %s", s) - } - return AddressFromIP(ip), nil -} - -func AddressFromIP(ip net.IP) Address { - var addr Address - if ip.To4() == nil { - addr.Af = ADDRESS_IP6 - var ip6 IP6Address - copy(ip6[:], ip.To16()) - addr.Un.SetIP6(ip6) - } else { - addr.Af = ADDRESS_IP4 - var ip4 IP4Address - copy(ip4[:], ip.To4()) - addr.Un.SetIP4(ip4) - } - return addr -} - -func (x Address) ToIP() net.IP { - if x.Af == ADDRESS_IP6 { - ip6 := x.Un.GetIP6() - return net.IP(ip6[:]).To16() - } else { - ip4 := x.Un.GetIP4() - return net.IP(ip4[:]).To4() - } -} - -func (x Address) String() string { - return x.ToIP().String() -} - -func (x *Address) MarshalText() ([]byte, error) { - return []byte(x.String()), nil -} - -func (x *Address) UnmarshalText(text []byte) error { - addr, err := ParseAddress(string(text)) - if err != nil { - return err - } - *x = addr - return nil -} - -// FibMplsLabel defines type 'fib_mpls_label'. -type FibMplsLabel struct { - IsUniform uint8 `binapi:"u8,name=is_uniform" json:"is_uniform,omitempty"` - Label uint32 `binapi:"u32,name=label" json:"label,omitempty"` - TTL uint8 `binapi:"u8,name=ttl" json:"ttl,omitempty"` - Exp uint8 `binapi:"u8,name=exp" json:"exp,omitempty"` -} - -// FibPath defines type 'fib_path'. -type FibPath struct { - SwIfIndex uint32 `binapi:"u32,name=sw_if_index" json:"sw_if_index,omitempty"` - TableID uint32 `binapi:"u32,name=table_id" json:"table_id,omitempty"` - RpfID uint32 `binapi:"u32,name=rpf_id" json:"rpf_id,omitempty"` - Weight uint8 `binapi:"u8,name=weight" json:"weight,omitempty"` - Preference uint8 `binapi:"u8,name=preference" json:"preference,omitempty"` - Type FibPathType `binapi:"fib_path_type,name=type" json:"type,omitempty"` - Flags FibPathFlags `binapi:"fib_path_flags,name=flags" json:"flags,omitempty"` - Proto FibPathNhProto `binapi:"fib_path_nh_proto,name=proto" json:"proto,omitempty"` - Nh FibPathNh `binapi:"fib_path_nh,name=nh" json:"nh,omitempty"` - NLabels uint8 `binapi:"u8,name=n_labels" json:"n_labels,omitempty"` - LabelStack [16]FibMplsLabel `binapi:"fib_mpls_label[16],name=label_stack" json:"label_stack,omitempty"` -} - -// FibPathNh defines type 'fib_path_nh'. -type FibPathNh struct { - Address AddressUnion `binapi:"address_union,name=address" json:"address,omitempty"` - ViaLabel uint32 `binapi:"u32,name=via_label" json:"via_label,omitempty"` - ObjID uint32 `binapi:"u32,name=obj_id" json:"obj_id,omitempty"` - ClassifyTableIndex uint32 `binapi:"u32,name=classify_table_index" json:"classify_table_index,omitempty"` -} - -// IP4Prefix defines type 'ip4_prefix'. -type IP4Prefix struct { - Address IP4Address `binapi:"ip4_address,name=address" json:"address,omitempty"` - Len uint8 `binapi:"u8,name=len" json:"len,omitempty"` -} - -func ParseIP4Prefix(s string) (prefix IP4Prefix, err error) { - hasPrefix := strings.Contains(s, "/") - if hasPrefix { - ip, network, err := net.ParseCIDR(s) - if err != nil { - return IP4Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) - } - maskSize, _ := network.Mask.Size() - prefix.Len = byte(maskSize) - prefix.Address, err = ParseIP4Address(ip.String()) - if err != nil { - return IP4Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) - } - } else { - ip := net.ParseIP(s) - defaultMaskSize, _ := net.CIDRMask(32, 32).Size() - if ip.To4() == nil { - defaultMaskSize, _ = net.CIDRMask(128, 128).Size() - } - prefix.Len = byte(defaultMaskSize) - prefix.Address, err = ParseIP4Address(ip.String()) - if err != nil { - return IP4Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) - } - } - return prefix, nil -} - -func (x IP4Prefix) ToIPNet() *net.IPNet { - mask := net.CIDRMask(int(x.Len), 32) - ipnet := &net.IPNet{IP: x.Address.ToIP(), Mask: mask} - return ipnet -} - -func (x IP4Prefix) String() string { - ip := x.Address.String() - return ip + "/" + strconv.Itoa(int(x.Len)) -} - -func (x *IP4Prefix) MarshalText() ([]byte, error) { - return []byte(x.String()), nil -} - -func (x *IP4Prefix) UnmarshalText(text []byte) error { - prefix, err := ParseIP4Prefix(string(text)) - if err != nil { - return err - } - *x = prefix - return nil -} - -// IP6Prefix defines type 'ip6_prefix'. -type IP6Prefix struct { - Address IP6Address `binapi:"ip6_address,name=address" json:"address,omitempty"` - Len uint8 `binapi:"u8,name=len" json:"len,omitempty"` -} - -func ParseIP6Prefix(s string) (prefix IP6Prefix, err error) { - hasPrefix := strings.Contains(s, "/") - if hasPrefix { - ip, network, err := net.ParseCIDR(s) - if err != nil { - return IP6Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) - } - maskSize, _ := network.Mask.Size() - prefix.Len = byte(maskSize) - prefix.Address, err = ParseIP6Address(ip.String()) - if err != nil { - return IP6Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) - } - } else { - ip := net.ParseIP(s) - defaultMaskSize, _ := net.CIDRMask(32, 32).Size() - if ip.To4() == nil { - defaultMaskSize, _ = net.CIDRMask(128, 128).Size() - } - prefix.Len = byte(defaultMaskSize) - prefix.Address, err = ParseIP6Address(ip.String()) - if err != nil { - return IP6Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) - } - } - return prefix, nil -} - -func (x IP6Prefix) ToIPNet() *net.IPNet { - mask := net.CIDRMask(int(x.Len), 128) - ipnet := &net.IPNet{IP: x.Address.ToIP(), Mask: mask} - return ipnet -} - -func (x IP6Prefix) String() string { - ip := x.Address.String() - return ip + "/" + strconv.Itoa(int(x.Len)) -} - -func (x *IP6Prefix) MarshalText() ([]byte, error) { - return []byte(x.String()), nil -} - -func (x *IP6Prefix) UnmarshalText(text []byte) error { - prefix, err := ParseIP6Prefix(string(text)) - if err != nil { - return err - } - *x = prefix - return nil -} - -// MplsRoute defines type 'mpls_route'. -type MplsRoute struct { - MrTableID uint32 `binapi:"u32,name=mr_table_id" json:"mr_table_id,omitempty"` - MrLabel uint32 `binapi:"u32,name=mr_label" json:"mr_label,omitempty"` - MrEos uint8 `binapi:"u8,name=mr_eos" json:"mr_eos,omitempty"` - MrEosProto uint8 `binapi:"u8,name=mr_eos_proto" json:"mr_eos_proto,omitempty"` - MrIsMulticast bool `binapi:"bool,name=mr_is_multicast" json:"mr_is_multicast,omitempty"` - MrNPaths uint8 `binapi:"u8,name=mr_n_paths" json:"-"` - MrPaths []FibPath `binapi:"fib_path[mr_n_paths],name=mr_paths" json:"mr_paths,omitempty"` -} - -// MplsTable defines type 'mpls_table'. -type MplsTable struct { - MtTableID uint32 `binapi:"u32,name=mt_table_id" json:"mt_table_id,omitempty"` - MtName string `binapi:"string[64],name=mt_name" json:"mt_name,omitempty"` -} - -// MplsTunnel defines type 'mpls_tunnel'. -type MplsTunnel struct { - MtSwIfIndex InterfaceIndex `binapi:"interface_index,name=mt_sw_if_index" json:"mt_sw_if_index,omitempty"` - MtTunnelIndex uint32 `binapi:"u32,name=mt_tunnel_index" json:"mt_tunnel_index,omitempty"` - MtL2Only bool `binapi:"bool,name=mt_l2_only" json:"mt_l2_only,omitempty"` - MtIsMulticast bool `binapi:"bool,name=mt_is_multicast" json:"mt_is_multicast,omitempty"` - MtNPaths uint8 `binapi:"u8,name=mt_n_paths" json:"-"` - MtPaths []FibPath `binapi:"fib_path[mt_n_paths],name=mt_paths" json:"mt_paths,omitempty"` -} - -// Mprefix defines type 'mprefix'. -type Mprefix struct { - Af AddressFamily `binapi:"address_family,name=af" json:"af,omitempty"` - GrpAddressLength uint16 `binapi:"u16,name=grp_address_length" json:"grp_address_length,omitempty"` - GrpAddress AddressUnion `binapi:"address_union,name=grp_address" json:"grp_address,omitempty"` - SrcAddress AddressUnion `binapi:"address_union,name=src_address" json:"src_address,omitempty"` -} - -// Prefix defines type 'prefix'. -type Prefix struct { - Address Address `binapi:"address,name=address" json:"address,omitempty"` - Len uint8 `binapi:"u8,name=len" json:"len,omitempty"` -} - -func ParsePrefix(ip string) (prefix Prefix, err error) { - hasPrefix := strings.Contains(ip, "/") - if hasPrefix { - netIP, network, err := net.ParseCIDR(ip) - if err != nil { - return Prefix{}, fmt.Errorf("invalid IP %s: %s", ip, err) - } - maskSize, _ := network.Mask.Size() - prefix.Len = byte(maskSize) - prefix.Address, err = ParseAddress(netIP.String()) - if err != nil { - return Prefix{}, fmt.Errorf("invalid IP %s: %s", ip, err) - } - } else { - netIP := net.ParseIP(ip) - defaultMaskSize, _ := net.CIDRMask(32, 32).Size() - if netIP.To4() == nil { - defaultMaskSize, _ = net.CIDRMask(128, 128).Size() - } - prefix.Len = byte(defaultMaskSize) - prefix.Address, err = ParseAddress(netIP.String()) - if err != nil { - return Prefix{}, fmt.Errorf("invalid IP %s: %s", ip, err) - } - } - return prefix, nil -} - -func (x Prefix) ToIPNet() *net.IPNet { - var mask net.IPMask - if x.Address.Af == ADDRESS_IP4 { - mask = net.CIDRMask(int(x.Len), 32) - } else { - mask = net.CIDRMask(int(x.Len), 128) - } - ipnet := &net.IPNet{IP: x.Address.ToIP(), Mask: mask} - return ipnet -} - -func (x Prefix) String() string { - ip := x.Address.String() - return ip + "/" + strconv.Itoa(int(x.Len)) -} - -func (x *Prefix) MarshalText() ([]byte, error) { - return []byte(x.String()), nil -} - -func (x *Prefix) UnmarshalText(text []byte) error { - prefix, err := ParsePrefix(string(text)) - if err != nil { - return err - } - *x = prefix - return nil -} - -// PrefixMatcher defines type 'prefix_matcher'. -type PrefixMatcher struct { - Le uint8 `binapi:"u8,name=le" json:"le,omitempty"` - Ge uint8 `binapi:"u8,name=ge" json:"ge,omitempty"` -} - -// AddressUnion defines union 'address_union'. -type AddressUnion struct { - // AddressUnion can be one of: - // - IP4 *IP4Address - // - IP6 *IP6Address - XXX_UnionData [16]byte -} - -func AddressUnionIP4(a IP4Address) (u AddressUnion) { - u.SetIP4(a) - return -} -func (u *AddressUnion) SetIP4(a IP4Address) { - buf := codec.NewBuffer(u.XXX_UnionData[:]) - buf.EncodeBytes(a[:], 4) -} -func (u *AddressUnion) GetIP4() (a IP4Address) { - buf := codec.NewBuffer(u.XXX_UnionData[:]) - copy(a[:], buf.DecodeBytes(4)) - return -} - -func AddressUnionIP6(a IP6Address) (u AddressUnion) { - u.SetIP6(a) - return -} -func (u *AddressUnion) SetIP6(a IP6Address) { - buf := codec.NewBuffer(u.XXX_UnionData[:]) - buf.EncodeBytes(a[:], 16) -} -func (u *AddressUnion) GetIP6() (a IP6Address) { - buf := codec.NewBuffer(u.XXX_UnionData[:]) - copy(a[:], buf.DecodeBytes(16)) - return -} - -// MplsIPBindUnbind defines message 'mpls_ip_bind_unbind'. -type MplsIPBindUnbind struct { - MbMplsTableID uint32 `binapi:"u32,name=mb_mpls_table_id" json:"mb_mpls_table_id,omitempty"` - MbLabel uint32 `binapi:"u32,name=mb_label" json:"mb_label,omitempty"` - MbIPTableID uint32 `binapi:"u32,name=mb_ip_table_id" json:"mb_ip_table_id,omitempty"` - MbIsBind bool `binapi:"bool,name=mb_is_bind" json:"mb_is_bind,omitempty"` - MbPrefix Prefix `binapi:"prefix,name=mb_prefix" json:"mb_prefix,omitempty"` -} - -func (m *MplsIPBindUnbind) Reset() { *m = MplsIPBindUnbind{} } -func (*MplsIPBindUnbind) GetMessageName() string { return "mpls_ip_bind_unbind" } -func (*MplsIPBindUnbind) GetCrcString() string { return "48249a27" } -func (*MplsIPBindUnbind) GetMessageType() api.MessageType { - return api.RequestMessage -} - -func (m *MplsIPBindUnbind) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.MbMplsTableID - size += 4 // m.MbLabel - size += 4 // m.MbIPTableID - size += 1 // m.MbIsBind - size += 4 // m.MbPrefix.Address.Af - size += 1 * 16 // m.MbPrefix.Address.Un - size += 1 // m.MbPrefix.Len - return size -} -func (m *MplsIPBindUnbind) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeUint32(m.MbMplsTableID) - buf.EncodeUint32(m.MbLabel) - buf.EncodeUint32(m.MbIPTableID) - buf.EncodeBool(m.MbIsBind) - buf.EncodeUint32(uint32(m.MbPrefix.Address.Af)) - buf.EncodeBytes(m.MbPrefix.Address.Un.XXX_UnionData[:], 16) - buf.EncodeUint8(m.MbPrefix.Len) - return buf.Bytes(), nil -} -func (m *MplsIPBindUnbind) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.MbMplsTableID = buf.DecodeUint32() - m.MbLabel = buf.DecodeUint32() - m.MbIPTableID = buf.DecodeUint32() - m.MbIsBind = buf.DecodeBool() - m.MbPrefix.Address.Af = AddressFamily(buf.DecodeUint32()) - copy(m.MbPrefix.Address.Un.XXX_UnionData[:], buf.DecodeBytes(16)) - m.MbPrefix.Len = buf.DecodeUint8() - return nil -} - -// MplsIPBindUnbindReply defines message 'mpls_ip_bind_unbind_reply'. -type MplsIPBindUnbindReply struct { - Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` -} - -func (m *MplsIPBindUnbindReply) Reset() { *m = MplsIPBindUnbindReply{} } -func (*MplsIPBindUnbindReply) GetMessageName() string { return "mpls_ip_bind_unbind_reply" } -func (*MplsIPBindUnbindReply) GetCrcString() string { return "e8d4e804" } -func (*MplsIPBindUnbindReply) GetMessageType() api.MessageType { - return api.ReplyMessage -} - -func (m *MplsIPBindUnbindReply) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.Retval - return size -} -func (m *MplsIPBindUnbindReply) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeInt32(m.Retval) - return buf.Bytes(), nil -} -func (m *MplsIPBindUnbindReply) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.Retval = buf.DecodeInt32() - return nil -} - -// MplsRouteAddDel defines message 'mpls_route_add_del'. -type MplsRouteAddDel struct { - MrIsAdd bool `binapi:"bool,name=mr_is_add" json:"mr_is_add,omitempty"` - MrIsMultipath bool `binapi:"bool,name=mr_is_multipath" json:"mr_is_multipath,omitempty"` - MrRoute MplsRoute `binapi:"mpls_route,name=mr_route" json:"mr_route,omitempty"` -} - -func (m *MplsRouteAddDel) Reset() { *m = MplsRouteAddDel{} } -func (*MplsRouteAddDel) GetMessageName() string { return "mpls_route_add_del" } -func (*MplsRouteAddDel) GetCrcString() string { return "343cff54" } -func (*MplsRouteAddDel) GetMessageType() api.MessageType { - return api.RequestMessage -} - -func (m *MplsRouteAddDel) Size() (size int) { - if m == nil { - return 0 - } - size += 1 // m.MrIsAdd - size += 1 // m.MrIsMultipath - size += 4 // m.MrRoute.MrTableID - size += 4 // m.MrRoute.MrLabel - size += 1 // m.MrRoute.MrEos - size += 1 // m.MrRoute.MrEosProto - size += 1 // m.MrRoute.MrIsMulticast - size += 1 // m.MrRoute.MrNPaths - for j2 := 0; j2 < len(m.MrRoute.MrPaths); j2++ { - var s2 FibPath - _ = s2 - if j2 < len(m.MrRoute.MrPaths) { - s2 = m.MrRoute.MrPaths[j2] - } - size += 4 // s2.SwIfIndex - size += 4 // s2.TableID - size += 4 // s2.RpfID - size += 1 // s2.Weight - size += 1 // s2.Preference - size += 4 // s2.Type - size += 4 // s2.Flags - size += 4 // s2.Proto - size += 1 * 16 // s2.Nh.Address - size += 4 // s2.Nh.ViaLabel - size += 4 // s2.Nh.ObjID - size += 4 // s2.Nh.ClassifyTableIndex - size += 1 // s2.NLabels - for j3 := 0; j3 < 16; j3++ { - size += 1 // s2.LabelStack[j3].IsUniform - size += 4 // s2.LabelStack[j3].Label - size += 1 // s2.LabelStack[j3].TTL - size += 1 // s2.LabelStack[j3].Exp - } - } - return size -} -func (m *MplsRouteAddDel) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeBool(m.MrIsAdd) - buf.EncodeBool(m.MrIsMultipath) - buf.EncodeUint32(m.MrRoute.MrTableID) - buf.EncodeUint32(m.MrRoute.MrLabel) - buf.EncodeUint8(m.MrRoute.MrEos) - buf.EncodeUint8(m.MrRoute.MrEosProto) - buf.EncodeBool(m.MrRoute.MrIsMulticast) - buf.EncodeUint8(uint8(len(m.MrRoute.MrPaths))) - for j1 := 0; j1 < len(m.MrRoute.MrPaths); j1++ { - var v1 FibPath // MrPaths - if j1 < len(m.MrRoute.MrPaths) { - v1 = m.MrRoute.MrPaths[j1] - } - buf.EncodeUint32(v1.SwIfIndex) - buf.EncodeUint32(v1.TableID) - buf.EncodeUint32(v1.RpfID) - buf.EncodeUint8(v1.Weight) - buf.EncodeUint8(v1.Preference) - buf.EncodeUint32(uint32(v1.Type)) - buf.EncodeUint32(uint32(v1.Flags)) - buf.EncodeUint32(uint32(v1.Proto)) - buf.EncodeBytes(v1.Nh.Address.XXX_UnionData[:], 16) - buf.EncodeUint32(v1.Nh.ViaLabel) - buf.EncodeUint32(v1.Nh.ObjID) - buf.EncodeUint32(v1.Nh.ClassifyTableIndex) - buf.EncodeUint8(v1.NLabels) - for j2 := 0; j2 < 16; j2++ { - buf.EncodeUint8(v1.LabelStack[j2].IsUniform) - buf.EncodeUint32(v1.LabelStack[j2].Label) - buf.EncodeUint8(v1.LabelStack[j2].TTL) - buf.EncodeUint8(v1.LabelStack[j2].Exp) - } - } - return buf.Bytes(), nil -} -func (m *MplsRouteAddDel) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.MrIsAdd = buf.DecodeBool() - m.MrIsMultipath = buf.DecodeBool() - m.MrRoute.MrTableID = buf.DecodeUint32() - m.MrRoute.MrLabel = buf.DecodeUint32() - m.MrRoute.MrEos = buf.DecodeUint8() - m.MrRoute.MrEosProto = buf.DecodeUint8() - m.MrRoute.MrIsMulticast = buf.DecodeBool() - m.MrRoute.MrNPaths = buf.DecodeUint8() - m.MrRoute.MrPaths = make([]FibPath, m.MrRoute.MrNPaths) - for j1 := 0; j1 < len(m.MrRoute.MrPaths); j1++ { - m.MrRoute.MrPaths[j1].SwIfIndex = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].TableID = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].RpfID = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].Weight = buf.DecodeUint8() - m.MrRoute.MrPaths[j1].Preference = buf.DecodeUint8() - m.MrRoute.MrPaths[j1].Type = FibPathType(buf.DecodeUint32()) - m.MrRoute.MrPaths[j1].Flags = FibPathFlags(buf.DecodeUint32()) - m.MrRoute.MrPaths[j1].Proto = FibPathNhProto(buf.DecodeUint32()) - copy(m.MrRoute.MrPaths[j1].Nh.Address.XXX_UnionData[:], buf.DecodeBytes(16)) - m.MrRoute.MrPaths[j1].Nh.ViaLabel = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].Nh.ObjID = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].Nh.ClassifyTableIndex = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].NLabels = buf.DecodeUint8() - for j2 := 0; j2 < 16; j2++ { - m.MrRoute.MrPaths[j1].LabelStack[j2].IsUniform = buf.DecodeUint8() - m.MrRoute.MrPaths[j1].LabelStack[j2].Label = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].LabelStack[j2].TTL = buf.DecodeUint8() - m.MrRoute.MrPaths[j1].LabelStack[j2].Exp = buf.DecodeUint8() - } - } - return nil -} - -// MplsRouteAddDelReply defines message 'mpls_route_add_del_reply'. -type MplsRouteAddDelReply struct { - Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` - StatsIndex uint32 `binapi:"u32,name=stats_index" json:"stats_index,omitempty"` -} - -func (m *MplsRouteAddDelReply) Reset() { *m = MplsRouteAddDelReply{} } -func (*MplsRouteAddDelReply) GetMessageName() string { return "mpls_route_add_del_reply" } -func (*MplsRouteAddDelReply) GetCrcString() string { return "1992deab" } -func (*MplsRouteAddDelReply) GetMessageType() api.MessageType { - return api.ReplyMessage -} - -func (m *MplsRouteAddDelReply) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.Retval - size += 4 // m.StatsIndex - return size -} -func (m *MplsRouteAddDelReply) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeInt32(m.Retval) - buf.EncodeUint32(m.StatsIndex) - return buf.Bytes(), nil -} -func (m *MplsRouteAddDelReply) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.Retval = buf.DecodeInt32() - m.StatsIndex = buf.DecodeUint32() - return nil -} - -// MplsRouteDetails defines message 'mpls_route_details'. -type MplsRouteDetails struct { - MrRoute MplsRoute `binapi:"mpls_route,name=mr_route" json:"mr_route,omitempty"` -} - -func (m *MplsRouteDetails) Reset() { *m = MplsRouteDetails{} } -func (*MplsRouteDetails) GetMessageName() string { return "mpls_route_details" } -func (*MplsRouteDetails) GetCrcString() string { return "d0ac384c" } -func (*MplsRouteDetails) GetMessageType() api.MessageType { - return api.ReplyMessage -} - -func (m *MplsRouteDetails) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.MrRoute.MrTableID - size += 4 // m.MrRoute.MrLabel - size += 1 // m.MrRoute.MrEos - size += 1 // m.MrRoute.MrEosProto - size += 1 // m.MrRoute.MrIsMulticast - size += 1 // m.MrRoute.MrNPaths - for j2 := 0; j2 < len(m.MrRoute.MrPaths); j2++ { - var s2 FibPath - _ = s2 - if j2 < len(m.MrRoute.MrPaths) { - s2 = m.MrRoute.MrPaths[j2] - } - size += 4 // s2.SwIfIndex - size += 4 // s2.TableID - size += 4 // s2.RpfID - size += 1 // s2.Weight - size += 1 // s2.Preference - size += 4 // s2.Type - size += 4 // s2.Flags - size += 4 // s2.Proto - size += 1 * 16 // s2.Nh.Address - size += 4 // s2.Nh.ViaLabel - size += 4 // s2.Nh.ObjID - size += 4 // s2.Nh.ClassifyTableIndex - size += 1 // s2.NLabels - for j3 := 0; j3 < 16; j3++ { - size += 1 // s2.LabelStack[j3].IsUniform - size += 4 // s2.LabelStack[j3].Label - size += 1 // s2.LabelStack[j3].TTL - size += 1 // s2.LabelStack[j3].Exp - } - } - return size -} -func (m *MplsRouteDetails) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeUint32(m.MrRoute.MrTableID) - buf.EncodeUint32(m.MrRoute.MrLabel) - buf.EncodeUint8(m.MrRoute.MrEos) - buf.EncodeUint8(m.MrRoute.MrEosProto) - buf.EncodeBool(m.MrRoute.MrIsMulticast) - buf.EncodeUint8(uint8(len(m.MrRoute.MrPaths))) - for j1 := 0; j1 < len(m.MrRoute.MrPaths); j1++ { - var v1 FibPath // MrPaths - if j1 < len(m.MrRoute.MrPaths) { - v1 = m.MrRoute.MrPaths[j1] - } - buf.EncodeUint32(v1.SwIfIndex) - buf.EncodeUint32(v1.TableID) - buf.EncodeUint32(v1.RpfID) - buf.EncodeUint8(v1.Weight) - buf.EncodeUint8(v1.Preference) - buf.EncodeUint32(uint32(v1.Type)) - buf.EncodeUint32(uint32(v1.Flags)) - buf.EncodeUint32(uint32(v1.Proto)) - buf.EncodeBytes(v1.Nh.Address.XXX_UnionData[:], 16) - buf.EncodeUint32(v1.Nh.ViaLabel) - buf.EncodeUint32(v1.Nh.ObjID) - buf.EncodeUint32(v1.Nh.ClassifyTableIndex) - buf.EncodeUint8(v1.NLabels) - for j2 := 0; j2 < 16; j2++ { - buf.EncodeUint8(v1.LabelStack[j2].IsUniform) - buf.EncodeUint32(v1.LabelStack[j2].Label) - buf.EncodeUint8(v1.LabelStack[j2].TTL) - buf.EncodeUint8(v1.LabelStack[j2].Exp) - } - } - return buf.Bytes(), nil -} -func (m *MplsRouteDetails) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.MrRoute.MrTableID = buf.DecodeUint32() - m.MrRoute.MrLabel = buf.DecodeUint32() - m.MrRoute.MrEos = buf.DecodeUint8() - m.MrRoute.MrEosProto = buf.DecodeUint8() - m.MrRoute.MrIsMulticast = buf.DecodeBool() - m.MrRoute.MrNPaths = buf.DecodeUint8() - m.MrRoute.MrPaths = make([]FibPath, m.MrRoute.MrNPaths) - for j1 := 0; j1 < len(m.MrRoute.MrPaths); j1++ { - m.MrRoute.MrPaths[j1].SwIfIndex = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].TableID = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].RpfID = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].Weight = buf.DecodeUint8() - m.MrRoute.MrPaths[j1].Preference = buf.DecodeUint8() - m.MrRoute.MrPaths[j1].Type = FibPathType(buf.DecodeUint32()) - m.MrRoute.MrPaths[j1].Flags = FibPathFlags(buf.DecodeUint32()) - m.MrRoute.MrPaths[j1].Proto = FibPathNhProto(buf.DecodeUint32()) - copy(m.MrRoute.MrPaths[j1].Nh.Address.XXX_UnionData[:], buf.DecodeBytes(16)) - m.MrRoute.MrPaths[j1].Nh.ViaLabel = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].Nh.ObjID = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].Nh.ClassifyTableIndex = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].NLabels = buf.DecodeUint8() - for j2 := 0; j2 < 16; j2++ { - m.MrRoute.MrPaths[j1].LabelStack[j2].IsUniform = buf.DecodeUint8() - m.MrRoute.MrPaths[j1].LabelStack[j2].Label = buf.DecodeUint32() - m.MrRoute.MrPaths[j1].LabelStack[j2].TTL = buf.DecodeUint8() - m.MrRoute.MrPaths[j1].LabelStack[j2].Exp = buf.DecodeUint8() - } - } - return nil -} - -// MplsRouteDump defines message 'mpls_route_dump'. -type MplsRouteDump struct { - Table MplsTable `binapi:"mpls_table,name=table" json:"table,omitempty"` -} - -func (m *MplsRouteDump) Reset() { *m = MplsRouteDump{} } -func (*MplsRouteDump) GetMessageName() string { return "mpls_route_dump" } -func (*MplsRouteDump) GetCrcString() string { return "935fdefa" } -func (*MplsRouteDump) GetMessageType() api.MessageType { - return api.RequestMessage -} - -func (m *MplsRouteDump) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.Table.MtTableID - size += 64 // m.Table.MtName - return size -} -func (m *MplsRouteDump) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeUint32(m.Table.MtTableID) - buf.EncodeString(m.Table.MtName, 64) - return buf.Bytes(), nil -} -func (m *MplsRouteDump) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.Table.MtTableID = buf.DecodeUint32() - m.Table.MtName = buf.DecodeString(64) - return nil -} - -// MplsTableAddDel defines message 'mpls_table_add_del'. -type MplsTableAddDel struct { - MtIsAdd bool `binapi:"bool,name=mt_is_add,default=true" json:"mt_is_add,omitempty"` - MtTable MplsTable `binapi:"mpls_table,name=mt_table" json:"mt_table,omitempty"` -} - -func (m *MplsTableAddDel) Reset() { *m = MplsTableAddDel{} } -func (*MplsTableAddDel) GetMessageName() string { return "mpls_table_add_del" } -func (*MplsTableAddDel) GetCrcString() string { return "57817512" } -func (*MplsTableAddDel) GetMessageType() api.MessageType { - return api.RequestMessage -} - -func (m *MplsTableAddDel) Size() (size int) { - if m == nil { - return 0 - } - size += 1 // m.MtIsAdd - size += 4 // m.MtTable.MtTableID - size += 64 // m.MtTable.MtName - return size -} -func (m *MplsTableAddDel) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeBool(m.MtIsAdd) - buf.EncodeUint32(m.MtTable.MtTableID) - buf.EncodeString(m.MtTable.MtName, 64) - return buf.Bytes(), nil -} -func (m *MplsTableAddDel) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.MtIsAdd = buf.DecodeBool() - m.MtTable.MtTableID = buf.DecodeUint32() - m.MtTable.MtName = buf.DecodeString(64) - return nil -} - -// MplsTableAddDelReply defines message 'mpls_table_add_del_reply'. -type MplsTableAddDelReply struct { - Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` -} - -func (m *MplsTableAddDelReply) Reset() { *m = MplsTableAddDelReply{} } -func (*MplsTableAddDelReply) GetMessageName() string { return "mpls_table_add_del_reply" } -func (*MplsTableAddDelReply) GetCrcString() string { return "e8d4e804" } -func (*MplsTableAddDelReply) GetMessageType() api.MessageType { - return api.ReplyMessage -} - -func (m *MplsTableAddDelReply) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.Retval - return size -} -func (m *MplsTableAddDelReply) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeInt32(m.Retval) - return buf.Bytes(), nil -} -func (m *MplsTableAddDelReply) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.Retval = buf.DecodeInt32() - return nil -} - -// MplsTableDetails defines message 'mpls_table_details'. -type MplsTableDetails struct { - MtTable MplsTable `binapi:"mpls_table,name=mt_table" json:"mt_table,omitempty"` -} - -func (m *MplsTableDetails) Reset() { *m = MplsTableDetails{} } -func (*MplsTableDetails) GetMessageName() string { return "mpls_table_details" } -func (*MplsTableDetails) GetCrcString() string { return "f03ecdc8" } -func (*MplsTableDetails) GetMessageType() api.MessageType { - return api.ReplyMessage -} - -func (m *MplsTableDetails) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.MtTable.MtTableID - size += 64 // m.MtTable.MtName - return size -} -func (m *MplsTableDetails) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeUint32(m.MtTable.MtTableID) - buf.EncodeString(m.MtTable.MtName, 64) - return buf.Bytes(), nil -} -func (m *MplsTableDetails) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.MtTable.MtTableID = buf.DecodeUint32() - m.MtTable.MtName = buf.DecodeString(64) - return nil -} - -// MplsTableDump defines message 'mpls_table_dump'. -type MplsTableDump struct{} - -func (m *MplsTableDump) Reset() { *m = MplsTableDump{} } -func (*MplsTableDump) GetMessageName() string { return "mpls_table_dump" } -func (*MplsTableDump) GetCrcString() string { return "51077d14" } -func (*MplsTableDump) GetMessageType() api.MessageType { - return api.RequestMessage -} - -func (m *MplsTableDump) Size() (size int) { - if m == nil { - return 0 - } - return size -} -func (m *MplsTableDump) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - return buf.Bytes(), nil -} -func (m *MplsTableDump) Unmarshal(b []byte) error { - return nil -} - -// MplsTunnelAddDel defines message 'mpls_tunnel_add_del'. -type MplsTunnelAddDel struct { - MtIsAdd bool `binapi:"bool,name=mt_is_add,default=true" json:"mt_is_add,omitempty"` - MtTunnel MplsTunnel `binapi:"mpls_tunnel,name=mt_tunnel" json:"mt_tunnel,omitempty"` -} - -func (m *MplsTunnelAddDel) Reset() { *m = MplsTunnelAddDel{} } -func (*MplsTunnelAddDel) GetMessageName() string { return "mpls_tunnel_add_del" } -func (*MplsTunnelAddDel) GetCrcString() string { return "0de2478e" } -func (*MplsTunnelAddDel) GetMessageType() api.MessageType { - return api.RequestMessage -} - -func (m *MplsTunnelAddDel) Size() (size int) { - if m == nil { - return 0 - } - size += 1 // m.MtIsAdd - size += 4 // m.MtTunnel.MtSwIfIndex - size += 4 // m.MtTunnel.MtTunnelIndex - size += 1 // m.MtTunnel.MtL2Only - size += 1 // m.MtTunnel.MtIsMulticast - size += 1 // m.MtTunnel.MtNPaths - for j2 := 0; j2 < len(m.MtTunnel.MtPaths); j2++ { - var s2 FibPath - _ = s2 - if j2 < len(m.MtTunnel.MtPaths) { - s2 = m.MtTunnel.MtPaths[j2] - } - size += 4 // s2.SwIfIndex - size += 4 // s2.TableID - size += 4 // s2.RpfID - size += 1 // s2.Weight - size += 1 // s2.Preference - size += 4 // s2.Type - size += 4 // s2.Flags - size += 4 // s2.Proto - size += 1 * 16 // s2.Nh.Address - size += 4 // s2.Nh.ViaLabel - size += 4 // s2.Nh.ObjID - size += 4 // s2.Nh.ClassifyTableIndex - size += 1 // s2.NLabels - for j3 := 0; j3 < 16; j3++ { - size += 1 // s2.LabelStack[j3].IsUniform - size += 4 // s2.LabelStack[j3].Label - size += 1 // s2.LabelStack[j3].TTL - size += 1 // s2.LabelStack[j3].Exp - } - } - return size -} -func (m *MplsTunnelAddDel) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeBool(m.MtIsAdd) - buf.EncodeUint32(uint32(m.MtTunnel.MtSwIfIndex)) - buf.EncodeUint32(m.MtTunnel.MtTunnelIndex) - buf.EncodeBool(m.MtTunnel.MtL2Only) - buf.EncodeBool(m.MtTunnel.MtIsMulticast) - buf.EncodeUint8(uint8(len(m.MtTunnel.MtPaths))) - for j1 := 0; j1 < len(m.MtTunnel.MtPaths); j1++ { - var v1 FibPath // MtPaths - if j1 < len(m.MtTunnel.MtPaths) { - v1 = m.MtTunnel.MtPaths[j1] - } - buf.EncodeUint32(v1.SwIfIndex) - buf.EncodeUint32(v1.TableID) - buf.EncodeUint32(v1.RpfID) - buf.EncodeUint8(v1.Weight) - buf.EncodeUint8(v1.Preference) - buf.EncodeUint32(uint32(v1.Type)) - buf.EncodeUint32(uint32(v1.Flags)) - buf.EncodeUint32(uint32(v1.Proto)) - buf.EncodeBytes(v1.Nh.Address.XXX_UnionData[:], 16) - buf.EncodeUint32(v1.Nh.ViaLabel) - buf.EncodeUint32(v1.Nh.ObjID) - buf.EncodeUint32(v1.Nh.ClassifyTableIndex) - buf.EncodeUint8(v1.NLabels) - for j2 := 0; j2 < 16; j2++ { - buf.EncodeUint8(v1.LabelStack[j2].IsUniform) - buf.EncodeUint32(v1.LabelStack[j2].Label) - buf.EncodeUint8(v1.LabelStack[j2].TTL) - buf.EncodeUint8(v1.LabelStack[j2].Exp) - } - } - return buf.Bytes(), nil -} -func (m *MplsTunnelAddDel) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.MtIsAdd = buf.DecodeBool() - m.MtTunnel.MtSwIfIndex = InterfaceIndex(buf.DecodeUint32()) - m.MtTunnel.MtTunnelIndex = buf.DecodeUint32() - m.MtTunnel.MtL2Only = buf.DecodeBool() - m.MtTunnel.MtIsMulticast = buf.DecodeBool() - m.MtTunnel.MtNPaths = buf.DecodeUint8() - m.MtTunnel.MtPaths = make([]FibPath, m.MtTunnel.MtNPaths) - for j1 := 0; j1 < len(m.MtTunnel.MtPaths); j1++ { - m.MtTunnel.MtPaths[j1].SwIfIndex = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].TableID = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].RpfID = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].Weight = buf.DecodeUint8() - m.MtTunnel.MtPaths[j1].Preference = buf.DecodeUint8() - m.MtTunnel.MtPaths[j1].Type = FibPathType(buf.DecodeUint32()) - m.MtTunnel.MtPaths[j1].Flags = FibPathFlags(buf.DecodeUint32()) - m.MtTunnel.MtPaths[j1].Proto = FibPathNhProto(buf.DecodeUint32()) - copy(m.MtTunnel.MtPaths[j1].Nh.Address.XXX_UnionData[:], buf.DecodeBytes(16)) - m.MtTunnel.MtPaths[j1].Nh.ViaLabel = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].Nh.ObjID = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].Nh.ClassifyTableIndex = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].NLabels = buf.DecodeUint8() - for j2 := 0; j2 < 16; j2++ { - m.MtTunnel.MtPaths[j1].LabelStack[j2].IsUniform = buf.DecodeUint8() - m.MtTunnel.MtPaths[j1].LabelStack[j2].Label = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].LabelStack[j2].TTL = buf.DecodeUint8() - m.MtTunnel.MtPaths[j1].LabelStack[j2].Exp = buf.DecodeUint8() - } - } - return nil -} - -// MplsTunnelAddDelReply defines message 'mpls_tunnel_add_del_reply'. -type MplsTunnelAddDelReply struct { - Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` - SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"` - TunnelIndex uint32 `binapi:"u32,name=tunnel_index" json:"tunnel_index,omitempty"` -} - -func (m *MplsTunnelAddDelReply) Reset() { *m = MplsTunnelAddDelReply{} } -func (*MplsTunnelAddDelReply) GetMessageName() string { return "mpls_tunnel_add_del_reply" } -func (*MplsTunnelAddDelReply) GetCrcString() string { return "afb01472" } -func (*MplsTunnelAddDelReply) GetMessageType() api.MessageType { - return api.ReplyMessage -} - -func (m *MplsTunnelAddDelReply) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.Retval - size += 4 // m.SwIfIndex - size += 4 // m.TunnelIndex - return size -} -func (m *MplsTunnelAddDelReply) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeInt32(m.Retval) - buf.EncodeUint32(uint32(m.SwIfIndex)) - buf.EncodeUint32(m.TunnelIndex) - return buf.Bytes(), nil -} -func (m *MplsTunnelAddDelReply) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.Retval = buf.DecodeInt32() - m.SwIfIndex = InterfaceIndex(buf.DecodeUint32()) - m.TunnelIndex = buf.DecodeUint32() - return nil -} - -// MplsTunnelDetails defines message 'mpls_tunnel_details'. -type MplsTunnelDetails struct { - MtTunnel MplsTunnel `binapi:"mpls_tunnel,name=mt_tunnel" json:"mt_tunnel,omitempty"` -} - -func (m *MplsTunnelDetails) Reset() { *m = MplsTunnelDetails{} } -func (*MplsTunnelDetails) GetMessageName() string { return "mpls_tunnel_details" } -func (*MplsTunnelDetails) GetCrcString() string { return "bdc55cce" } -func (*MplsTunnelDetails) GetMessageType() api.MessageType { - return api.ReplyMessage -} - -func (m *MplsTunnelDetails) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.MtTunnel.MtSwIfIndex - size += 4 // m.MtTunnel.MtTunnelIndex - size += 1 // m.MtTunnel.MtL2Only - size += 1 // m.MtTunnel.MtIsMulticast - size += 1 // m.MtTunnel.MtNPaths - for j2 := 0; j2 < len(m.MtTunnel.MtPaths); j2++ { - var s2 FibPath - _ = s2 - if j2 < len(m.MtTunnel.MtPaths) { - s2 = m.MtTunnel.MtPaths[j2] - } - size += 4 // s2.SwIfIndex - size += 4 // s2.TableID - size += 4 // s2.RpfID - size += 1 // s2.Weight - size += 1 // s2.Preference - size += 4 // s2.Type - size += 4 // s2.Flags - size += 4 // s2.Proto - size += 1 * 16 // s2.Nh.Address - size += 4 // s2.Nh.ViaLabel - size += 4 // s2.Nh.ObjID - size += 4 // s2.Nh.ClassifyTableIndex - size += 1 // s2.NLabels - for j3 := 0; j3 < 16; j3++ { - size += 1 // s2.LabelStack[j3].IsUniform - size += 4 // s2.LabelStack[j3].Label - size += 1 // s2.LabelStack[j3].TTL - size += 1 // s2.LabelStack[j3].Exp - } - } - return size -} -func (m *MplsTunnelDetails) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeUint32(uint32(m.MtTunnel.MtSwIfIndex)) - buf.EncodeUint32(m.MtTunnel.MtTunnelIndex) - buf.EncodeBool(m.MtTunnel.MtL2Only) - buf.EncodeBool(m.MtTunnel.MtIsMulticast) - buf.EncodeUint8(uint8(len(m.MtTunnel.MtPaths))) - for j1 := 0; j1 < len(m.MtTunnel.MtPaths); j1++ { - var v1 FibPath // MtPaths - if j1 < len(m.MtTunnel.MtPaths) { - v1 = m.MtTunnel.MtPaths[j1] - } - buf.EncodeUint32(v1.SwIfIndex) - buf.EncodeUint32(v1.TableID) - buf.EncodeUint32(v1.RpfID) - buf.EncodeUint8(v1.Weight) - buf.EncodeUint8(v1.Preference) - buf.EncodeUint32(uint32(v1.Type)) - buf.EncodeUint32(uint32(v1.Flags)) - buf.EncodeUint32(uint32(v1.Proto)) - buf.EncodeBytes(v1.Nh.Address.XXX_UnionData[:], 16) - buf.EncodeUint32(v1.Nh.ViaLabel) - buf.EncodeUint32(v1.Nh.ObjID) - buf.EncodeUint32(v1.Nh.ClassifyTableIndex) - buf.EncodeUint8(v1.NLabels) - for j2 := 0; j2 < 16; j2++ { - buf.EncodeUint8(v1.LabelStack[j2].IsUniform) - buf.EncodeUint32(v1.LabelStack[j2].Label) - buf.EncodeUint8(v1.LabelStack[j2].TTL) - buf.EncodeUint8(v1.LabelStack[j2].Exp) - } - } - return buf.Bytes(), nil -} -func (m *MplsTunnelDetails) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.MtTunnel.MtSwIfIndex = InterfaceIndex(buf.DecodeUint32()) - m.MtTunnel.MtTunnelIndex = buf.DecodeUint32() - m.MtTunnel.MtL2Only = buf.DecodeBool() - m.MtTunnel.MtIsMulticast = buf.DecodeBool() - m.MtTunnel.MtNPaths = buf.DecodeUint8() - m.MtTunnel.MtPaths = make([]FibPath, m.MtTunnel.MtNPaths) - for j1 := 0; j1 < len(m.MtTunnel.MtPaths); j1++ { - m.MtTunnel.MtPaths[j1].SwIfIndex = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].TableID = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].RpfID = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].Weight = buf.DecodeUint8() - m.MtTunnel.MtPaths[j1].Preference = buf.DecodeUint8() - m.MtTunnel.MtPaths[j1].Type = FibPathType(buf.DecodeUint32()) - m.MtTunnel.MtPaths[j1].Flags = FibPathFlags(buf.DecodeUint32()) - m.MtTunnel.MtPaths[j1].Proto = FibPathNhProto(buf.DecodeUint32()) - copy(m.MtTunnel.MtPaths[j1].Nh.Address.XXX_UnionData[:], buf.DecodeBytes(16)) - m.MtTunnel.MtPaths[j1].Nh.ViaLabel = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].Nh.ObjID = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].Nh.ClassifyTableIndex = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].NLabels = buf.DecodeUint8() - for j2 := 0; j2 < 16; j2++ { - m.MtTunnel.MtPaths[j1].LabelStack[j2].IsUniform = buf.DecodeUint8() - m.MtTunnel.MtPaths[j1].LabelStack[j2].Label = buf.DecodeUint32() - m.MtTunnel.MtPaths[j1].LabelStack[j2].TTL = buf.DecodeUint8() - m.MtTunnel.MtPaths[j1].LabelStack[j2].Exp = buf.DecodeUint8() - } - } - return nil -} - -// MplsTunnelDump defines message 'mpls_tunnel_dump'. -type MplsTunnelDump struct { - SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"` -} - -func (m *MplsTunnelDump) Reset() { *m = MplsTunnelDump{} } -func (*MplsTunnelDump) GetMessageName() string { return "mpls_tunnel_dump" } -func (*MplsTunnelDump) GetCrcString() string { return "f9e6675e" } -func (*MplsTunnelDump) GetMessageType() api.MessageType { - return api.RequestMessage -} - -func (m *MplsTunnelDump) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.SwIfIndex - return size -} -func (m *MplsTunnelDump) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeUint32(uint32(m.SwIfIndex)) - return buf.Bytes(), nil -} -func (m *MplsTunnelDump) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.SwIfIndex = InterfaceIndex(buf.DecodeUint32()) - return nil -} - -// SwInterfaceSetMplsEnable defines message 'sw_interface_set_mpls_enable'. -type SwInterfaceSetMplsEnable struct { - SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"` - Enable bool `binapi:"bool,name=enable,default=true" json:"enable,omitempty"` -} - -func (m *SwInterfaceSetMplsEnable) Reset() { *m = SwInterfaceSetMplsEnable{} } -func (*SwInterfaceSetMplsEnable) GetMessageName() string { return "sw_interface_set_mpls_enable" } -func (*SwInterfaceSetMplsEnable) GetCrcString() string { return "ae6cfcfb" } -func (*SwInterfaceSetMplsEnable) GetMessageType() api.MessageType { - return api.RequestMessage -} - -func (m *SwInterfaceSetMplsEnable) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.SwIfIndex - size += 1 // m.Enable - return size -} -func (m *SwInterfaceSetMplsEnable) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeUint32(uint32(m.SwIfIndex)) - buf.EncodeBool(m.Enable) - return buf.Bytes(), nil -} -func (m *SwInterfaceSetMplsEnable) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.SwIfIndex = InterfaceIndex(buf.DecodeUint32()) - m.Enable = buf.DecodeBool() - return nil -} - -// SwInterfaceSetMplsEnableReply defines message 'sw_interface_set_mpls_enable_reply'. -type SwInterfaceSetMplsEnableReply struct { - Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` -} - -func (m *SwInterfaceSetMplsEnableReply) Reset() { *m = SwInterfaceSetMplsEnableReply{} } -func (*SwInterfaceSetMplsEnableReply) GetMessageName() string { - return "sw_interface_set_mpls_enable_reply" -} -func (*SwInterfaceSetMplsEnableReply) GetCrcString() string { return "e8d4e804" } -func (*SwInterfaceSetMplsEnableReply) GetMessageType() api.MessageType { - return api.ReplyMessage -} - -func (m *SwInterfaceSetMplsEnableReply) Size() (size int) { - if m == nil { - return 0 - } - size += 4 // m.Retval - return size -} -func (m *SwInterfaceSetMplsEnableReply) Marshal(b []byte) ([]byte, error) { - if b == nil { - b = make([]byte, m.Size()) - } - buf := codec.NewBuffer(b) - buf.EncodeInt32(m.Retval) - return buf.Bytes(), nil -} -func (m *SwInterfaceSetMplsEnableReply) Unmarshal(b []byte) error { - buf := codec.NewBuffer(b) - m.Retval = buf.DecodeInt32() - return nil -} - -func init() { file_mpls_binapi_init() } -func file_mpls_binapi_init() { - api.RegisterMessage((*MplsIPBindUnbind)(nil), "mpls_ip_bind_unbind_48249a27") - api.RegisterMessage((*MplsIPBindUnbindReply)(nil), "mpls_ip_bind_unbind_reply_e8d4e804") - api.RegisterMessage((*MplsRouteAddDel)(nil), "mpls_route_add_del_343cff54") - api.RegisterMessage((*MplsRouteAddDelReply)(nil), "mpls_route_add_del_reply_1992deab") - api.RegisterMessage((*MplsRouteDetails)(nil), "mpls_route_details_d0ac384c") - api.RegisterMessage((*MplsRouteDump)(nil), "mpls_route_dump_935fdefa") - api.RegisterMessage((*MplsTableAddDel)(nil), "mpls_table_add_del_57817512") - api.RegisterMessage((*MplsTableAddDelReply)(nil), "mpls_table_add_del_reply_e8d4e804") - api.RegisterMessage((*MplsTableDetails)(nil), "mpls_table_details_f03ecdc8") - api.RegisterMessage((*MplsTableDump)(nil), "mpls_table_dump_51077d14") - api.RegisterMessage((*MplsTunnelAddDel)(nil), "mpls_tunnel_add_del_0de2478e") - api.RegisterMessage((*MplsTunnelAddDelReply)(nil), "mpls_tunnel_add_del_reply_afb01472") - api.RegisterMessage((*MplsTunnelDetails)(nil), "mpls_tunnel_details_bdc55cce") - api.RegisterMessage((*MplsTunnelDump)(nil), "mpls_tunnel_dump_f9e6675e") - api.RegisterMessage((*SwInterfaceSetMplsEnable)(nil), "sw_interface_set_mpls_enable_ae6cfcfb") - api.RegisterMessage((*SwInterfaceSetMplsEnableReply)(nil), "sw_interface_set_mpls_enable_reply_e8d4e804") -} - -// Messages returns list of all messages in this module. -func AllMessages() []api.Message { - return []api.Message{ - (*MplsIPBindUnbind)(nil), - (*MplsIPBindUnbindReply)(nil), - (*MplsRouteAddDel)(nil), - (*MplsRouteAddDelReply)(nil), - (*MplsRouteDetails)(nil), - (*MplsRouteDump)(nil), - (*MplsTableAddDel)(nil), - (*MplsTableAddDelReply)(nil), - (*MplsTableDetails)(nil), - (*MplsTableDump)(nil), - (*MplsTunnelAddDel)(nil), - (*MplsTunnelAddDelReply)(nil), - (*MplsTunnelDetails)(nil), - (*MplsTunnelDump)(nil), - (*SwInterfaceSetMplsEnable)(nil), - (*SwInterfaceSetMplsEnableReply)(nil), - } -} |