diff options
Diffstat (limited to 'internal/testbinapi/binapi2001/mpls')
-rw-r--r-- | internal/testbinapi/binapi2001/mpls/mpls.ba.go | 2025 | ||||
-rw-r--r-- | internal/testbinapi/binapi2001/mpls/mpls_rpc.ba.go | 193 |
2 files changed, 2218 insertions, 0 deletions
diff --git a/internal/testbinapi/binapi2001/mpls/mpls.ba.go b/internal/testbinapi/binapi2001/mpls/mpls.ba.go new file mode 100644 index 0000000..11ab34b --- /dev/null +++ b/internal/testbinapi/binapi2001/mpls/mpls.ba.go @@ -0,0 +1,2025 @@ +// Code generated by GoVPP's binapi-generator. DO NOT EDIT. +// versions: +// binapi-generator: v0.4.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" + api "git.fd.io/govpp.git/api" + codec "git.fd.io/govpp.git/codec" + "net" + "strconv" + "strings" +) + +// 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) + } + 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, nil +} +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 { + // 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), + } +} diff --git a/internal/testbinapi/binapi2001/mpls/mpls_rpc.ba.go b/internal/testbinapi/binapi2001/mpls/mpls_rpc.ba.go new file mode 100644 index 0000000..422e185 --- /dev/null +++ b/internal/testbinapi/binapi2001/mpls/mpls_rpc.ba.go @@ -0,0 +1,193 @@ +// Code generated by GoVPP's binapi-generator. DO NOT EDIT. + +package mpls + +import ( + "context" + "fmt" + api "git.fd.io/govpp.git/api" + vpe "git.fd.io/govpp.git/internal/testbinapi/binapi2001/vpe" + "io" +) + +// RPCService defines RPC service mpls. +type RPCService interface { + MplsIPBindUnbind(ctx context.Context, in *MplsIPBindUnbind) (*MplsIPBindUnbindReply, error) + MplsRouteAddDel(ctx context.Context, in *MplsRouteAddDel) (*MplsRouteAddDelReply, error) + MplsRouteDump(ctx context.Context, in *MplsRouteDump) (RPCService_MplsRouteDumpClient, error) + MplsTableAddDel(ctx context.Context, in *MplsTableAddDel) (*MplsTableAddDelReply, error) + MplsTableDump(ctx context.Context, in *MplsTableDump) (RPCService_MplsTableDumpClient, error) + MplsTunnelAddDel(ctx context.Context, in *MplsTunnelAddDel) (*MplsTunnelAddDelReply, error) + MplsTunnelDump(ctx context.Context, in *MplsTunnelDump) (RPCService_MplsTunnelDumpClient, error) + SwInterfaceSetMplsEnable(ctx context.Context, in *SwInterfaceSetMplsEnable) (*SwInterfaceSetMplsEnableReply, error) +} + +type serviceClient struct { + conn api.Connection +} + +func NewServiceClient(conn api.Connection) RPCService { + return &serviceClient{conn} +} + +func (c *serviceClient) MplsIPBindUnbind(ctx context.Context, in *MplsIPBindUnbind) (*MplsIPBindUnbindReply, error) { + out := new(MplsIPBindUnbindReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *serviceClient) MplsRouteAddDel(ctx context.Context, in *MplsRouteAddDel) (*MplsRouteAddDelReply, error) { + out := new(MplsRouteAddDelReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *serviceClient) MplsRouteDump(ctx context.Context, in *MplsRouteDump) (RPCService_MplsRouteDumpClient, error) { + stream, err := c.conn.NewStream(ctx) + if err != nil { + return nil, err + } + x := &serviceClient_MplsRouteDumpClient{stream} + if err := x.Stream.SendMsg(in); err != nil { + return nil, err + } + if err = x.Stream.SendMsg(&vpe.ControlPing{}); err != nil { + return nil, err + } + return x, nil +} + +type RPCService_MplsRouteDumpClient interface { + Recv() (*MplsRouteDetails, error) + api.Stream +} + +type serviceClient_MplsRouteDumpClient struct { + api.Stream +} + +func (c *serviceClient_MplsRouteDumpClient) Recv() (*MplsRouteDetails, error) { + msg, err := c.Stream.RecvMsg() + if err != nil { + return nil, err + } + switch m := msg.(type) { + case *MplsRouteDetails: + return m, nil + case *vpe.ControlPingReply: + return nil, io.EOF + default: + return nil, fmt.Errorf("unexpected message: %T %v", m, m) + } +} + +func (c *serviceClient) MplsTableAddDel(ctx context.Context, in *MplsTableAddDel) (*MplsTableAddDelReply, error) { + out := new(MplsTableAddDelReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *serviceClient) MplsTableDump(ctx context.Context, in *MplsTableDump) (RPCService_MplsTableDumpClient, error) { + stream, err := c.conn.NewStream(ctx) + if err != nil { + return nil, err + } + x := &serviceClient_MplsTableDumpClient{stream} + if err := x.Stream.SendMsg(in); err != nil { + return nil, err + } + if err = x.Stream.SendMsg(&vpe.ControlPing{}); err != nil { + return nil, err + } + return x, nil +} + +type RPCService_MplsTableDumpClient interface { + Recv() (*MplsTableDetails, error) + api.Stream +} + +type serviceClient_MplsTableDumpClient struct { + api.Stream +} + +func (c *serviceClient_MplsTableDumpClient) Recv() (*MplsTableDetails, error) { + msg, err := c.Stream.RecvMsg() + if err != nil { + return nil, err + } + switch m := msg.(type) { + case *MplsTableDetails: + return m, nil + case *vpe.ControlPingReply: + return nil, io.EOF + default: + return nil, fmt.Errorf("unexpected message: %T %v", m, m) + } +} + +func (c *serviceClient) MplsTunnelAddDel(ctx context.Context, in *MplsTunnelAddDel) (*MplsTunnelAddDelReply, error) { + out := new(MplsTunnelAddDelReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *serviceClient) MplsTunnelDump(ctx context.Context, in *MplsTunnelDump) (RPCService_MplsTunnelDumpClient, error) { + stream, err := c.conn.NewStream(ctx) + if err != nil { + return nil, err + } + x := &serviceClient_MplsTunnelDumpClient{stream} + if err := x.Stream.SendMsg(in); err != nil { + return nil, err + } + if err = x.Stream.SendMsg(&vpe.ControlPing{}); err != nil { + return nil, err + } + return x, nil +} + +type RPCService_MplsTunnelDumpClient interface { + Recv() (*MplsTunnelDetails, error) + api.Stream +} + +type serviceClient_MplsTunnelDumpClient struct { + api.Stream +} + +func (c *serviceClient_MplsTunnelDumpClient) Recv() (*MplsTunnelDetails, error) { + msg, err := c.Stream.RecvMsg() + if err != nil { + return nil, err + } + switch m := msg.(type) { + case *MplsTunnelDetails: + return m, nil + case *vpe.ControlPingReply: + return nil, io.EOF + default: + return nil, fmt.Errorf("unexpected message: %T %v", m, m) + } +} + +func (c *serviceClient) SwInterfaceSetMplsEnable(ctx context.Context, in *SwInterfaceSetMplsEnable) (*SwInterfaceSetMplsEnableReply, error) { + out := new(SwInterfaceSetMplsEnableReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} |