1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-1.0+ WITH Linux-syscall-note */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Bond several ethernet interfaces into a Cisco, running 'Etherchannel'. 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * Portions are (c) Copyright 1995 Simon "Guru Aleph-Null" Janes 7*4882a593Smuzhiyun * NCM: Network and Communications Management, Inc. 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * BUT, I'm the one who modified it for ethernet, so: 10*4882a593Smuzhiyun * (c) Copyright 1999, Thomas Davis, tadavis@lbl.gov 11*4882a593Smuzhiyun * 12*4882a593Smuzhiyun * This software may be used and distributed according to the terms 13*4882a593Smuzhiyun * of the GNU Public License, incorporated herein by reference. 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * 2003/03/18 - Amir Noam <amir.noam at intel dot com> 16*4882a593Smuzhiyun * - Added support for getting slave's speed and duplex via ethtool. 17*4882a593Smuzhiyun * Needed for 802.3ad and other future modes. 18*4882a593Smuzhiyun * 19*4882a593Smuzhiyun * 2003/03/18 - Tsippy Mendelson <tsippy.mendelson at intel dot com> and 20*4882a593Smuzhiyun * Shmulik Hen <shmulik.hen at intel dot com> 21*4882a593Smuzhiyun * - Enable support of modes that need to use the unique mac address of 22*4882a593Smuzhiyun * each slave. 23*4882a593Smuzhiyun * 24*4882a593Smuzhiyun * 2003/03/18 - Tsippy Mendelson <tsippy.mendelson at intel dot com> and 25*4882a593Smuzhiyun * Amir Noam <amir.noam at intel dot com> 26*4882a593Smuzhiyun * - Moved driver's private data types to bonding.h 27*4882a593Smuzhiyun * 28*4882a593Smuzhiyun * 2003/03/18 - Amir Noam <amir.noam at intel dot com>, 29*4882a593Smuzhiyun * Tsippy Mendelson <tsippy.mendelson at intel dot com> and 30*4882a593Smuzhiyun * Shmulik Hen <shmulik.hen at intel dot com> 31*4882a593Smuzhiyun * - Added support for IEEE 802.3ad Dynamic link aggregation mode. 32*4882a593Smuzhiyun * 33*4882a593Smuzhiyun * 2003/05/01 - Amir Noam <amir.noam at intel dot com> 34*4882a593Smuzhiyun * - Added ABI version control to restore compatibility between 35*4882a593Smuzhiyun * new/old ifenslave and new/old bonding. 36*4882a593Smuzhiyun * 37*4882a593Smuzhiyun * 2003/12/01 - Shmulik Hen <shmulik.hen at intel dot com> 38*4882a593Smuzhiyun * - Code cleanup and style changes 39*4882a593Smuzhiyun * 40*4882a593Smuzhiyun * 2005/05/05 - Jason Gabler <jygabler at lbl dot gov> 41*4882a593Smuzhiyun * - added definitions for various XOR hashing policies 42*4882a593Smuzhiyun */ 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun #ifndef _LINUX_IF_BONDING_H 45*4882a593Smuzhiyun #define _LINUX_IF_BONDING_H 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun #include <linux/if.h> 48*4882a593Smuzhiyun #include <linux/types.h> 49*4882a593Smuzhiyun #include <linux/if_ether.h> 50*4882a593Smuzhiyun 51*4882a593Smuzhiyun /* userland - kernel ABI version (2003/05/08) */ 52*4882a593Smuzhiyun #define BOND_ABI_VERSION 2 53*4882a593Smuzhiyun 54*4882a593Smuzhiyun /* 55*4882a593Smuzhiyun * We can remove these ioctl definitions in 2.5. People should use the 56*4882a593Smuzhiyun * SIOC*** versions of them instead 57*4882a593Smuzhiyun */ 58*4882a593Smuzhiyun #define BOND_ENSLAVE_OLD (SIOCDEVPRIVATE) 59*4882a593Smuzhiyun #define BOND_RELEASE_OLD (SIOCDEVPRIVATE + 1) 60*4882a593Smuzhiyun #define BOND_SETHWADDR_OLD (SIOCDEVPRIVATE + 2) 61*4882a593Smuzhiyun #define BOND_SLAVE_INFO_QUERY_OLD (SIOCDEVPRIVATE + 11) 62*4882a593Smuzhiyun #define BOND_INFO_QUERY_OLD (SIOCDEVPRIVATE + 12) 63*4882a593Smuzhiyun #define BOND_CHANGE_ACTIVE_OLD (SIOCDEVPRIVATE + 13) 64*4882a593Smuzhiyun 65*4882a593Smuzhiyun #define BOND_CHECK_MII_STATUS (SIOCGMIIPHY) 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun #define BOND_MODE_ROUNDROBIN 0 68*4882a593Smuzhiyun #define BOND_MODE_ACTIVEBACKUP 1 69*4882a593Smuzhiyun #define BOND_MODE_XOR 2 70*4882a593Smuzhiyun #define BOND_MODE_BROADCAST 3 71*4882a593Smuzhiyun #define BOND_MODE_8023AD 4 72*4882a593Smuzhiyun #define BOND_MODE_TLB 5 73*4882a593Smuzhiyun #define BOND_MODE_ALB 6 /* TLB + RLB (receive load balancing) */ 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun /* each slave's link has 4 states */ 76*4882a593Smuzhiyun #define BOND_LINK_UP 0 /* link is up and running */ 77*4882a593Smuzhiyun #define BOND_LINK_FAIL 1 /* link has just gone down */ 78*4882a593Smuzhiyun #define BOND_LINK_DOWN 2 /* link has been down for too long time */ 79*4882a593Smuzhiyun #define BOND_LINK_BACK 3 /* link is going back */ 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun /* each slave has several states */ 82*4882a593Smuzhiyun #define BOND_STATE_ACTIVE 0 /* link is active */ 83*4882a593Smuzhiyun #define BOND_STATE_BACKUP 1 /* link is backup */ 84*4882a593Smuzhiyun 85*4882a593Smuzhiyun #define BOND_DEFAULT_MAX_BONDS 1 /* Default maximum number of devices to support */ 86*4882a593Smuzhiyun 87*4882a593Smuzhiyun #define BOND_DEFAULT_TX_QUEUES 16 /* Default number of tx queues per device */ 88*4882a593Smuzhiyun 89*4882a593Smuzhiyun #define BOND_DEFAULT_RESEND_IGMP 1 /* Default number of IGMP membership reports */ 90*4882a593Smuzhiyun 91*4882a593Smuzhiyun /* hashing types */ 92*4882a593Smuzhiyun #define BOND_XMIT_POLICY_LAYER2 0 /* layer 2 (MAC only), default */ 93*4882a593Smuzhiyun #define BOND_XMIT_POLICY_LAYER34 1 /* layer 3+4 (IP ^ (TCP || UDP)) */ 94*4882a593Smuzhiyun #define BOND_XMIT_POLICY_LAYER23 2 /* layer 2+3 (IP ^ MAC) */ 95*4882a593Smuzhiyun #define BOND_XMIT_POLICY_ENCAP23 3 /* encapsulated layer 2+3 */ 96*4882a593Smuzhiyun #define BOND_XMIT_POLICY_ENCAP34 4 /* encapsulated layer 3+4 */ 97*4882a593Smuzhiyun 98*4882a593Smuzhiyun /* 802.3ad port state definitions (43.4.2.2 in the 802.3ad standard) */ 99*4882a593Smuzhiyun #define LACP_STATE_LACP_ACTIVITY 0x1 100*4882a593Smuzhiyun #define LACP_STATE_LACP_TIMEOUT 0x2 101*4882a593Smuzhiyun #define LACP_STATE_AGGREGATION 0x4 102*4882a593Smuzhiyun #define LACP_STATE_SYNCHRONIZATION 0x8 103*4882a593Smuzhiyun #define LACP_STATE_COLLECTING 0x10 104*4882a593Smuzhiyun #define LACP_STATE_DISTRIBUTING 0x20 105*4882a593Smuzhiyun #define LACP_STATE_DEFAULTED 0x40 106*4882a593Smuzhiyun #define LACP_STATE_EXPIRED 0x80 107*4882a593Smuzhiyun 108*4882a593Smuzhiyun typedef struct ifbond { 109*4882a593Smuzhiyun __s32 bond_mode; 110*4882a593Smuzhiyun __s32 num_slaves; 111*4882a593Smuzhiyun __s32 miimon; 112*4882a593Smuzhiyun } ifbond; 113*4882a593Smuzhiyun 114*4882a593Smuzhiyun typedef struct ifslave { 115*4882a593Smuzhiyun __s32 slave_id; /* Used as an IN param to the BOND_SLAVE_INFO_QUERY ioctl */ 116*4882a593Smuzhiyun char slave_name[IFNAMSIZ]; 117*4882a593Smuzhiyun __s8 link; 118*4882a593Smuzhiyun __s8 state; 119*4882a593Smuzhiyun __u32 link_failure_count; 120*4882a593Smuzhiyun } ifslave; 121*4882a593Smuzhiyun 122*4882a593Smuzhiyun struct ad_info { 123*4882a593Smuzhiyun __u16 aggregator_id; 124*4882a593Smuzhiyun __u16 ports; 125*4882a593Smuzhiyun __u16 actor_key; 126*4882a593Smuzhiyun __u16 partner_key; 127*4882a593Smuzhiyun __u8 partner_system[ETH_ALEN]; 128*4882a593Smuzhiyun }; 129*4882a593Smuzhiyun 130*4882a593Smuzhiyun /* Embedded inside LINK_XSTATS_TYPE_BOND */ 131*4882a593Smuzhiyun enum { 132*4882a593Smuzhiyun BOND_XSTATS_UNSPEC, 133*4882a593Smuzhiyun BOND_XSTATS_3AD, 134*4882a593Smuzhiyun __BOND_XSTATS_MAX 135*4882a593Smuzhiyun }; 136*4882a593Smuzhiyun #define BOND_XSTATS_MAX (__BOND_XSTATS_MAX - 1) 137*4882a593Smuzhiyun 138*4882a593Smuzhiyun /* Embedded inside BOND_XSTATS_3AD */ 139*4882a593Smuzhiyun enum { 140*4882a593Smuzhiyun BOND_3AD_STAT_LACPDU_RX, 141*4882a593Smuzhiyun BOND_3AD_STAT_LACPDU_TX, 142*4882a593Smuzhiyun BOND_3AD_STAT_LACPDU_UNKNOWN_RX, 143*4882a593Smuzhiyun BOND_3AD_STAT_LACPDU_ILLEGAL_RX, 144*4882a593Smuzhiyun BOND_3AD_STAT_MARKER_RX, 145*4882a593Smuzhiyun BOND_3AD_STAT_MARKER_TX, 146*4882a593Smuzhiyun BOND_3AD_STAT_MARKER_RESP_RX, 147*4882a593Smuzhiyun BOND_3AD_STAT_MARKER_RESP_TX, 148*4882a593Smuzhiyun BOND_3AD_STAT_MARKER_UNKNOWN_RX, 149*4882a593Smuzhiyun BOND_3AD_STAT_PAD, 150*4882a593Smuzhiyun __BOND_3AD_STAT_MAX 151*4882a593Smuzhiyun }; 152*4882a593Smuzhiyun #define BOND_3AD_STAT_MAX (__BOND_3AD_STAT_MAX - 1) 153*4882a593Smuzhiyun 154*4882a593Smuzhiyun #endif /* _LINUX_IF_BONDING_H */ 155*4882a593Smuzhiyun 156*4882a593Smuzhiyun /* 157*4882a593Smuzhiyun * Local variables: 158*4882a593Smuzhiyun * version-control: t 159*4882a593Smuzhiyun * kept-new-versions: 5 160*4882a593Smuzhiyun * c-indent-level: 8 161*4882a593Smuzhiyun * c-basic-offset: 8 162*4882a593Smuzhiyun * tab-width: 8 163*4882a593Smuzhiyun * End: 164*4882a593Smuzhiyun */ 165*4882a593Smuzhiyun 166