binapi: remove internal/testbinapi
[govpp.git] / internal / testbinapi / binapi2001 / bier / bier.ba.go
diff --git a/internal/testbinapi/binapi2001/bier/bier.ba.go b/internal/testbinapi/binapi2001/bier/bier.ba.go
deleted file mode 100644 (file)
index ed46a97..0000000
+++ /dev/null
@@ -1,2011 +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/bier.api.json
-
-// Package bier contains generated bindings for API file bier.api.
-//
-// Contents:
-//   5 aliases
-//   7 enums
-//  11 structs
-//   1 union
-//  22 messages
-//
-package bier
-
-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    = "bier"
-       APIVersion = "1.2.1"
-       VersionCrc = 0x27c878c4
-)
-
-// 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)) + ")"
-}
-
-// 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)) + ")"
-}
-
-// 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
-}
-
-// 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
-}
-
-// BierRoute defines type 'bier_route'.
-type BierRoute struct {
-       BrBp     uint32      `binapi:"u32,name=br_bp" json:"br_bp,omitempty"`
-       BrTblID  BierTableID `binapi:"bier_table_id,name=br_tbl_id" json:"br_tbl_id,omitempty"`
-       BrNPaths uint8       `binapi:"u8,name=br_n_paths" json:"-"`
-       BrPaths  []FibPath   `binapi:"fib_path[br_n_paths],name=br_paths" json:"br_paths,omitempty"`
-}
-
-// BierTableID defines type 'bier_table_id'.
-type BierTableID struct {
-       BtSet       uint8 `binapi:"u8,name=bt_set" json:"bt_set,omitempty"`
-       BtSubDomain uint8 `binapi:"u8,name=bt_sub_domain" json:"bt_sub_domain,omitempty"`
-       BtHdrLenID  uint8 `binapi:"u8,name=bt_hdr_len_id" json:"bt_hdr_len_id,omitempty"`
-}
-
-// 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
-}
-
-// 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
-}
-
-// BierDispEntryAddDel defines message 'bier_disp_entry_add_del'.
-type BierDispEntryAddDel struct {
-       BdeBp           uint16    `binapi:"u16,name=bde_bp" json:"bde_bp,omitempty"`
-       BdeTblID        uint32    `binapi:"u32,name=bde_tbl_id" json:"bde_tbl_id,omitempty"`
-       BdeIsAdd        bool      `binapi:"bool,name=bde_is_add" json:"bde_is_add,omitempty"`
-       BdePayloadProto uint8     `binapi:"u8,name=bde_payload_proto" json:"bde_payload_proto,omitempty"`
-       BdeNPaths       uint8     `binapi:"u8,name=bde_n_paths" json:"-"`
-       BdePaths        []FibPath `binapi:"fib_path[bde_n_paths],name=bde_paths" json:"bde_paths,omitempty"`
-}
-
-func (m *BierDispEntryAddDel) Reset()               { *m = BierDispEntryAddDel{} }
-func (*BierDispEntryAddDel) GetMessageName() string { return "bier_disp_entry_add_del" }
-func (*BierDispEntryAddDel) GetCrcString() string   { return "648323eb" }
-func (*BierDispEntryAddDel) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierDispEntryAddDel) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 2 // m.BdeBp
-       size += 4 // m.BdeTblID
-       size += 1 // m.BdeIsAdd
-       size += 1 // m.BdePayloadProto
-       size += 1 // m.BdeNPaths
-       for j1 := 0; j1 < len(m.BdePaths); j1++ {
-               var s1 FibPath
-               _ = s1
-               if j1 < len(m.BdePaths) {
-                       s1 = m.BdePaths[j1]
-               }
-               size += 4      // s1.SwIfIndex
-               size += 4      // s1.TableID
-               size += 4      // s1.RpfID
-               size += 1      // s1.Weight
-               size += 1      // s1.Preference
-               size += 4      // s1.Type
-               size += 4      // s1.Flags
-               size += 4      // s1.Proto
-               size += 1 * 16 // s1.Nh.Address
-               size += 4      // s1.Nh.ViaLabel
-               size += 4      // s1.Nh.ObjID
-               size += 4      // s1.Nh.ClassifyTableIndex
-               size += 1      // s1.NLabels
-               for j2 := 0; j2 < 16; j2++ {
-                       size += 1 // s1.LabelStack[j2].IsUniform
-                       size += 4 // s1.LabelStack[j2].Label
-                       size += 1 // s1.LabelStack[j2].TTL
-                       size += 1 // s1.LabelStack[j2].Exp
-               }
-       }
-       return size
-}
-func (m *BierDispEntryAddDel) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint16(m.BdeBp)
-       buf.EncodeUint32(m.BdeTblID)
-       buf.EncodeBool(m.BdeIsAdd)
-       buf.EncodeUint8(m.BdePayloadProto)
-       buf.EncodeUint8(uint8(len(m.BdePaths)))
-       for j0 := 0; j0 < len(m.BdePaths); j0++ {
-               var v0 FibPath // BdePaths
-               if j0 < len(m.BdePaths) {
-                       v0 = m.BdePaths[j0]
-               }
-               buf.EncodeUint32(v0.SwIfIndex)
-               buf.EncodeUint32(v0.TableID)
-               buf.EncodeUint32(v0.RpfID)
-               buf.EncodeUint8(v0.Weight)
-               buf.EncodeUint8(v0.Preference)
-               buf.EncodeUint32(uint32(v0.Type))
-               buf.EncodeUint32(uint32(v0.Flags))
-               buf.EncodeUint32(uint32(v0.Proto))
-               buf.EncodeBytes(v0.Nh.Address.XXX_UnionData[:], 16)
-               buf.EncodeUint32(v0.Nh.ViaLabel)
-               buf.EncodeUint32(v0.Nh.ObjID)
-               buf.EncodeUint32(v0.Nh.ClassifyTableIndex)
-               buf.EncodeUint8(v0.NLabels)
-               for j1 := 0; j1 < 16; j1++ {
-                       buf.EncodeUint8(v0.LabelStack[j1].IsUniform)
-                       buf.EncodeUint32(v0.LabelStack[j1].Label)
-                       buf.EncodeUint8(v0.LabelStack[j1].TTL)
-                       buf.EncodeUint8(v0.LabelStack[j1].Exp)
-               }
-       }
-       return buf.Bytes(), nil
-}
-func (m *BierDispEntryAddDel) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BdeBp = buf.DecodeUint16()
-       m.BdeTblID = buf.DecodeUint32()
-       m.BdeIsAdd = buf.DecodeBool()
-       m.BdePayloadProto = buf.DecodeUint8()
-       m.BdeNPaths = buf.DecodeUint8()
-       m.BdePaths = make([]FibPath, m.BdeNPaths)
-       for j0 := 0; j0 < len(m.BdePaths); j0++ {
-               m.BdePaths[j0].SwIfIndex = buf.DecodeUint32()
-               m.BdePaths[j0].TableID = buf.DecodeUint32()
-               m.BdePaths[j0].RpfID = buf.DecodeUint32()
-               m.BdePaths[j0].Weight = buf.DecodeUint8()
-               m.BdePaths[j0].Preference = buf.DecodeUint8()
-               m.BdePaths[j0].Type = FibPathType(buf.DecodeUint32())
-               m.BdePaths[j0].Flags = FibPathFlags(buf.DecodeUint32())
-               m.BdePaths[j0].Proto = FibPathNhProto(buf.DecodeUint32())
-               copy(m.BdePaths[j0].Nh.Address.XXX_UnionData[:], buf.DecodeBytes(16))
-               m.BdePaths[j0].Nh.ViaLabel = buf.DecodeUint32()
-               m.BdePaths[j0].Nh.ObjID = buf.DecodeUint32()
-               m.BdePaths[j0].Nh.ClassifyTableIndex = buf.DecodeUint32()
-               m.BdePaths[j0].NLabels = buf.DecodeUint8()
-               for j1 := 0; j1 < 16; j1++ {
-                       m.BdePaths[j0].LabelStack[j1].IsUniform = buf.DecodeUint8()
-                       m.BdePaths[j0].LabelStack[j1].Label = buf.DecodeUint32()
-                       m.BdePaths[j0].LabelStack[j1].TTL = buf.DecodeUint8()
-                       m.BdePaths[j0].LabelStack[j1].Exp = buf.DecodeUint8()
-               }
-       }
-       return nil
-}
-
-// BierDispEntryAddDelReply defines message 'bier_disp_entry_add_del_reply'.
-type BierDispEntryAddDelReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *BierDispEntryAddDelReply) Reset()               { *m = BierDispEntryAddDelReply{} }
-func (*BierDispEntryAddDelReply) GetMessageName() string { return "bier_disp_entry_add_del_reply" }
-func (*BierDispEntryAddDelReply) GetCrcString() string   { return "e8d4e804" }
-func (*BierDispEntryAddDelReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierDispEntryAddDelReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *BierDispEntryAddDelReply) 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 *BierDispEntryAddDelReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// BierDispEntryDetails defines message 'bier_disp_entry_details'.
-type BierDispEntryDetails struct {
-       BdeBp           uint16    `binapi:"u16,name=bde_bp" json:"bde_bp,omitempty"`
-       BdeTblID        uint32    `binapi:"u32,name=bde_tbl_id" json:"bde_tbl_id,omitempty"`
-       BdeIsAdd        bool      `binapi:"bool,name=bde_is_add" json:"bde_is_add,omitempty"`
-       BdePayloadProto uint8     `binapi:"u8,name=bde_payload_proto" json:"bde_payload_proto,omitempty"`
-       BdeNPaths       uint8     `binapi:"u8,name=bde_n_paths" json:"-"`
-       BdePaths        []FibPath `binapi:"fib_path[bde_n_paths],name=bde_paths" json:"bde_paths,omitempty"`
-}
-
-func (m *BierDispEntryDetails) Reset()               { *m = BierDispEntryDetails{} }
-func (*BierDispEntryDetails) GetMessageName() string { return "bier_disp_entry_details" }
-func (*BierDispEntryDetails) GetCrcString() string   { return "e5b039a9" }
-func (*BierDispEntryDetails) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierDispEntryDetails) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 2 // m.BdeBp
-       size += 4 // m.BdeTblID
-       size += 1 // m.BdeIsAdd
-       size += 1 // m.BdePayloadProto
-       size += 1 // m.BdeNPaths
-       for j1 := 0; j1 < len(m.BdePaths); j1++ {
-               var s1 FibPath
-               _ = s1
-               if j1 < len(m.BdePaths) {
-                       s1 = m.BdePaths[j1]
-               }
-               size += 4      // s1.SwIfIndex
-               size += 4      // s1.TableID
-               size += 4      // s1.RpfID
-               size += 1      // s1.Weight
-               size += 1      // s1.Preference
-               size += 4      // s1.Type
-               size += 4      // s1.Flags
-               size += 4      // s1.Proto
-               size += 1 * 16 // s1.Nh.Address
-               size += 4      // s1.Nh.ViaLabel
-               size += 4      // s1.Nh.ObjID
-               size += 4      // s1.Nh.ClassifyTableIndex
-               size += 1      // s1.NLabels
-               for j2 := 0; j2 < 16; j2++ {
-                       size += 1 // s1.LabelStack[j2].IsUniform
-                       size += 4 // s1.LabelStack[j2].Label
-                       size += 1 // s1.LabelStack[j2].TTL
-                       size += 1 // s1.LabelStack[j2].Exp
-               }
-       }
-       return size
-}
-func (m *BierDispEntryDetails) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint16(m.BdeBp)
-       buf.EncodeUint32(m.BdeTblID)
-       buf.EncodeBool(m.BdeIsAdd)
-       buf.EncodeUint8(m.BdePayloadProto)
-       buf.EncodeUint8(uint8(len(m.BdePaths)))
-       for j0 := 0; j0 < len(m.BdePaths); j0++ {
-               var v0 FibPath // BdePaths
-               if j0 < len(m.BdePaths) {
-                       v0 = m.BdePaths[j0]
-               }
-               buf.EncodeUint32(v0.SwIfIndex)
-               buf.EncodeUint32(v0.TableID)
-               buf.EncodeUint32(v0.RpfID)
-               buf.EncodeUint8(v0.Weight)
-               buf.EncodeUint8(v0.Preference)
-               buf.EncodeUint32(uint32(v0.Type))
-               buf.EncodeUint32(uint32(v0.Flags))
-               buf.EncodeUint32(uint32(v0.Proto))
-               buf.EncodeBytes(v0.Nh.Address.XXX_UnionData[:], 16)
-               buf.EncodeUint32(v0.Nh.ViaLabel)
-               buf.EncodeUint32(v0.Nh.ObjID)
-               buf.EncodeUint32(v0.Nh.ClassifyTableIndex)
-               buf.EncodeUint8(v0.NLabels)
-               for j1 := 0; j1 < 16; j1++ {
-                       buf.EncodeUint8(v0.LabelStack[j1].IsUniform)
-                       buf.EncodeUint32(v0.LabelStack[j1].Label)
-                       buf.EncodeUint8(v0.LabelStack[j1].TTL)
-                       buf.EncodeUint8(v0.LabelStack[j1].Exp)
-               }
-       }
-       return buf.Bytes(), nil
-}
-func (m *BierDispEntryDetails) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BdeBp = buf.DecodeUint16()
-       m.BdeTblID = buf.DecodeUint32()
-       m.BdeIsAdd = buf.DecodeBool()
-       m.BdePayloadProto = buf.DecodeUint8()
-       m.BdeNPaths = buf.DecodeUint8()
-       m.BdePaths = make([]FibPath, m.BdeNPaths)
-       for j0 := 0; j0 < len(m.BdePaths); j0++ {
-               m.BdePaths[j0].SwIfIndex = buf.DecodeUint32()
-               m.BdePaths[j0].TableID = buf.DecodeUint32()
-               m.BdePaths[j0].RpfID = buf.DecodeUint32()
-               m.BdePaths[j0].Weight = buf.DecodeUint8()
-               m.BdePaths[j0].Preference = buf.DecodeUint8()
-               m.BdePaths[j0].Type = FibPathType(buf.DecodeUint32())
-               m.BdePaths[j0].Flags = FibPathFlags(buf.DecodeUint32())
-               m.BdePaths[j0].Proto = FibPathNhProto(buf.DecodeUint32())
-               copy(m.BdePaths[j0].Nh.Address.XXX_UnionData[:], buf.DecodeBytes(16))
-               m.BdePaths[j0].Nh.ViaLabel = buf.DecodeUint32()
-               m.BdePaths[j0].Nh.ObjID = buf.DecodeUint32()
-               m.BdePaths[j0].Nh.ClassifyTableIndex = buf.DecodeUint32()
-               m.BdePaths[j0].NLabels = buf.DecodeUint8()
-               for j1 := 0; j1 < 16; j1++ {
-                       m.BdePaths[j0].LabelStack[j1].IsUniform = buf.DecodeUint8()
-                       m.BdePaths[j0].LabelStack[j1].Label = buf.DecodeUint32()
-                       m.BdePaths[j0].LabelStack[j1].TTL = buf.DecodeUint8()
-                       m.BdePaths[j0].LabelStack[j1].Exp = buf.DecodeUint8()
-               }
-       }
-       return nil
-}
-
-// BierDispEntryDump defines message 'bier_disp_entry_dump'.
-type BierDispEntryDump struct {
-       BdeTblID uint32 `binapi:"u32,name=bde_tbl_id" json:"bde_tbl_id,omitempty"`
-}
-
-func (m *BierDispEntryDump) Reset()               { *m = BierDispEntryDump{} }
-func (*BierDispEntryDump) GetMessageName() string { return "bier_disp_entry_dump" }
-func (*BierDispEntryDump) GetCrcString() string   { return "b5fa54ad" }
-func (*BierDispEntryDump) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierDispEntryDump) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.BdeTblID
-       return size
-}
-func (m *BierDispEntryDump) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(m.BdeTblID)
-       return buf.Bytes(), nil
-}
-func (m *BierDispEntryDump) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BdeTblID = buf.DecodeUint32()
-       return nil
-}
-
-// BierDispTableAddDel defines message 'bier_disp_table_add_del'.
-type BierDispTableAddDel struct {
-       BdtTblID uint32 `binapi:"u32,name=bdt_tbl_id" json:"bdt_tbl_id,omitempty"`
-       BdtIsAdd bool   `binapi:"bool,name=bdt_is_add" json:"bdt_is_add,omitempty"`
-}
-
-func (m *BierDispTableAddDel) Reset()               { *m = BierDispTableAddDel{} }
-func (*BierDispTableAddDel) GetMessageName() string { return "bier_disp_table_add_del" }
-func (*BierDispTableAddDel) GetCrcString() string   { return "889657ac" }
-func (*BierDispTableAddDel) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierDispTableAddDel) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.BdtTblID
-       size += 1 // m.BdtIsAdd
-       return size
-}
-func (m *BierDispTableAddDel) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(m.BdtTblID)
-       buf.EncodeBool(m.BdtIsAdd)
-       return buf.Bytes(), nil
-}
-func (m *BierDispTableAddDel) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BdtTblID = buf.DecodeUint32()
-       m.BdtIsAdd = buf.DecodeBool()
-       return nil
-}
-
-// BierDispTableAddDelReply defines message 'bier_disp_table_add_del_reply'.
-type BierDispTableAddDelReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *BierDispTableAddDelReply) Reset()               { *m = BierDispTableAddDelReply{} }
-func (*BierDispTableAddDelReply) GetMessageName() string { return "bier_disp_table_add_del_reply" }
-func (*BierDispTableAddDelReply) GetCrcString() string   { return "e8d4e804" }
-func (*BierDispTableAddDelReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierDispTableAddDelReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *BierDispTableAddDelReply) 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 *BierDispTableAddDelReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// BierDispTableDetails defines message 'bier_disp_table_details'.
-type BierDispTableDetails struct {
-       BdtTblID uint32 `binapi:"u32,name=bdt_tbl_id" json:"bdt_tbl_id,omitempty"`
-}
-
-func (m *BierDispTableDetails) Reset()               { *m = BierDispTableDetails{} }
-func (*BierDispTableDetails) GetMessageName() string { return "bier_disp_table_details" }
-func (*BierDispTableDetails) GetCrcString() string   { return "d27942c0" }
-func (*BierDispTableDetails) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierDispTableDetails) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.BdtTblID
-       return size
-}
-func (m *BierDispTableDetails) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(m.BdtTblID)
-       return buf.Bytes(), nil
-}
-func (m *BierDispTableDetails) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BdtTblID = buf.DecodeUint32()
-       return nil
-}
-
-// BierDispTableDump defines message 'bier_disp_table_dump'.
-type BierDispTableDump struct{}
-
-func (m *BierDispTableDump) Reset()               { *m = BierDispTableDump{} }
-func (*BierDispTableDump) GetMessageName() string { return "bier_disp_table_dump" }
-func (*BierDispTableDump) GetCrcString() string   { return "51077d14" }
-func (*BierDispTableDump) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierDispTableDump) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       return size
-}
-func (m *BierDispTableDump) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       return buf.Bytes(), nil
-}
-func (m *BierDispTableDump) Unmarshal(b []byte) error {
-       return nil
-}
-
-// BierImpAdd defines message 'bier_imp_add'.
-type BierImpAdd struct {
-       BiTblID  BierTableID `binapi:"bier_table_id,name=bi_tbl_id" json:"bi_tbl_id,omitempty"`
-       BiSrc    uint16      `binapi:"u16,name=bi_src" json:"bi_src,omitempty"`
-       BiNBytes uint8       `binapi:"u8,name=bi_n_bytes" json:"-"`
-       BiBytes  []byte      `binapi:"u8[bi_n_bytes],name=bi_bytes" json:"bi_bytes,omitempty"`
-}
-
-func (m *BierImpAdd) Reset()               { *m = BierImpAdd{} }
-func (*BierImpAdd) GetMessageName() string { return "bier_imp_add" }
-func (*BierImpAdd) GetCrcString() string   { return "3856dc3d" }
-func (*BierImpAdd) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierImpAdd) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 1                  // m.BiTblID.BtSet
-       size += 1                  // m.BiTblID.BtSubDomain
-       size += 1                  // m.BiTblID.BtHdrLenID
-       size += 2                  // m.BiSrc
-       size += 1                  // m.BiNBytes
-       size += 1 * len(m.BiBytes) // m.BiBytes
-       return size
-}
-func (m *BierImpAdd) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint8(m.BiTblID.BtSet)
-       buf.EncodeUint8(m.BiTblID.BtSubDomain)
-       buf.EncodeUint8(m.BiTblID.BtHdrLenID)
-       buf.EncodeUint16(m.BiSrc)
-       buf.EncodeUint8(uint8(len(m.BiBytes)))
-       buf.EncodeBytes(m.BiBytes, 0)
-       return buf.Bytes(), nil
-}
-func (m *BierImpAdd) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BiTblID.BtSet = buf.DecodeUint8()
-       m.BiTblID.BtSubDomain = buf.DecodeUint8()
-       m.BiTblID.BtHdrLenID = buf.DecodeUint8()
-       m.BiSrc = buf.DecodeUint16()
-       m.BiNBytes = buf.DecodeUint8()
-       m.BiBytes = make([]byte, m.BiNBytes)
-       copy(m.BiBytes, buf.DecodeBytes(len(m.BiBytes)))
-       return nil
-}
-
-// BierImpAddReply defines message 'bier_imp_add_reply'.
-type BierImpAddReply struct {
-       Retval  int32  `binapi:"i32,name=retval" json:"retval,omitempty"`
-       BiIndex uint32 `binapi:"u32,name=bi_index" json:"bi_index,omitempty"`
-}
-
-func (m *BierImpAddReply) Reset()               { *m = BierImpAddReply{} }
-func (*BierImpAddReply) GetMessageName() string { return "bier_imp_add_reply" }
-func (*BierImpAddReply) GetCrcString() string   { return "d49c5793" }
-func (*BierImpAddReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierImpAddReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       size += 4 // m.BiIndex
-       return size
-}
-func (m *BierImpAddReply) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeInt32(m.Retval)
-       buf.EncodeUint32(m.BiIndex)
-       return buf.Bytes(), nil
-}
-func (m *BierImpAddReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       m.BiIndex = buf.DecodeUint32()
-       return nil
-}
-
-// BierImpDel defines message 'bier_imp_del'.
-type BierImpDel struct {
-       BiIndex uint32 `binapi:"u32,name=bi_index" json:"bi_index,omitempty"`
-}
-
-func (m *BierImpDel) Reset()               { *m = BierImpDel{} }
-func (*BierImpDel) GetMessageName() string { return "bier_imp_del" }
-func (*BierImpDel) GetCrcString() string   { return "7d45edf6" }
-func (*BierImpDel) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierImpDel) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.BiIndex
-       return size
-}
-func (m *BierImpDel) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(m.BiIndex)
-       return buf.Bytes(), nil
-}
-func (m *BierImpDel) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BiIndex = buf.DecodeUint32()
-       return nil
-}
-
-// BierImpDelReply defines message 'bier_imp_del_reply'.
-type BierImpDelReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *BierImpDelReply) Reset()               { *m = BierImpDelReply{} }
-func (*BierImpDelReply) GetMessageName() string { return "bier_imp_del_reply" }
-func (*BierImpDelReply) GetCrcString() string   { return "e8d4e804" }
-func (*BierImpDelReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierImpDelReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *BierImpDelReply) 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 *BierImpDelReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// BierImpDetails defines message 'bier_imp_details'.
-type BierImpDetails struct {
-       BiTblID  BierTableID `binapi:"bier_table_id,name=bi_tbl_id" json:"bi_tbl_id,omitempty"`
-       BiSrc    uint16      `binapi:"u16,name=bi_src" json:"bi_src,omitempty"`
-       BiNBytes uint8       `binapi:"u8,name=bi_n_bytes" json:"-"`
-       BiBytes  []byte      `binapi:"u8[bi_n_bytes],name=bi_bytes" json:"bi_bytes,omitempty"`
-}
-
-func (m *BierImpDetails) Reset()               { *m = BierImpDetails{} }
-func (*BierImpDetails) GetMessageName() string { return "bier_imp_details" }
-func (*BierImpDetails) GetCrcString() string   { return "b76192df" }
-func (*BierImpDetails) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierImpDetails) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 1                  // m.BiTblID.BtSet
-       size += 1                  // m.BiTblID.BtSubDomain
-       size += 1                  // m.BiTblID.BtHdrLenID
-       size += 2                  // m.BiSrc
-       size += 1                  // m.BiNBytes
-       size += 1 * len(m.BiBytes) // m.BiBytes
-       return size
-}
-func (m *BierImpDetails) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint8(m.BiTblID.BtSet)
-       buf.EncodeUint8(m.BiTblID.BtSubDomain)
-       buf.EncodeUint8(m.BiTblID.BtHdrLenID)
-       buf.EncodeUint16(m.BiSrc)
-       buf.EncodeUint8(uint8(len(m.BiBytes)))
-       buf.EncodeBytes(m.BiBytes, 0)
-       return buf.Bytes(), nil
-}
-func (m *BierImpDetails) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BiTblID.BtSet = buf.DecodeUint8()
-       m.BiTblID.BtSubDomain = buf.DecodeUint8()
-       m.BiTblID.BtHdrLenID = buf.DecodeUint8()
-       m.BiSrc = buf.DecodeUint16()
-       m.BiNBytes = buf.DecodeUint8()
-       m.BiBytes = make([]byte, m.BiNBytes)
-       copy(m.BiBytes, buf.DecodeBytes(len(m.BiBytes)))
-       return nil
-}
-
-// BierImpDump defines message 'bier_imp_dump'.
-type BierImpDump struct{}
-
-func (m *BierImpDump) Reset()               { *m = BierImpDump{} }
-func (*BierImpDump) GetMessageName() string { return "bier_imp_dump" }
-func (*BierImpDump) GetCrcString() string   { return "51077d14" }
-func (*BierImpDump) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierImpDump) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       return size
-}
-func (m *BierImpDump) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       return buf.Bytes(), nil
-}
-func (m *BierImpDump) Unmarshal(b []byte) error {
-       return nil
-}
-
-// BierRouteAddDel defines message 'bier_route_add_del'.
-type BierRouteAddDel struct {
-       BrIsAdd     bool      `binapi:"bool,name=br_is_add" json:"br_is_add,omitempty"`
-       BrIsReplace bool      `binapi:"bool,name=br_is_replace" json:"br_is_replace,omitempty"`
-       BrRoute     BierRoute `binapi:"bier_route,name=br_route" json:"br_route,omitempty"`
-}
-
-func (m *BierRouteAddDel) Reset()               { *m = BierRouteAddDel{} }
-func (*BierRouteAddDel) GetMessageName() string { return "bier_route_add_del" }
-func (*BierRouteAddDel) GetCrcString() string   { return "f29edca0" }
-func (*BierRouteAddDel) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierRouteAddDel) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 1 // m.BrIsAdd
-       size += 1 // m.BrIsReplace
-       size += 4 // m.BrRoute.BrBp
-       size += 1 // m.BrRoute.BrTblID.BtSet
-       size += 1 // m.BrRoute.BrTblID.BtSubDomain
-       size += 1 // m.BrRoute.BrTblID.BtHdrLenID
-       size += 1 // m.BrRoute.BrNPaths
-       for j2 := 0; j2 < len(m.BrRoute.BrPaths); j2++ {
-               var s2 FibPath
-               _ = s2
-               if j2 < len(m.BrRoute.BrPaths) {
-                       s2 = m.BrRoute.BrPaths[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 *BierRouteAddDel) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeBool(m.BrIsAdd)
-       buf.EncodeBool(m.BrIsReplace)
-       buf.EncodeUint32(m.BrRoute.BrBp)
-       buf.EncodeUint8(m.BrRoute.BrTblID.BtSet)
-       buf.EncodeUint8(m.BrRoute.BrTblID.BtSubDomain)
-       buf.EncodeUint8(m.BrRoute.BrTblID.BtHdrLenID)
-       buf.EncodeUint8(uint8(len(m.BrRoute.BrPaths)))
-       for j1 := 0; j1 < len(m.BrRoute.BrPaths); j1++ {
-               var v1 FibPath // BrPaths
-               if j1 < len(m.BrRoute.BrPaths) {
-                       v1 = m.BrRoute.BrPaths[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 *BierRouteAddDel) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BrIsAdd = buf.DecodeBool()
-       m.BrIsReplace = buf.DecodeBool()
-       m.BrRoute.BrBp = buf.DecodeUint32()
-       m.BrRoute.BrTblID.BtSet = buf.DecodeUint8()
-       m.BrRoute.BrTblID.BtSubDomain = buf.DecodeUint8()
-       m.BrRoute.BrTblID.BtHdrLenID = buf.DecodeUint8()
-       m.BrRoute.BrNPaths = buf.DecodeUint8()
-       m.BrRoute.BrPaths = make([]FibPath, m.BrRoute.BrNPaths)
-       for j1 := 0; j1 < len(m.BrRoute.BrPaths); j1++ {
-               m.BrRoute.BrPaths[j1].SwIfIndex = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].TableID = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].RpfID = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].Weight = buf.DecodeUint8()
-               m.BrRoute.BrPaths[j1].Preference = buf.DecodeUint8()
-               m.BrRoute.BrPaths[j1].Type = FibPathType(buf.DecodeUint32())
-               m.BrRoute.BrPaths[j1].Flags = FibPathFlags(buf.DecodeUint32())
-               m.BrRoute.BrPaths[j1].Proto = FibPathNhProto(buf.DecodeUint32())
-               copy(m.BrRoute.BrPaths[j1].Nh.Address.XXX_UnionData[:], buf.DecodeBytes(16))
-               m.BrRoute.BrPaths[j1].Nh.ViaLabel = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].Nh.ObjID = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].Nh.ClassifyTableIndex = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].NLabels = buf.DecodeUint8()
-               for j2 := 0; j2 < 16; j2++ {
-                       m.BrRoute.BrPaths[j1].LabelStack[j2].IsUniform = buf.DecodeUint8()
-                       m.BrRoute.BrPaths[j1].LabelStack[j2].Label = buf.DecodeUint32()
-                       m.BrRoute.BrPaths[j1].LabelStack[j2].TTL = buf.DecodeUint8()
-                       m.BrRoute.BrPaths[j1].LabelStack[j2].Exp = buf.DecodeUint8()
-               }
-       }
-       return nil
-}
-
-// BierRouteAddDelReply defines message 'bier_route_add_del_reply'.
-type BierRouteAddDelReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *BierRouteAddDelReply) Reset()               { *m = BierRouteAddDelReply{} }
-func (*BierRouteAddDelReply) GetMessageName() string { return "bier_route_add_del_reply" }
-func (*BierRouteAddDelReply) GetCrcString() string   { return "e8d4e804" }
-func (*BierRouteAddDelReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierRouteAddDelReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *BierRouteAddDelReply) 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 *BierRouteAddDelReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// BierRouteDetails defines message 'bier_route_details'.
-type BierRouteDetails struct {
-       BrRoute BierRoute `binapi:"bier_route,name=br_route" json:"br_route,omitempty"`
-}
-
-func (m *BierRouteDetails) Reset()               { *m = BierRouteDetails{} }
-func (*BierRouteDetails) GetMessageName() string { return "bier_route_details" }
-func (*BierRouteDetails) GetCrcString() string   { return "39ee6a56" }
-func (*BierRouteDetails) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierRouteDetails) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.BrRoute.BrBp
-       size += 1 // m.BrRoute.BrTblID.BtSet
-       size += 1 // m.BrRoute.BrTblID.BtSubDomain
-       size += 1 // m.BrRoute.BrTblID.BtHdrLenID
-       size += 1 // m.BrRoute.BrNPaths
-       for j2 := 0; j2 < len(m.BrRoute.BrPaths); j2++ {
-               var s2 FibPath
-               _ = s2
-               if j2 < len(m.BrRoute.BrPaths) {
-                       s2 = m.BrRoute.BrPaths[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 *BierRouteDetails) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(m.BrRoute.BrBp)
-       buf.EncodeUint8(m.BrRoute.BrTblID.BtSet)
-       buf.EncodeUint8(m.BrRoute.BrTblID.BtSubDomain)
-       buf.EncodeUint8(m.BrRoute.BrTblID.BtHdrLenID)
-       buf.EncodeUint8(uint8(len(m.BrRoute.BrPaths)))
-       for j1 := 0; j1 < len(m.BrRoute.BrPaths); j1++ {
-               var v1 FibPath // BrPaths
-               if j1 < len(m.BrRoute.BrPaths) {
-                       v1 = m.BrRoute.BrPaths[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 *BierRouteDetails) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BrRoute.BrBp = buf.DecodeUint32()
-       m.BrRoute.BrTblID.BtSet = buf.DecodeUint8()
-       m.BrRoute.BrTblID.BtSubDomain = buf.DecodeUint8()
-       m.BrRoute.BrTblID.BtHdrLenID = buf.DecodeUint8()
-       m.BrRoute.BrNPaths = buf.DecodeUint8()
-       m.BrRoute.BrPaths = make([]FibPath, m.BrRoute.BrNPaths)
-       for j1 := 0; j1 < len(m.BrRoute.BrPaths); j1++ {
-               m.BrRoute.BrPaths[j1].SwIfIndex = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].TableID = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].RpfID = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].Weight = buf.DecodeUint8()
-               m.BrRoute.BrPaths[j1].Preference = buf.DecodeUint8()
-               m.BrRoute.BrPaths[j1].Type = FibPathType(buf.DecodeUint32())
-               m.BrRoute.BrPaths[j1].Flags = FibPathFlags(buf.DecodeUint32())
-               m.BrRoute.BrPaths[j1].Proto = FibPathNhProto(buf.DecodeUint32())
-               copy(m.BrRoute.BrPaths[j1].Nh.Address.XXX_UnionData[:], buf.DecodeBytes(16))
-               m.BrRoute.BrPaths[j1].Nh.ViaLabel = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].Nh.ObjID = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].Nh.ClassifyTableIndex = buf.DecodeUint32()
-               m.BrRoute.BrPaths[j1].NLabels = buf.DecodeUint8()
-               for j2 := 0; j2 < 16; j2++ {
-                       m.BrRoute.BrPaths[j1].LabelStack[j2].IsUniform = buf.DecodeUint8()
-                       m.BrRoute.BrPaths[j1].LabelStack[j2].Label = buf.DecodeUint32()
-                       m.BrRoute.BrPaths[j1].LabelStack[j2].TTL = buf.DecodeUint8()
-                       m.BrRoute.BrPaths[j1].LabelStack[j2].Exp = buf.DecodeUint8()
-               }
-       }
-       return nil
-}
-
-// BierRouteDump defines message 'bier_route_dump'.
-type BierRouteDump struct {
-       BrTblID BierTableID `binapi:"bier_table_id,name=br_tbl_id" json:"br_tbl_id,omitempty"`
-}
-
-func (m *BierRouteDump) Reset()               { *m = BierRouteDump{} }
-func (*BierRouteDump) GetMessageName() string { return "bier_route_dump" }
-func (*BierRouteDump) GetCrcString() string   { return "38339846" }
-func (*BierRouteDump) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierRouteDump) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 1 // m.BrTblID.BtSet
-       size += 1 // m.BrTblID.BtSubDomain
-       size += 1 // m.BrTblID.BtHdrLenID
-       return size
-}
-func (m *BierRouteDump) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint8(m.BrTblID.BtSet)
-       buf.EncodeUint8(m.BrTblID.BtSubDomain)
-       buf.EncodeUint8(m.BrTblID.BtHdrLenID)
-       return buf.Bytes(), nil
-}
-func (m *BierRouteDump) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BrTblID.BtSet = buf.DecodeUint8()
-       m.BrTblID.BtSubDomain = buf.DecodeUint8()
-       m.BrTblID.BtHdrLenID = buf.DecodeUint8()
-       return nil
-}
-
-// BierTableAddDel defines message 'bier_table_add_del'.
-type BierTableAddDel struct {
-       BtTblID BierTableID `binapi:"bier_table_id,name=bt_tbl_id" json:"bt_tbl_id,omitempty"`
-       BtLabel uint32      `binapi:"u32,name=bt_label" json:"bt_label,omitempty"`
-       BtIsAdd bool        `binapi:"bool,name=bt_is_add" json:"bt_is_add,omitempty"`
-}
-
-func (m *BierTableAddDel) Reset()               { *m = BierTableAddDel{} }
-func (*BierTableAddDel) GetMessageName() string { return "bier_table_add_del" }
-func (*BierTableAddDel) GetCrcString() string   { return "35e59209" }
-func (*BierTableAddDel) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierTableAddDel) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 1 // m.BtTblID.BtSet
-       size += 1 // m.BtTblID.BtSubDomain
-       size += 1 // m.BtTblID.BtHdrLenID
-       size += 4 // m.BtLabel
-       size += 1 // m.BtIsAdd
-       return size
-}
-func (m *BierTableAddDel) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint8(m.BtTblID.BtSet)
-       buf.EncodeUint8(m.BtTblID.BtSubDomain)
-       buf.EncodeUint8(m.BtTblID.BtHdrLenID)
-       buf.EncodeUint32(m.BtLabel)
-       buf.EncodeBool(m.BtIsAdd)
-       return buf.Bytes(), nil
-}
-func (m *BierTableAddDel) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BtTblID.BtSet = buf.DecodeUint8()
-       m.BtTblID.BtSubDomain = buf.DecodeUint8()
-       m.BtTblID.BtHdrLenID = buf.DecodeUint8()
-       m.BtLabel = buf.DecodeUint32()
-       m.BtIsAdd = buf.DecodeBool()
-       return nil
-}
-
-// BierTableAddDelReply defines message 'bier_table_add_del_reply'.
-type BierTableAddDelReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *BierTableAddDelReply) Reset()               { *m = BierTableAddDelReply{} }
-func (*BierTableAddDelReply) GetMessageName() string { return "bier_table_add_del_reply" }
-func (*BierTableAddDelReply) GetCrcString() string   { return "e8d4e804" }
-func (*BierTableAddDelReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierTableAddDelReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *BierTableAddDelReply) 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 *BierTableAddDelReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// BierTableDetails defines message 'bier_table_details'.
-type BierTableDetails struct {
-       BtLabel uint32      `binapi:"u32,name=bt_label" json:"bt_label,omitempty"`
-       BtTblID BierTableID `binapi:"bier_table_id,name=bt_tbl_id" json:"bt_tbl_id,omitempty"`
-}
-
-func (m *BierTableDetails) Reset()               { *m = BierTableDetails{} }
-func (*BierTableDetails) GetMessageName() string { return "bier_table_details" }
-func (*BierTableDetails) GetCrcString() string   { return "fc44a9dd" }
-func (*BierTableDetails) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *BierTableDetails) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.BtLabel
-       size += 1 // m.BtTblID.BtSet
-       size += 1 // m.BtTblID.BtSubDomain
-       size += 1 // m.BtTblID.BtHdrLenID
-       return size
-}
-func (m *BierTableDetails) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(m.BtLabel)
-       buf.EncodeUint8(m.BtTblID.BtSet)
-       buf.EncodeUint8(m.BtTblID.BtSubDomain)
-       buf.EncodeUint8(m.BtTblID.BtHdrLenID)
-       return buf.Bytes(), nil
-}
-func (m *BierTableDetails) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.BtLabel = buf.DecodeUint32()
-       m.BtTblID.BtSet = buf.DecodeUint8()
-       m.BtTblID.BtSubDomain = buf.DecodeUint8()
-       m.BtTblID.BtHdrLenID = buf.DecodeUint8()
-       return nil
-}
-
-// BierTableDump defines message 'bier_table_dump'.
-type BierTableDump struct{}
-
-func (m *BierTableDump) Reset()               { *m = BierTableDump{} }
-func (*BierTableDump) GetMessageName() string { return "bier_table_dump" }
-func (*BierTableDump) GetCrcString() string   { return "51077d14" }
-func (*BierTableDump) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *BierTableDump) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       return size
-}
-func (m *BierTableDump) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       return buf.Bytes(), nil
-}
-func (m *BierTableDump) Unmarshal(b []byte) error {
-       return nil
-}
-
-func init() { file_bier_binapi_init() }
-func file_bier_binapi_init() {
-       api.RegisterMessage((*BierDispEntryAddDel)(nil), "bier_disp_entry_add_del_648323eb")
-       api.RegisterMessage((*BierDispEntryAddDelReply)(nil), "bier_disp_entry_add_del_reply_e8d4e804")
-       api.RegisterMessage((*BierDispEntryDetails)(nil), "bier_disp_entry_details_e5b039a9")
-       api.RegisterMessage((*BierDispEntryDump)(nil), "bier_disp_entry_dump_b5fa54ad")
-       api.RegisterMessage((*BierDispTableAddDel)(nil), "bier_disp_table_add_del_889657ac")
-       api.RegisterMessage((*BierDispTableAddDelReply)(nil), "bier_disp_table_add_del_reply_e8d4e804")
-       api.RegisterMessage((*BierDispTableDetails)(nil), "bier_disp_table_details_d27942c0")
-       api.RegisterMessage((*BierDispTableDump)(nil), "bier_disp_table_dump_51077d14")
-       api.RegisterMessage((*BierImpAdd)(nil), "bier_imp_add_3856dc3d")
-       api.RegisterMessage((*BierImpAddReply)(nil), "bier_imp_add_reply_d49c5793")
-       api.RegisterMessage((*BierImpDel)(nil), "bier_imp_del_7d45edf6")
-       api.RegisterMessage((*BierImpDelReply)(nil), "bier_imp_del_reply_e8d4e804")
-       api.RegisterMessage((*BierImpDetails)(nil), "bier_imp_details_b76192df")
-       api.RegisterMessage((*BierImpDump)(nil), "bier_imp_dump_51077d14")
-       api.RegisterMessage((*BierRouteAddDel)(nil), "bier_route_add_del_f29edca0")
-       api.RegisterMessage((*BierRouteAddDelReply)(nil), "bier_route_add_del_reply_e8d4e804")
-       api.RegisterMessage((*BierRouteDetails)(nil), "bier_route_details_39ee6a56")
-       api.RegisterMessage((*BierRouteDump)(nil), "bier_route_dump_38339846")
-       api.RegisterMessage((*BierTableAddDel)(nil), "bier_table_add_del_35e59209")
-       api.RegisterMessage((*BierTableAddDelReply)(nil), "bier_table_add_del_reply_e8d4e804")
-       api.RegisterMessage((*BierTableDetails)(nil), "bier_table_details_fc44a9dd")
-       api.RegisterMessage((*BierTableDump)(nil), "bier_table_dump_51077d14")
-}
-
-// Messages returns list of all messages in this module.
-func AllMessages() []api.Message {
-       return []api.Message{
-               (*BierDispEntryAddDel)(nil),
-               (*BierDispEntryAddDelReply)(nil),
-               (*BierDispEntryDetails)(nil),
-               (*BierDispEntryDump)(nil),
-               (*BierDispTableAddDel)(nil),
-               (*BierDispTableAddDelReply)(nil),
-               (*BierDispTableDetails)(nil),
-               (*BierDispTableDump)(nil),
-               (*BierImpAdd)(nil),
-               (*BierImpAddReply)(nil),
-               (*BierImpDel)(nil),
-               (*BierImpDelReply)(nil),
-               (*BierImpDetails)(nil),
-               (*BierImpDump)(nil),
-               (*BierRouteAddDel)(nil),
-               (*BierRouteAddDelReply)(nil),
-               (*BierRouteDetails)(nil),
-               (*BierRouteDump)(nil),
-               (*BierTableAddDel)(nil),
-               (*BierTableAddDelReply)(nil),
-               (*BierTableDetails)(nil),
-               (*BierTableDump)(nil),
-       }
-}