xref: /OK3568_Linux_fs/kernel/include/uapi/linux/if_bonding.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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