binapi: remove internal/testbinapi
[govpp.git] / internal / testbinapi / binapi2001 / igmp / igmp.ba.go
diff --git a/internal/testbinapi/binapi2001/igmp/igmp.ba.go b/internal/testbinapi/binapi2001/igmp/igmp.ba.go
deleted file mode 100644 (file)
index 0612a4b..0000000
+++ /dev/null
@@ -1,1717 +0,0 @@
-// Code generated by GoVPP's binapi-generator. DO NOT EDIT.
-// versions:
-//  binapi-generator: v0.5.0-dev
-//  VPP:              20.01
-// source: .vppapi/plugins/igmp.api.json
-
-// Package igmp contains generated bindings for API file igmp.api.
-//
-// Contents:
-//   6 aliases
-//  12 enums
-//   8 structs
-//   1 union
-//  19 messages
-//
-package igmp
-
-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    = "igmp"
-       APIVersion = "1.0.0"
-       VersionCrc = 0xfd1fef7b
-)
-
-// 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)) + ")"
-}
-
-// FilterMode defines enum 'filter_mode'.
-type FilterMode uint32
-
-const (
-       EXCLUDE FilterMode = 0
-       INCLUDE FilterMode = 1
-)
-
-var (
-       FilterMode_name = map[uint32]string{
-               0: "EXCLUDE",
-               1: "INCLUDE",
-       }
-       FilterMode_value = map[string]uint32{
-               "EXCLUDE": 0,
-               "INCLUDE": 1,
-       }
-)
-
-func (x FilterMode) String() string {
-       s, ok := FilterMode_name[uint32(x)]
-       if ok {
-               return s
-       }
-       return "FilterMode(" + strconv.Itoa(int(x)) + ")"
-}
-
-// GroupPrefixType defines enum 'group_prefix_type'.
-type GroupPrefixType uint32
-
-const (
-       ASM GroupPrefixType = 0
-       SSM GroupPrefixType = 1
-)
-
-var (
-       GroupPrefixType_name = map[uint32]string{
-               0: "ASM",
-               1: "SSM",
-       }
-       GroupPrefixType_value = map[string]uint32{
-               "ASM": 0,
-               "SSM": 1,
-       }
-)
-
-func (x GroupPrefixType) String() string {
-       s, ok := GroupPrefixType_name[uint32(x)]
-       if ok {
-               return s
-       }
-       return "GroupPrefixType(" + strconv.Itoa(int(x)) + ")"
-}
-
-// IfStatusFlags defines enum 'if_status_flags'.
-type IfStatusFlags uint32
-
-const (
-       IF_STATUS_API_FLAG_ADMIN_UP IfStatusFlags = 1
-       IF_STATUS_API_FLAG_LINK_UP  IfStatusFlags = 2
-)
-
-var (
-       IfStatusFlags_name = map[uint32]string{
-               1: "IF_STATUS_API_FLAG_ADMIN_UP",
-               2: "IF_STATUS_API_FLAG_LINK_UP",
-       }
-       IfStatusFlags_value = map[string]uint32{
-               "IF_STATUS_API_FLAG_ADMIN_UP": 1,
-               "IF_STATUS_API_FLAG_LINK_UP":  2,
-       }
-)
-
-func (x IfStatusFlags) String() string {
-       s, ok := IfStatusFlags_name[uint32(x)]
-       if ok {
-               return s
-       }
-       str := func(n uint32) string {
-               s, ok := IfStatusFlags_name[uint32(n)]
-               if ok {
-                       return s
-               }
-               return "IfStatusFlags(" + strconv.Itoa(int(n)) + ")"
-       }
-       for i := uint32(0); i <= 32; i++ {
-               val := uint32(x)
-               if val&(1<<i) != 0 {
-                       if s != "" {
-                               s += "|"
-                       }
-                       s += str(1 << i)
-               }
-       }
-       if s == "" {
-               return str(uint32(x))
-       }
-       return s
-}
-
-// IfType defines enum 'if_type'.
-type IfType uint32
-
-const (
-       IF_API_TYPE_HARDWARE IfType = 1
-       IF_API_TYPE_SUB      IfType = 2
-       IF_API_TYPE_P2P      IfType = 3
-       IF_API_TYPE_PIPE     IfType = 4
-)
-
-var (
-       IfType_name = map[uint32]string{
-               1: "IF_API_TYPE_HARDWARE",
-               2: "IF_API_TYPE_SUB",
-               3: "IF_API_TYPE_P2P",
-               4: "IF_API_TYPE_PIPE",
-       }
-       IfType_value = map[string]uint32{
-               "IF_API_TYPE_HARDWARE": 1,
-               "IF_API_TYPE_SUB":      2,
-               "IF_API_TYPE_P2P":      3,
-               "IF_API_TYPE_PIPE":     4,
-       }
-)
-
-func (x IfType) String() string {
-       s, ok := IfType_name[uint32(x)]
-       if ok {
-               return s
-       }
-       return "IfType(" + strconv.Itoa(int(x)) + ")"
-}
-
-// IPDscp defines enum 'ip_dscp'.
-type IPDscp uint8
-
-const (
-       IP_API_DSCP_CS0  IPDscp = 0
-       IP_API_DSCP_CS1  IPDscp = 8
-       IP_API_DSCP_AF11 IPDscp = 10
-       IP_API_DSCP_AF12 IPDscp = 12
-       IP_API_DSCP_AF13 IPDscp = 14
-       IP_API_DSCP_CS2  IPDscp = 16
-       IP_API_DSCP_AF21 IPDscp = 18
-       IP_API_DSCP_AF22 IPDscp = 20
-       IP_API_DSCP_AF23 IPDscp = 22
-       IP_API_DSCP_CS3  IPDscp = 24
-       IP_API_DSCP_AF31 IPDscp = 26
-       IP_API_DSCP_AF32 IPDscp = 28
-       IP_API_DSCP_AF33 IPDscp = 30
-       IP_API_DSCP_CS4  IPDscp = 32
-       IP_API_DSCP_AF41 IPDscp = 34
-       IP_API_DSCP_AF42 IPDscp = 36
-       IP_API_DSCP_AF43 IPDscp = 38
-       IP_API_DSCP_CS5  IPDscp = 40
-       IP_API_DSCP_EF   IPDscp = 46
-       IP_API_DSCP_CS6  IPDscp = 48
-       IP_API_DSCP_CS7  IPDscp = 50
-)
-
-var (
-       IPDscp_name = map[uint8]string{
-               0:  "IP_API_DSCP_CS0",
-               8:  "IP_API_DSCP_CS1",
-               10: "IP_API_DSCP_AF11",
-               12: "IP_API_DSCP_AF12",
-               14: "IP_API_DSCP_AF13",
-               16: "IP_API_DSCP_CS2",
-               18: "IP_API_DSCP_AF21",
-               20: "IP_API_DSCP_AF22",
-               22: "IP_API_DSCP_AF23",
-               24: "IP_API_DSCP_CS3",
-               26: "IP_API_DSCP_AF31",
-               28: "IP_API_DSCP_AF32",
-               30: "IP_API_DSCP_AF33",
-               32: "IP_API_DSCP_CS4",
-               34: "IP_API_DSCP_AF41",
-               36: "IP_API_DSCP_AF42",
-               38: "IP_API_DSCP_AF43",
-               40: "IP_API_DSCP_CS5",
-               46: "IP_API_DSCP_EF",
-               48: "IP_API_DSCP_CS6",
-               50: "IP_API_DSCP_CS7",
-       }
-       IPDscp_value = map[string]uint8{
-               "IP_API_DSCP_CS0":  0,
-               "IP_API_DSCP_CS1":  8,
-               "IP_API_DSCP_AF11": 10,
-               "IP_API_DSCP_AF12": 12,
-               "IP_API_DSCP_AF13": 14,
-               "IP_API_DSCP_CS2":  16,
-               "IP_API_DSCP_AF21": 18,
-               "IP_API_DSCP_AF22": 20,
-               "IP_API_DSCP_AF23": 22,
-               "IP_API_DSCP_CS3":  24,
-               "IP_API_DSCP_AF31": 26,
-               "IP_API_DSCP_AF32": 28,
-               "IP_API_DSCP_AF33": 30,
-               "IP_API_DSCP_CS4":  32,
-               "IP_API_DSCP_AF41": 34,
-               "IP_API_DSCP_AF42": 36,
-               "IP_API_DSCP_AF43": 38,
-               "IP_API_DSCP_CS5":  40,
-               "IP_API_DSCP_EF":   46,
-               "IP_API_DSCP_CS6":  48,
-               "IP_API_DSCP_CS7":  50,
-       }
-)
-
-func (x IPDscp) String() string {
-       s, ok := IPDscp_name[uint8(x)]
-       if ok {
-               return s
-       }
-       return "IPDscp(" + strconv.Itoa(int(x)) + ")"
-}
-
-// IPEcn defines enum 'ip_ecn'.
-type IPEcn uint8
-
-const (
-       IP_API_ECN_NONE IPEcn = 0
-       IP_API_ECN_ECT0 IPEcn = 1
-       IP_API_ECN_ECT1 IPEcn = 2
-       IP_API_ECN_CE   IPEcn = 3
-)
-
-var (
-       IPEcn_name = map[uint8]string{
-               0: "IP_API_ECN_NONE",
-               1: "IP_API_ECN_ECT0",
-               2: "IP_API_ECN_ECT1",
-               3: "IP_API_ECN_CE",
-       }
-       IPEcn_value = map[string]uint8{
-               "IP_API_ECN_NONE": 0,
-               "IP_API_ECN_ECT0": 1,
-               "IP_API_ECN_ECT1": 2,
-               "IP_API_ECN_CE":   3,
-       }
-)
-
-func (x IPEcn) String() string {
-       s, ok := IPEcn_name[uint8(x)]
-       if ok {
-               return s
-       }
-       return "IPEcn(" + strconv.Itoa(int(x)) + ")"
-}
-
-// IPProto defines enum 'ip_proto'.
-type IPProto uint32
-
-const (
-       IP_API_PROTO_HOPOPT   IPProto = 0
-       IP_API_PROTO_ICMP     IPProto = 1
-       IP_API_PROTO_IGMP     IPProto = 2
-       IP_API_PROTO_TCP      IPProto = 6
-       IP_API_PROTO_UDP      IPProto = 17
-       IP_API_PROTO_GRE      IPProto = 47
-       IP_API_PROTO_AH       IPProto = 50
-       IP_API_PROTO_ESP      IPProto = 51
-       IP_API_PROTO_EIGRP    IPProto = 88
-       IP_API_PROTO_OSPF     IPProto = 89
-       IP_API_PROTO_SCTP     IPProto = 132
-       IP_API_PROTO_RESERVED IPProto = 255
-)
-
-var (
-       IPProto_name = map[uint32]string{
-               0:   "IP_API_PROTO_HOPOPT",
-               1:   "IP_API_PROTO_ICMP",
-               2:   "IP_API_PROTO_IGMP",
-               6:   "IP_API_PROTO_TCP",
-               17:  "IP_API_PROTO_UDP",
-               47:  "IP_API_PROTO_GRE",
-               50:  "IP_API_PROTO_AH",
-               51:  "IP_API_PROTO_ESP",
-               88:  "IP_API_PROTO_EIGRP",
-               89:  "IP_API_PROTO_OSPF",
-               132: "IP_API_PROTO_SCTP",
-               255: "IP_API_PROTO_RESERVED",
-       }
-       IPProto_value = map[string]uint32{
-               "IP_API_PROTO_HOPOPT":   0,
-               "IP_API_PROTO_ICMP":     1,
-               "IP_API_PROTO_IGMP":     2,
-               "IP_API_PROTO_TCP":      6,
-               "IP_API_PROTO_UDP":      17,
-               "IP_API_PROTO_GRE":      47,
-               "IP_API_PROTO_AH":       50,
-               "IP_API_PROTO_ESP":      51,
-               "IP_API_PROTO_EIGRP":    88,
-               "IP_API_PROTO_OSPF":     89,
-               "IP_API_PROTO_SCTP":     132,
-               "IP_API_PROTO_RESERVED": 255,
-       }
-)
-
-func (x IPProto) String() string {
-       s, ok := IPProto_name[uint32(x)]
-       if ok {
-               return s
-       }
-       return "IPProto(" + strconv.Itoa(int(x)) + ")"
-}
-
-// LinkDuplex defines enum 'link_duplex'.
-type LinkDuplex uint32
-
-const (
-       LINK_DUPLEX_API_UNKNOWN LinkDuplex = 0
-       LINK_DUPLEX_API_HALF    LinkDuplex = 1
-       LINK_DUPLEX_API_FULL    LinkDuplex = 2
-)
-
-var (
-       LinkDuplex_name = map[uint32]string{
-               0: "LINK_DUPLEX_API_UNKNOWN",
-               1: "LINK_DUPLEX_API_HALF",
-               2: "LINK_DUPLEX_API_FULL",
-       }
-       LinkDuplex_value = map[string]uint32{
-               "LINK_DUPLEX_API_UNKNOWN": 0,
-               "LINK_DUPLEX_API_HALF":    1,
-               "LINK_DUPLEX_API_FULL":    2,
-       }
-)
-
-func (x LinkDuplex) String() string {
-       s, ok := LinkDuplex_name[uint32(x)]
-       if ok {
-               return s
-       }
-       return "LinkDuplex(" + strconv.Itoa(int(x)) + ")"
-}
-
-// MtuProto defines enum 'mtu_proto'.
-type MtuProto uint32
-
-const (
-       MTU_PROTO_API_L3   MtuProto = 1
-       MTU_PROTO_API_IP4  MtuProto = 2
-       MTU_PROTO_API_IP6  MtuProto = 3
-       MTU_PROTO_API_MPLS MtuProto = 4
-       MTU_PROTO_API_N    MtuProto = 5
-)
-
-var (
-       MtuProto_name = map[uint32]string{
-               1: "MTU_PROTO_API_L3",
-               2: "MTU_PROTO_API_IP4",
-               3: "MTU_PROTO_API_IP6",
-               4: "MTU_PROTO_API_MPLS",
-               5: "MTU_PROTO_API_N",
-       }
-       MtuProto_value = map[string]uint32{
-               "MTU_PROTO_API_L3":   1,
-               "MTU_PROTO_API_IP4":  2,
-               "MTU_PROTO_API_IP6":  3,
-               "MTU_PROTO_API_MPLS": 4,
-               "MTU_PROTO_API_N":    5,
-       }
-)
-
-func (x MtuProto) String() string {
-       s, ok := MtuProto_name[uint32(x)]
-       if ok {
-               return s
-       }
-       return "MtuProto(" + strconv.Itoa(int(x)) + ")"
-}
-
-// RxMode defines enum 'rx_mode'.
-type RxMode uint32
-
-const (
-       RX_MODE_API_UNKNOWN   RxMode = 0
-       RX_MODE_API_POLLING   RxMode = 1
-       RX_MODE_API_INTERRUPT RxMode = 2
-       RX_MODE_API_ADAPTIVE  RxMode = 3
-       RX_MODE_API_DEFAULT   RxMode = 4
-)
-
-var (
-       RxMode_name = map[uint32]string{
-               0: "RX_MODE_API_UNKNOWN",
-               1: "RX_MODE_API_POLLING",
-               2: "RX_MODE_API_INTERRUPT",
-               3: "RX_MODE_API_ADAPTIVE",
-               4: "RX_MODE_API_DEFAULT",
-       }
-       RxMode_value = map[string]uint32{
-               "RX_MODE_API_UNKNOWN":   0,
-               "RX_MODE_API_POLLING":   1,
-               "RX_MODE_API_INTERRUPT": 2,
-               "RX_MODE_API_ADAPTIVE":  3,
-               "RX_MODE_API_DEFAULT":   4,
-       }
-)
-
-func (x RxMode) String() string {
-       s, ok := RxMode_name[uint32(x)]
-       if ok {
-               return s
-       }
-       return "RxMode(" + strconv.Itoa(int(x)) + ")"
-}
-
-// SubIfFlags defines enum 'sub_if_flags'.
-type SubIfFlags uint32
-
-const (
-       SUB_IF_API_FLAG_NO_TAGS           SubIfFlags = 1
-       SUB_IF_API_FLAG_ONE_TAG           SubIfFlags = 2
-       SUB_IF_API_FLAG_TWO_TAGS          SubIfFlags = 4
-       SUB_IF_API_FLAG_DOT1AD            SubIfFlags = 8
-       SUB_IF_API_FLAG_EXACT_MATCH       SubIfFlags = 16
-       SUB_IF_API_FLAG_DEFAULT           SubIfFlags = 32
-       SUB_IF_API_FLAG_OUTER_VLAN_ID_ANY SubIfFlags = 64
-       SUB_IF_API_FLAG_INNER_VLAN_ID_ANY SubIfFlags = 128
-       SUB_IF_API_FLAG_MASK_VNET         SubIfFlags = 254
-       SUB_IF_API_FLAG_DOT1AH            SubIfFlags = 256
-)
-
-var (
-       SubIfFlags_name = map[uint32]string{
-               1:   "SUB_IF_API_FLAG_NO_TAGS",
-               2:   "SUB_IF_API_FLAG_ONE_TAG",
-               4:   "SUB_IF_API_FLAG_TWO_TAGS",
-               8:   "SUB_IF_API_FLAG_DOT1AD",
-               16:  "SUB_IF_API_FLAG_EXACT_MATCH",
-               32:  "SUB_IF_API_FLAG_DEFAULT",
-               64:  "SUB_IF_API_FLAG_OUTER_VLAN_ID_ANY",
-               128: "SUB_IF_API_FLAG_INNER_VLAN_ID_ANY",
-               254: "SUB_IF_API_FLAG_MASK_VNET",
-               256: "SUB_IF_API_FLAG_DOT1AH",
-       }
-       SubIfFlags_value = map[string]uint32{
-               "SUB_IF_API_FLAG_NO_TAGS":           1,
-               "SUB_IF_API_FLAG_ONE_TAG":           2,
-               "SUB_IF_API_FLAG_TWO_TAGS":          4,
-               "SUB_IF_API_FLAG_DOT1AD":            8,
-               "SUB_IF_API_FLAG_EXACT_MATCH":       16,
-               "SUB_IF_API_FLAG_DEFAULT":           32,
-               "SUB_IF_API_FLAG_OUTER_VLAN_ID_ANY": 64,
-               "SUB_IF_API_FLAG_INNER_VLAN_ID_ANY": 128,
-               "SUB_IF_API_FLAG_MASK_VNET":         254,
-               "SUB_IF_API_FLAG_DOT1AH":            256,
-       }
-)
-
-func (x SubIfFlags) String() string {
-       s, ok := SubIfFlags_name[uint32(x)]
-       if ok {
-               return s
-       }
-       str := func(n uint32) string {
-               s, ok := SubIfFlags_name[uint32(n)]
-               if ok {
-                       return s
-               }
-               return "SubIfFlags(" + strconv.Itoa(int(n)) + ")"
-       }
-       for i := uint32(0); i <= 32; i++ {
-               val := uint32(x)
-               if val&(1<<i) != 0 {
-                       if s != "" {
-                               s += "|"
-                       }
-                       s += str(1 << i)
-               }
-       }
-       if s == "" {
-               return str(uint32(x))
-       }
-       return s
-}
-
-// AddressWithPrefix defines alias 'address_with_prefix'.
-type AddressWithPrefix Prefix
-
-func ParseAddressWithPrefix(s string) (AddressWithPrefix, error) {
-       prefix, err := ParsePrefix(s)
-       if err != nil {
-               return AddressWithPrefix{}, err
-       }
-       return AddressWithPrefix(prefix), nil
-}
-
-func (x AddressWithPrefix) String() string {
-       return Prefix(x).String()
-}
-
-func (x *AddressWithPrefix) MarshalText() ([]byte, error) {
-       return []byte(x.String()), nil
-}
-
-func (x *AddressWithPrefix) UnmarshalText(text []byte) error {
-       prefix, err := ParseAddressWithPrefix(string(text))
-       if err != nil {
-               return err
-       }
-       *x = prefix
-       return nil
-}
-
-// InterfaceIndex defines alias 'interface_index'.
-type InterfaceIndex uint32
-
-// IP4Address defines alias 'ip4_address'.
-type IP4Address [4]uint8
-
-func ParseIP4Address(s string) (IP4Address, error) {
-       ip := net.ParseIP(s).To4()
-       if ip == nil {
-               return IP4Address{}, fmt.Errorf("invalid IP address: %s", s)
-       }
-       var ipaddr IP4Address
-       copy(ipaddr[:], ip.To4())
-       return ipaddr, nil
-}
-
-func (x IP4Address) ToIP() net.IP {
-       return net.IP(x[:]).To4()
-}
-
-func (x IP4Address) String() string {
-       return x.ToIP().String()
-}
-
-func (x *IP4Address) MarshalText() ([]byte, error) {
-       return []byte(x.String()), nil
-}
-
-func (x *IP4Address) UnmarshalText(text []byte) error {
-       ipaddr, err := ParseIP4Address(string(text))
-       if err != nil {
-               return err
-       }
-       *x = ipaddr
-       return nil
-}
-
-// IP4AddressWithPrefix defines alias 'ip4_address_with_prefix'.
-type IP4AddressWithPrefix IP4Prefix
-
-// IP6Address defines alias 'ip6_address'.
-type IP6Address [16]uint8
-
-func ParseIP6Address(s string) (IP6Address, error) {
-       ip := net.ParseIP(s).To16()
-       if ip == nil {
-               return IP6Address{}, fmt.Errorf("invalid IP address: %s", s)
-       }
-       var ipaddr IP6Address
-       copy(ipaddr[:], ip.To16())
-       return ipaddr, nil
-}
-
-func (x IP6Address) ToIP() net.IP {
-       return net.IP(x[:]).To16()
-}
-
-func (x IP6Address) String() string {
-       return x.ToIP().String()
-}
-
-func (x *IP6Address) MarshalText() ([]byte, error) {
-       return []byte(x.String()), nil
-}
-
-func (x *IP6Address) UnmarshalText(text []byte) error {
-       ipaddr, err := ParseIP6Address(string(text))
-       if err != nil {
-               return err
-       }
-       *x = ipaddr
-       return nil
-}
-
-// IP6AddressWithPrefix defines alias 'ip6_address_with_prefix'.
-type IP6AddressWithPrefix IP6Prefix
-
-// Address defines type 'address'.
-type Address struct {
-       Af AddressFamily `binapi:"address_family,name=af" json:"af,omitempty"`
-       Un AddressUnion  `binapi:"address_union,name=un" json:"un,omitempty"`
-}
-
-func ParseAddress(s string) (Address, error) {
-       ip := net.ParseIP(s)
-       if ip == nil {
-               return Address{}, fmt.Errorf("invalid address: %s", s)
-       }
-       return AddressFromIP(ip), nil
-}
-
-func AddressFromIP(ip net.IP) Address {
-       var addr Address
-       if ip.To4() == nil {
-               addr.Af = ADDRESS_IP6
-               var ip6 IP6Address
-               copy(ip6[:], ip.To16())
-               addr.Un.SetIP6(ip6)
-       } else {
-               addr.Af = ADDRESS_IP4
-               var ip4 IP4Address
-               copy(ip4[:], ip.To4())
-               addr.Un.SetIP4(ip4)
-       }
-       return addr
-}
-
-func (x Address) ToIP() net.IP {
-       if x.Af == ADDRESS_IP6 {
-               ip6 := x.Un.GetIP6()
-               return net.IP(ip6[:]).To16()
-       } else {
-               ip4 := x.Un.GetIP4()
-               return net.IP(ip4[:]).To4()
-       }
-}
-
-func (x Address) String() string {
-       return x.ToIP().String()
-}
-
-func (x *Address) MarshalText() ([]byte, error) {
-       return []byte(x.String()), nil
-}
-
-func (x *Address) UnmarshalText(text []byte) error {
-       addr, err := ParseAddress(string(text))
-       if err != nil {
-               return err
-       }
-       *x = addr
-       return nil
-}
-
-// GroupPrefix defines type 'group_prefix'.
-type GroupPrefix struct {
-       Type   GroupPrefixType `binapi:"group_prefix_type,name=type" json:"type,omitempty"`
-       Prefix Prefix          `binapi:"prefix,name=prefix" json:"prefix,omitempty"`
-}
-
-// IgmpGroup defines type 'igmp_group'.
-type IgmpGroup struct {
-       Filter    FilterMode     `binapi:"filter_mode,name=filter" json:"filter,omitempty"`
-       NSrcs     uint8          `binapi:"u8,name=n_srcs" json:"-"`
-       SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"`
-       Gaddr     IP4Address     `binapi:"ip4_address,name=gaddr" json:"gaddr,omitempty"`
-       Saddrs    []IP4Address   `binapi:"ip4_address[n_srcs],name=saddrs" json:"saddrs,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
-}
-
-// IgmpClearInterface defines message 'igmp_clear_interface'.
-type IgmpClearInterface struct {
-       SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"`
-}
-
-func (m *IgmpClearInterface) Reset()               { *m = IgmpClearInterface{} }
-func (*IgmpClearInterface) GetMessageName() string { return "igmp_clear_interface" }
-func (*IgmpClearInterface) GetCrcString() string   { return "f9e6675e" }
-func (*IgmpClearInterface) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *IgmpClearInterface) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.SwIfIndex
-       return size
-}
-func (m *IgmpClearInterface) 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 *IgmpClearInterface) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.SwIfIndex = InterfaceIndex(buf.DecodeUint32())
-       return nil
-}
-
-// IgmpClearInterfaceReply defines message 'igmp_clear_interface_reply'.
-type IgmpClearInterfaceReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *IgmpClearInterfaceReply) Reset()               { *m = IgmpClearInterfaceReply{} }
-func (*IgmpClearInterfaceReply) GetMessageName() string { return "igmp_clear_interface_reply" }
-func (*IgmpClearInterfaceReply) GetCrcString() string   { return "e8d4e804" }
-func (*IgmpClearInterfaceReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *IgmpClearInterfaceReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *IgmpClearInterfaceReply) 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 *IgmpClearInterfaceReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// IgmpDetails defines message 'igmp_details'.
-type IgmpDetails struct {
-       SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"`
-       Saddr     IP4Address     `binapi:"ip4_address,name=saddr" json:"saddr,omitempty"`
-       Gaddr     IP4Address     `binapi:"ip4_address,name=gaddr" json:"gaddr,omitempty"`
-}
-
-func (m *IgmpDetails) Reset()               { *m = IgmpDetails{} }
-func (*IgmpDetails) GetMessageName() string { return "igmp_details" }
-func (*IgmpDetails) GetCrcString() string   { return "52f12a89" }
-func (*IgmpDetails) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *IgmpDetails) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4     // m.SwIfIndex
-       size += 1 * 4 // m.Saddr
-       size += 1 * 4 // m.Gaddr
-       return size
-}
-func (m *IgmpDetails) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(uint32(m.SwIfIndex))
-       buf.EncodeBytes(m.Saddr[:], 4)
-       buf.EncodeBytes(m.Gaddr[:], 4)
-       return buf.Bytes(), nil
-}
-func (m *IgmpDetails) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.SwIfIndex = InterfaceIndex(buf.DecodeUint32())
-       copy(m.Saddr[:], buf.DecodeBytes(4))
-       copy(m.Gaddr[:], buf.DecodeBytes(4))
-       return nil
-}
-
-// IgmpDump defines message 'igmp_dump'.
-type IgmpDump struct {
-       SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"`
-}
-
-func (m *IgmpDump) Reset()               { *m = IgmpDump{} }
-func (*IgmpDump) GetMessageName() string { return "igmp_dump" }
-func (*IgmpDump) GetCrcString() string   { return "f9e6675e" }
-func (*IgmpDump) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *IgmpDump) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.SwIfIndex
-       return size
-}
-func (m *IgmpDump) 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 *IgmpDump) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.SwIfIndex = InterfaceIndex(buf.DecodeUint32())
-       return nil
-}
-
-// IgmpEnableDisable defines message 'igmp_enable_disable'.
-type IgmpEnableDisable struct {
-       Enable    bool           `binapi:"bool,name=enable" json:"enable,omitempty"`
-       Mode      uint8          `binapi:"u8,name=mode" json:"mode,omitempty"`
-       SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"`
-}
-
-func (m *IgmpEnableDisable) Reset()               { *m = IgmpEnableDisable{} }
-func (*IgmpEnableDisable) GetMessageName() string { return "igmp_enable_disable" }
-func (*IgmpEnableDisable) GetCrcString() string   { return "b1edfb96" }
-func (*IgmpEnableDisable) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *IgmpEnableDisable) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 1 // m.Enable
-       size += 1 // m.Mode
-       size += 4 // m.SwIfIndex
-       return size
-}
-func (m *IgmpEnableDisable) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeBool(m.Enable)
-       buf.EncodeUint8(m.Mode)
-       buf.EncodeUint32(uint32(m.SwIfIndex))
-       return buf.Bytes(), nil
-}
-func (m *IgmpEnableDisable) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Enable = buf.DecodeBool()
-       m.Mode = buf.DecodeUint8()
-       m.SwIfIndex = InterfaceIndex(buf.DecodeUint32())
-       return nil
-}
-
-// IgmpEnableDisableReply defines message 'igmp_enable_disable_reply'.
-type IgmpEnableDisableReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *IgmpEnableDisableReply) Reset()               { *m = IgmpEnableDisableReply{} }
-func (*IgmpEnableDisableReply) GetMessageName() string { return "igmp_enable_disable_reply" }
-func (*IgmpEnableDisableReply) GetCrcString() string   { return "e8d4e804" }
-func (*IgmpEnableDisableReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *IgmpEnableDisableReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *IgmpEnableDisableReply) 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 *IgmpEnableDisableReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// IgmpEvent defines message 'igmp_event'.
-type IgmpEvent struct {
-       SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"`
-       Filter    FilterMode     `binapi:"filter_mode,name=filter" json:"filter,omitempty"`
-       Saddr     IP4Address     `binapi:"ip4_address,name=saddr" json:"saddr,omitempty"`
-       Gaddr     IP4Address     `binapi:"ip4_address,name=gaddr" json:"gaddr,omitempty"`
-}
-
-func (m *IgmpEvent) Reset()               { *m = IgmpEvent{} }
-func (*IgmpEvent) GetMessageName() string { return "igmp_event" }
-func (*IgmpEvent) GetCrcString() string   { return "d7696eaf" }
-func (*IgmpEvent) GetMessageType() api.MessageType {
-       return api.OtherMessage
-}
-
-func (m *IgmpEvent) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4     // m.SwIfIndex
-       size += 4     // m.Filter
-       size += 1 * 4 // m.Saddr
-       size += 1 * 4 // m.Gaddr
-       return size
-}
-func (m *IgmpEvent) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(uint32(m.SwIfIndex))
-       buf.EncodeUint32(uint32(m.Filter))
-       buf.EncodeBytes(m.Saddr[:], 4)
-       buf.EncodeBytes(m.Gaddr[:], 4)
-       return buf.Bytes(), nil
-}
-func (m *IgmpEvent) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.SwIfIndex = InterfaceIndex(buf.DecodeUint32())
-       m.Filter = FilterMode(buf.DecodeUint32())
-       copy(m.Saddr[:], buf.DecodeBytes(4))
-       copy(m.Gaddr[:], buf.DecodeBytes(4))
-       return nil
-}
-
-// IgmpGroupPrefixDetails defines message 'igmp_group_prefix_details'.
-type IgmpGroupPrefixDetails struct {
-       Gp GroupPrefix `binapi:"group_prefix,name=gp" json:"gp,omitempty"`
-}
-
-func (m *IgmpGroupPrefixDetails) Reset()               { *m = IgmpGroupPrefixDetails{} }
-func (*IgmpGroupPrefixDetails) GetMessageName() string { return "igmp_group_prefix_details" }
-func (*IgmpGroupPrefixDetails) GetCrcString() string   { return "c3b3c526" }
-func (*IgmpGroupPrefixDetails) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *IgmpGroupPrefixDetails) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4      // m.Gp.Type
-       size += 4      // m.Gp.Prefix.Address.Af
-       size += 1 * 16 // m.Gp.Prefix.Address.Un
-       size += 1      // m.Gp.Prefix.Len
-       return size
-}
-func (m *IgmpGroupPrefixDetails) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(uint32(m.Gp.Type))
-       buf.EncodeUint32(uint32(m.Gp.Prefix.Address.Af))
-       buf.EncodeBytes(m.Gp.Prefix.Address.Un.XXX_UnionData[:], 16)
-       buf.EncodeUint8(m.Gp.Prefix.Len)
-       return buf.Bytes(), nil
-}
-func (m *IgmpGroupPrefixDetails) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Gp.Type = GroupPrefixType(buf.DecodeUint32())
-       m.Gp.Prefix.Address.Af = AddressFamily(buf.DecodeUint32())
-       copy(m.Gp.Prefix.Address.Un.XXX_UnionData[:], buf.DecodeBytes(16))
-       m.Gp.Prefix.Len = buf.DecodeUint8()
-       return nil
-}
-
-// IgmpGroupPrefixDump defines message 'igmp_group_prefix_dump'.
-type IgmpGroupPrefixDump struct{}
-
-func (m *IgmpGroupPrefixDump) Reset()               { *m = IgmpGroupPrefixDump{} }
-func (*IgmpGroupPrefixDump) GetMessageName() string { return "igmp_group_prefix_dump" }
-func (*IgmpGroupPrefixDump) GetCrcString() string   { return "51077d14" }
-func (*IgmpGroupPrefixDump) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *IgmpGroupPrefixDump) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       return size
-}
-func (m *IgmpGroupPrefixDump) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       return buf.Bytes(), nil
-}
-func (m *IgmpGroupPrefixDump) Unmarshal(b []byte) error {
-       return nil
-}
-
-// IgmpGroupPrefixSet defines message 'igmp_group_prefix_set'.
-type IgmpGroupPrefixSet struct {
-       Gp GroupPrefix `binapi:"group_prefix,name=gp" json:"gp,omitempty"`
-}
-
-func (m *IgmpGroupPrefixSet) Reset()               { *m = IgmpGroupPrefixSet{} }
-func (*IgmpGroupPrefixSet) GetMessageName() string { return "igmp_group_prefix_set" }
-func (*IgmpGroupPrefixSet) GetCrcString() string   { return "d4f20ac5" }
-func (*IgmpGroupPrefixSet) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *IgmpGroupPrefixSet) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4      // m.Gp.Type
-       size += 4      // m.Gp.Prefix.Address.Af
-       size += 1 * 16 // m.Gp.Prefix.Address.Un
-       size += 1      // m.Gp.Prefix.Len
-       return size
-}
-func (m *IgmpGroupPrefixSet) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(uint32(m.Gp.Type))
-       buf.EncodeUint32(uint32(m.Gp.Prefix.Address.Af))
-       buf.EncodeBytes(m.Gp.Prefix.Address.Un.XXX_UnionData[:], 16)
-       buf.EncodeUint8(m.Gp.Prefix.Len)
-       return buf.Bytes(), nil
-}
-func (m *IgmpGroupPrefixSet) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Gp.Type = GroupPrefixType(buf.DecodeUint32())
-       m.Gp.Prefix.Address.Af = AddressFamily(buf.DecodeUint32())
-       copy(m.Gp.Prefix.Address.Un.XXX_UnionData[:], buf.DecodeBytes(16))
-       m.Gp.Prefix.Len = buf.DecodeUint8()
-       return nil
-}
-
-// IgmpGroupPrefixSetReply defines message 'igmp_group_prefix_set_reply'.
-type IgmpGroupPrefixSetReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *IgmpGroupPrefixSetReply) Reset()               { *m = IgmpGroupPrefixSetReply{} }
-func (*IgmpGroupPrefixSetReply) GetMessageName() string { return "igmp_group_prefix_set_reply" }
-func (*IgmpGroupPrefixSetReply) GetCrcString() string   { return "e8d4e804" }
-func (*IgmpGroupPrefixSetReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *IgmpGroupPrefixSetReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *IgmpGroupPrefixSetReply) 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 *IgmpGroupPrefixSetReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// IgmpListen defines message 'igmp_listen'.
-type IgmpListen struct {
-       Group IgmpGroup `binapi:"igmp_group,name=group" json:"group,omitempty"`
-}
-
-func (m *IgmpListen) Reset()               { *m = IgmpListen{} }
-func (*IgmpListen) GetMessageName() string { return "igmp_listen" }
-func (*IgmpListen) GetCrcString() string   { return "3f93a51a" }
-func (*IgmpListen) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *IgmpListen) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4     // m.Group.Filter
-       size += 1     // m.Group.NSrcs
-       size += 4     // m.Group.SwIfIndex
-       size += 1 * 4 // m.Group.Gaddr
-       for j2 := 0; j2 < len(m.Group.Saddrs); j2++ {
-               var s2 IP4Address
-               _ = s2
-               if j2 < len(m.Group.Saddrs) {
-                       s2 = m.Group.Saddrs[j2]
-               }
-               size += 1 * 4 // s2
-       }
-       return size
-}
-func (m *IgmpListen) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(uint32(m.Group.Filter))
-       buf.EncodeUint8(uint8(len(m.Group.Saddrs)))
-       buf.EncodeUint32(uint32(m.Group.SwIfIndex))
-       buf.EncodeBytes(m.Group.Gaddr[:], 4)
-       for j1 := 0; j1 < len(m.Group.Saddrs); j1++ {
-               var v1 IP4Address // Saddrs
-               if j1 < len(m.Group.Saddrs) {
-                       v1 = m.Group.Saddrs[j1]
-               }
-               buf.EncodeBytes(v1[:], 4)
-       }
-       return buf.Bytes(), nil
-}
-func (m *IgmpListen) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Group.Filter = FilterMode(buf.DecodeUint32())
-       m.Group.NSrcs = buf.DecodeUint8()
-       m.Group.SwIfIndex = InterfaceIndex(buf.DecodeUint32())
-       copy(m.Group.Gaddr[:], buf.DecodeBytes(4))
-       m.Group.Saddrs = make([]IP4Address, m.Group.NSrcs)
-       for j1 := 0; j1 < len(m.Group.Saddrs); j1++ {
-               copy(m.Group.Saddrs[j1][:], buf.DecodeBytes(4))
-       }
-       return nil
-}
-
-// IgmpListenReply defines message 'igmp_listen_reply'.
-type IgmpListenReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *IgmpListenReply) Reset()               { *m = IgmpListenReply{} }
-func (*IgmpListenReply) GetMessageName() string { return "igmp_listen_reply" }
-func (*IgmpListenReply) GetCrcString() string   { return "e8d4e804" }
-func (*IgmpListenReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *IgmpListenReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *IgmpListenReply) 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 *IgmpListenReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// IgmpProxyDeviceAddDel defines message 'igmp_proxy_device_add_del'.
-type IgmpProxyDeviceAddDel struct {
-       Add       uint8          `binapi:"u8,name=add" json:"add,omitempty"`
-       VrfID     uint32         `binapi:"u32,name=vrf_id" json:"vrf_id,omitempty"`
-       SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"`
-}
-
-func (m *IgmpProxyDeviceAddDel) Reset()               { *m = IgmpProxyDeviceAddDel{} }
-func (*IgmpProxyDeviceAddDel) GetMessageName() string { return "igmp_proxy_device_add_del" }
-func (*IgmpProxyDeviceAddDel) GetCrcString() string   { return "0b9be9ce" }
-func (*IgmpProxyDeviceAddDel) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *IgmpProxyDeviceAddDel) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 1 // m.Add
-       size += 4 // m.VrfID
-       size += 4 // m.SwIfIndex
-       return size
-}
-func (m *IgmpProxyDeviceAddDel) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint8(m.Add)
-       buf.EncodeUint32(m.VrfID)
-       buf.EncodeUint32(uint32(m.SwIfIndex))
-       return buf.Bytes(), nil
-}
-func (m *IgmpProxyDeviceAddDel) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Add = buf.DecodeUint8()
-       m.VrfID = buf.DecodeUint32()
-       m.SwIfIndex = InterfaceIndex(buf.DecodeUint32())
-       return nil
-}
-
-// IgmpProxyDeviceAddDelInterface defines message 'igmp_proxy_device_add_del_interface'.
-type IgmpProxyDeviceAddDelInterface struct {
-       Add       bool           `binapi:"bool,name=add" json:"add,omitempty"`
-       VrfID     uint32         `binapi:"u32,name=vrf_id" json:"vrf_id,omitempty"`
-       SwIfIndex InterfaceIndex `binapi:"interface_index,name=sw_if_index" json:"sw_if_index,omitempty"`
-}
-
-func (m *IgmpProxyDeviceAddDelInterface) Reset() { *m = IgmpProxyDeviceAddDelInterface{} }
-func (*IgmpProxyDeviceAddDelInterface) GetMessageName() string {
-       return "igmp_proxy_device_add_del_interface"
-}
-func (*IgmpProxyDeviceAddDelInterface) GetCrcString() string { return "1a9ec24a" }
-func (*IgmpProxyDeviceAddDelInterface) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *IgmpProxyDeviceAddDelInterface) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 1 // m.Add
-       size += 4 // m.VrfID
-       size += 4 // m.SwIfIndex
-       return size
-}
-func (m *IgmpProxyDeviceAddDelInterface) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeBool(m.Add)
-       buf.EncodeUint32(m.VrfID)
-       buf.EncodeUint32(uint32(m.SwIfIndex))
-       return buf.Bytes(), nil
-}
-func (m *IgmpProxyDeviceAddDelInterface) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Add = buf.DecodeBool()
-       m.VrfID = buf.DecodeUint32()
-       m.SwIfIndex = InterfaceIndex(buf.DecodeUint32())
-       return nil
-}
-
-// IgmpProxyDeviceAddDelInterfaceReply defines message 'igmp_proxy_device_add_del_interface_reply'.
-type IgmpProxyDeviceAddDelInterfaceReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *IgmpProxyDeviceAddDelInterfaceReply) Reset() { *m = IgmpProxyDeviceAddDelInterfaceReply{} }
-func (*IgmpProxyDeviceAddDelInterfaceReply) GetMessageName() string {
-       return "igmp_proxy_device_add_del_interface_reply"
-}
-func (*IgmpProxyDeviceAddDelInterfaceReply) GetCrcString() string { return "e8d4e804" }
-func (*IgmpProxyDeviceAddDelInterfaceReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *IgmpProxyDeviceAddDelInterfaceReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *IgmpProxyDeviceAddDelInterfaceReply) 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 *IgmpProxyDeviceAddDelInterfaceReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// IgmpProxyDeviceAddDelReply defines message 'igmp_proxy_device_add_del_reply'.
-type IgmpProxyDeviceAddDelReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *IgmpProxyDeviceAddDelReply) Reset()               { *m = IgmpProxyDeviceAddDelReply{} }
-func (*IgmpProxyDeviceAddDelReply) GetMessageName() string { return "igmp_proxy_device_add_del_reply" }
-func (*IgmpProxyDeviceAddDelReply) GetCrcString() string   { return "e8d4e804" }
-func (*IgmpProxyDeviceAddDelReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *IgmpProxyDeviceAddDelReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *IgmpProxyDeviceAddDelReply) 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 *IgmpProxyDeviceAddDelReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-// WantIgmpEvents defines message 'want_igmp_events'.
-type WantIgmpEvents struct {
-       Enable uint32 `binapi:"u32,name=enable" json:"enable,omitempty"`
-       PID    uint32 `binapi:"u32,name=pid" json:"pid,omitempty"`
-}
-
-func (m *WantIgmpEvents) Reset()               { *m = WantIgmpEvents{} }
-func (*WantIgmpEvents) GetMessageName() string { return "want_igmp_events" }
-func (*WantIgmpEvents) GetCrcString() string   { return "cfaccc1f" }
-func (*WantIgmpEvents) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
-
-func (m *WantIgmpEvents) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Enable
-       size += 4 // m.PID
-       return size
-}
-func (m *WantIgmpEvents) Marshal(b []byte) ([]byte, error) {
-       if b == nil {
-               b = make([]byte, m.Size())
-       }
-       buf := codec.NewBuffer(b)
-       buf.EncodeUint32(m.Enable)
-       buf.EncodeUint32(m.PID)
-       return buf.Bytes(), nil
-}
-func (m *WantIgmpEvents) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Enable = buf.DecodeUint32()
-       m.PID = buf.DecodeUint32()
-       return nil
-}
-
-// WantIgmpEventsReply defines message 'want_igmp_events_reply'.
-type WantIgmpEventsReply struct {
-       Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"`
-}
-
-func (m *WantIgmpEventsReply) Reset()               { *m = WantIgmpEventsReply{} }
-func (*WantIgmpEventsReply) GetMessageName() string { return "want_igmp_events_reply" }
-func (*WantIgmpEventsReply) GetCrcString() string   { return "e8d4e804" }
-func (*WantIgmpEventsReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
-
-func (m *WantIgmpEventsReply) Size() (size int) {
-       if m == nil {
-               return 0
-       }
-       size += 4 // m.Retval
-       return size
-}
-func (m *WantIgmpEventsReply) 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 *WantIgmpEventsReply) Unmarshal(b []byte) error {
-       buf := codec.NewBuffer(b)
-       m.Retval = buf.DecodeInt32()
-       return nil
-}
-
-func init() { file_igmp_binapi_init() }
-func file_igmp_binapi_init() {
-       api.RegisterMessage((*IgmpClearInterface)(nil), "igmp_clear_interface_f9e6675e")
-       api.RegisterMessage((*IgmpClearInterfaceReply)(nil), "igmp_clear_interface_reply_e8d4e804")
-       api.RegisterMessage((*IgmpDetails)(nil), "igmp_details_52f12a89")
-       api.RegisterMessage((*IgmpDump)(nil), "igmp_dump_f9e6675e")
-       api.RegisterMessage((*IgmpEnableDisable)(nil), "igmp_enable_disable_b1edfb96")
-       api.RegisterMessage((*IgmpEnableDisableReply)(nil), "igmp_enable_disable_reply_e8d4e804")
-       api.RegisterMessage((*IgmpEvent)(nil), "igmp_event_d7696eaf")
-       api.RegisterMessage((*IgmpGroupPrefixDetails)(nil), "igmp_group_prefix_details_c3b3c526")
-       api.RegisterMessage((*IgmpGroupPrefixDump)(nil), "igmp_group_prefix_dump_51077d14")
-       api.RegisterMessage((*IgmpGroupPrefixSet)(nil), "igmp_group_prefix_set_d4f20ac5")
-       api.RegisterMessage((*IgmpGroupPrefixSetReply)(nil), "igmp_group_prefix_set_reply_e8d4e804")
-       api.RegisterMessage((*IgmpListen)(nil), "igmp_listen_3f93a51a")
-       api.RegisterMessage((*IgmpListenReply)(nil), "igmp_listen_reply_e8d4e804")
-       api.RegisterMessage((*IgmpProxyDeviceAddDel)(nil), "igmp_proxy_device_add_del_0b9be9ce")
-       api.RegisterMessage((*IgmpProxyDeviceAddDelInterface)(nil), "igmp_proxy_device_add_del_interface_1a9ec24a")
-       api.RegisterMessage((*IgmpProxyDeviceAddDelInterfaceReply)(nil), "igmp_proxy_device_add_del_interface_reply_e8d4e804")
-       api.RegisterMessage((*IgmpProxyDeviceAddDelReply)(nil), "igmp_proxy_device_add_del_reply_e8d4e804")
-       api.RegisterMessage((*WantIgmpEvents)(nil), "want_igmp_events_cfaccc1f")
-       api.RegisterMessage((*WantIgmpEventsReply)(nil), "want_igmp_events_reply_e8d4e804")
-}
-
-// Messages returns list of all messages in this module.
-func AllMessages() []api.Message {
-       return []api.Message{
-               (*IgmpClearInterface)(nil),
-               (*IgmpClearInterfaceReply)(nil),
-               (*IgmpDetails)(nil),
-               (*IgmpDump)(nil),
-               (*IgmpEnableDisable)(nil),
-               (*IgmpEnableDisableReply)(nil),
-               (*IgmpEvent)(nil),
-               (*IgmpGroupPrefixDetails)(nil),
-               (*IgmpGroupPrefixDump)(nil),
-               (*IgmpGroupPrefixSet)(nil),
-               (*IgmpGroupPrefixSetReply)(nil),
-               (*IgmpListen)(nil),
-               (*IgmpListenReply)(nil),
-               (*IgmpProxyDeviceAddDel)(nil),
-               (*IgmpProxyDeviceAddDelInterface)(nil),
-               (*IgmpProxyDeviceAddDelInterfaceReply)(nil),
-               (*IgmpProxyDeviceAddDelReply)(nil),
-               (*WantIgmpEvents)(nil),
-               (*WantIgmpEventsReply)(nil),
-       }
-}