xref: /titanic_51/usr/src/cmd/cmd-inet/usr.lib/in.mpathd/mpd_defs.h (revision 25540de2e9a31b620c68d87ce2f3bbe8a196ad93)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
23  * Use is subject to license terms.
24  */
25 
26 #ifndef	_MPD_DEFS_H
27 #define	_MPD_DEFS_H
28 
29 #ifdef	__cplusplus
30 extern "C" {
31 #endif
32 
33 #include <alloca.h>
34 #include <stdio.h>
35 #include <stdlib.h>
36 #include <strings.h>
37 #include <errno.h>
38 #include <sys/types.h>
39 #include <limits.h>
40 #include <fcntl.h>
41 #include <signal.h>
42 #include <poll.h>
43 #include <unistd.h>
44 #include <time.h>
45 #include <stdarg.h>
46 #include <syslog.h>
47 
48 #include <sys/param.h>
49 #include <sys/socket.h>
50 #include <sys/sysmacros.h>
51 #include <arpa/inet.h>
52 #include <netdb.h>
53 
54 #include <sys/ioctl.h>
55 #include <sys/sockio.h>
56 #include <net/if.h>
57 #include <stropts.h>
58 #include <sys/tihdr.h>
59 #include <inet/mib2.h>
60 
61 #include <string.h>
62 #include <ctype.h>
63 
64 #include <netinet/in_systm.h>
65 #include <netinet/in.h>
66 #include <netinet/ip.h>
67 #include <netinet/ip_icmp.h>
68 #include <netinet/if_ether.h>
69 #include <netinet/ip6.h>
70 #include <netinet/icmp6.h>
71 #include <net/route.h>
72 #include <net/if_dl.h>
73 
74 #include <inet/ip.h>
75 #include <libintl.h>
76 #include <locale.h>
77 #include <deflt.h>
78 
79 #include <libdlpi.h>
80 #include <libinetutil.h>
81 #include <libnvpair.h>
82 #include <libsysevent.h>
83 #include <sys/sysevent.h>
84 #include <sys/sysevent/eventdefs.h>
85 #include <sys/sysevent/ipmp.h>
86 
87 #include <ipmp_mpathd.h>
88 #include <ipmp_query_impl.h>
89 #include <assert.h>
90 
91 /* Debug flags */
92 #define	D_ALL		0xffff		/* enable all debug */
93 #define	D_PROBE		0x0001		/* probe mechanism */
94 #define	D_FAILREP	0x0002		/* failure/repair mechanism */
95 #define	D_PHYINT	0x0004		/* phyint table */
96 #define	D_LOGINT	0x0008		/* logint table */
97 #define	D_TARGET	0x0010		/* target table */
98 #define	D_TIMER		0x0020		/* Timer mechanism */
99 #define	D_PKTBAD	0x0040		/* Malformed packet */
100 #define	D_LINKNOTE	0x0080		/* Link up/down notifications */
101 /*
102  * Need a common header file that defines the 2 constants below.
103  * Many applications need them.
104  */
105 #define	IF_SEPARATOR		':'
106 #define	IPV6_MAX_HOPS		255
107 
108 /*
109  * General parameters for phyint failure/repair detection
110  */
111 #define	NUM_PROBE_FAILS		5	/* NUM_PROBE_FAILS probe failures */
112 					/* trigger NIC failure detection */
113 #define	NUM_PROBE_REPAIRS	10	/* NUM_PROBE_REPAIRS probe repairs */
114 					/* trigger NIC repair detection */
115 
116 #define	MIN_RANDOM_FACTOR	0.5	/* Randomization factors to */
117 #define	MAX_RANDOM_FACTOR	1.0	/* determine probe send time */
118 
119 #define	MIN_PROBE_TARGETS	3	/* Minimum number of targets */
120 #define	MAX_PROBE_TARGETS	5	/* Maximum number of targets */
121 
122 /*
123  * A target that is declared slow is usable again after MIN_RECOVERY_TIME ns
124  */
125 #define	MIN_RECOVERY_TIME	(60000000000LL) /* (In ns) 60 secs */
126 
127 /*
128  * If the Failure Detection Time (FDT) is bumped up because the target CRTT
129  * is high, it won't be reduced for the next MIN_SETTLING_TIME ns, to prevent
130  * flapping of FDT
131  */
132 #define	MIN_SETTLING_TIME	(60000000000LL) /* (In ns) 60 secs */
133 
134 /*
135  * An admin or script might place a phyint in a group before assigning a test
136  * address.  To give them time to configure a test address, we delay whining
137  * about it being missing for TESTADDR_CONF_TIME seconds.
138  */
139 #define	TESTADDR_CONF_TIME	20
140 
141 /*
142  * The circular probe stats array should be able to hold enough
143  * samples to detect phyint failure, target failure, phyint repair
144  * and target repair.
145  */
146 #define	PROBE_STATS_COUNT	\
147 	((uint16_t)(NUM_PROBE_REPAIRS * MAX_PROBE_TARGETS + 2))
148 
149 #define	FAILURE_DETECTION_TIME	10000	/* Default is 10 s */
150 #define	MIN_FAILURE_DETECTION_TIME	100	/* Minimum is 100 ms */
151 #define	FAILURE_DETECTION_QP	40	/* quiet period, in seconds */
152 
153 #define	NEXT_FDT_MULTIPLE	2	/* Raise or lower the FDT by this */
154 					/* factor when required */
155 #define	LOWER_FDT_TRIGGER	4	/* Lower the FDT if crtt is less */
156 					/* than FDT / LOWER_FDT_TRIGGER  */
157 #define	EXCEPTION_FACTOR	2	/* The exception target has a crtt */
158 					/* greater by this factor */
159 
160 #define	IF_SCAN_INTERVAL	20000	/* Do initifs() every 20 secs */
161 
162 /* Return a random number from a range inclusive of the endpoints */
163 #define	GET_RANDOM(LOW, HIGH) (random() % ((HIGH) - (LOW) + 1) + (LOW))
164 
165 #define	TIMER_INFINITY	0x7FFFFFFFU	/* Never time out */
166 
167 /*
168  * Comparing unsigned 32 bit time values in a circular 32-bit sequence space
169  */
170 #define	TIME_GE(a, b)	((int32_t)((a) - (b)) >= 0)
171 #define	TIME_GT(a, b)	((int32_t)((a) - (b)) >  0)
172 #define	TIME_LT(a, b)	((int32_t)((a) - (b)) <  0)
173 #define	TIME_LE(a, b)	((int32_t)((a) - (b)) <= 0)
174 
175 /*
176  * Comparing unsigned 16 bit sequence numbers in a circular 16-bit
177  * sequence space
178  */
179 #define	SEQ_GE(a, b)	((int16_t)((a) - (b)) >= (int16_t)0)
180 #define	SEQ_GT(a, b)	((int16_t)((a) - (b)) >  (int16_t)0)
181 #define	SEQ_LT(a, b)	((int16_t)((a) - (b)) <  (int16_t)0)
182 #define	SEQ_LE(a, b)	((int16_t)((a) - (b)) <= (int16_t)0)
183 
184 #define	AF_OTHER(af)	((af) == AF_INET ? AF_INET6 : AF_INET)
185 #define	AF_STR(af)	((af) == AF_INET ? "inet" : "inet6")
186 
187 /*
188  * Globals
189  */
190 extern boolean_t failback_enabled;	/* cmd option to disable failbacks */
191 extern boolean_t track_all_phyints;	/* cmd option to track all phyints */
192 
193 					/* all times below in millisec */
194 extern	int	user_probe_interval;	/* interval between probes, as */
195 					/* derived from user specified fdt */
196 extern	int	user_failure_detection_time; /* User specified fdt */
197 
198 extern	int	ifsock_v4;		/* IPv4 socket for ioctls */
199 extern	int	ifsock_v6;		/* IPv6 socket for ioctls */
200 
201 extern int debug;			/* debug option */
202 extern boolean_t cleanup_started;	/* true if we're shutting down */
203 extern boolean_t handle_link_notifications;
204 
205 /*
206  * Function prototypes
207  */
208 extern void	timer_schedule(uint_t delay);
209 extern void	logmsg(int pri, const char *fmt, ...);
210 extern void	logperror(const char *str);
211 extern int	poll_add(int fd);
212 extern int	poll_remove(int fd);
213 extern uint64_t	getcurrentsec(void);
214 extern uint_t	getcurrenttime(void);
215 
216 #define	logerr(...)	logmsg(LOG_ERR, __VA_ARGS__)
217 #define	logtrace(...)	logmsg(LOG_INFO, __VA_ARGS__)
218 #define	logdebug(...)	logmsg(LOG_DEBUG, __VA_ARGS__)
219 
220 #ifdef	__cplusplus
221 }
222 #endif
223 
224 #endif	/* _MPD_DEFS_H */
225