blob: 715ed240bc0eac8cfdb4b8919a273f2e5e0a9a54 [file] [log] [blame]
Willy Tarreaubaaee002006-06-26 02:48:02 +02001/*
Willy Tarreau2dd0d472006-06-29 17:53:05 +02002 include/common/standard.h
Willy Tarreaubaaee002006-06-26 02:48:02 +02003 This files contains some general purpose functions and macros.
4
Willy Tarreauc6f4ce82009-06-10 11:09:37 +02005 Copyright (C) 2000-2009 Willy Tarreau - w@1wt.eu
Willy Tarreaubaaee002006-06-26 02:48:02 +02006
7 This library is free software; you can redistribute it and/or
8 modify it under the terms of the GNU Lesser General Public
9 License as published by the Free Software Foundation, version 2.1
10 exclusively.
11
12 This library is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 Lesser General Public License for more details.
16
17 You should have received a copy of the GNU Lesser General Public
18 License along with this library; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20*/
21
Willy Tarreau2dd0d472006-06-29 17:53:05 +020022#ifndef _COMMON_STANDARD_H
23#define _COMMON_STANDARD_H
Willy Tarreaubaaee002006-06-26 02:48:02 +020024
Willy Tarreau167d8b52007-04-09 22:16:12 +020025#include <limits.h>
Willy Tarreaufe944602007-10-25 10:34:16 +020026#include <time.h>
Willy Tarreau938b3032007-05-10 06:39:03 +020027#include <sys/types.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020028#include <netinet/in.h>
Willy Tarreaue3ba5f02006-06-29 18:54:54 +020029#include <common/config.h>
Willy Tarreau482b00d2009-10-04 22:48:42 +020030#include <common/eb32tree.h>
Willy Tarreauca28d1e2007-01-24 18:20:50 +010031#include <proto/fd.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020032
33/****** string-specific macros and functions ******/
34/* if a > max, then bound <a> to <max>. The macro returns the new <a> */
35#define UBOUND(a, max) ({ typeof(a) b = (max); if ((a) > b) (a) = b; (a); })
36
37/* if a < min, then bound <a> to <min>. The macro returns the new <a> */
38#define LBOUND(a, min) ({ typeof(a) b = (min); if ((a) < b) (a) = b; (a); })
39
40/* returns 1 only if only zero or one bit is set in X, which means that X is a
41 * power of 2, and 0 otherwise */
42#define POWEROF2(x) (((x) & ((x)-1)) == 0)
43
Willy Tarreau7d58a632007-01-13 23:06:06 +010044/*
45 * Gcc >= 3 provides the ability for the programme to give hints to the
46 * compiler about what branch of an if is most likely to be taken. This
47 * helps the compiler produce the most compact critical paths, which is
48 * generally better for the cache and to reduce the number of jumps.
49 */
Willy Tarreau70bcfb72008-01-27 02:21:53 +010050#if !defined(likely)
Willy Tarreau7d58a632007-01-13 23:06:06 +010051#if __GNUC__ < 3
52#define __builtin_expect(x,y) (x)
Willy Tarreau70bcfb72008-01-27 02:21:53 +010053#define likely(x) (x)
54#define unlikely(x) (x)
55#elif __GNUC__ < 4
56/* gcc 3.x does the best job at this */
Willy Tarreau7d58a632007-01-13 23:06:06 +010057#define likely(x) (__builtin_expect((x) != 0, 1))
58#define unlikely(x) (__builtin_expect((x) != 0, 0))
Willy Tarreau70bcfb72008-01-27 02:21:53 +010059#else
60/* GCC 4.x is stupid, it performs the comparison then compares it to 1,
61 * so we cheat in a dirty way to prevent it from doing this. This will
62 * only work with ints and booleans though.
63 */
64#define likely(x) (x)
Willy Tarreau75875a72008-07-06 15:18:50 +020065#define unlikely(x) (__builtin_expect((unsigned long)(x), 0))
Willy Tarreau70bcfb72008-01-27 02:21:53 +010066#endif
67#endif
Willy Tarreaubaaee002006-06-26 02:48:02 +020068
69/*
70 * copies at most <size-1> chars from <src> to <dst>. Last char is always
71 * set to 0, unless <size> is 0. The number of chars copied is returned
72 * (excluding the terminating zero).
73 * This code has been optimized for size and speed : on x86, it's 45 bytes
74 * long, uses only registers, and consumes only 4 cycles per char.
75 */
76extern int strlcpy2(char *dst, const char *src, int size);
77
78/*
Willy Tarreau72d759c2007-10-25 12:14:10 +020079 * This function simply returns a locally allocated string containing
Willy Tarreaubaaee002006-06-26 02:48:02 +020080 * the ascii representation for number 'n' in decimal.
81 */
Willy Tarreaue7239b52009-03-29 13:41:58 +020082extern char itoa_str[][171];
Willy Tarreau72d759c2007-10-25 12:14:10 +020083extern const char *ultoa_r(unsigned long n, char *buffer, int size);
Willy Tarreaue7239b52009-03-29 13:41:58 +020084extern const char *ulltoh_r(unsigned long long n, char *buffer, int size);
Willy Tarreau72d759c2007-10-25 12:14:10 +020085static inline const char *ultoa(unsigned long n)
86{
87 return ultoa_r(n, itoa_str[0], sizeof(itoa_str[0]));
88}
89
90/* Fast macros to convert up to 10 different parameters inside a same call of
91 * expression.
92 */
93#define U2A0(n) ({ ultoa_r((n), itoa_str[0], sizeof(itoa_str[0])); })
94#define U2A1(n) ({ ultoa_r((n), itoa_str[1], sizeof(itoa_str[1])); })
95#define U2A2(n) ({ ultoa_r((n), itoa_str[2], sizeof(itoa_str[2])); })
96#define U2A3(n) ({ ultoa_r((n), itoa_str[3], sizeof(itoa_str[3])); })
97#define U2A4(n) ({ ultoa_r((n), itoa_str[4], sizeof(itoa_str[4])); })
98#define U2A5(n) ({ ultoa_r((n), itoa_str[5], sizeof(itoa_str[5])); })
99#define U2A6(n) ({ ultoa_r((n), itoa_str[6], sizeof(itoa_str[6])); })
100#define U2A7(n) ({ ultoa_r((n), itoa_str[7], sizeof(itoa_str[7])); })
101#define U2A8(n) ({ ultoa_r((n), itoa_str[8], sizeof(itoa_str[8])); })
102#define U2A9(n) ({ ultoa_r((n), itoa_str[9], sizeof(itoa_str[9])); })
Willy Tarreaubaaee002006-06-26 02:48:02 +0200103
Willy Tarreaue7239b52009-03-29 13:41:58 +0200104/* The same macros provide HTML encoding of numbers */
105#define U2H0(n) ({ ulltoh_r((n), itoa_str[0], sizeof(itoa_str[0])); })
106#define U2H1(n) ({ ulltoh_r((n), itoa_str[1], sizeof(itoa_str[1])); })
107#define U2H2(n) ({ ulltoh_r((n), itoa_str[2], sizeof(itoa_str[2])); })
108#define U2H3(n) ({ ulltoh_r((n), itoa_str[3], sizeof(itoa_str[3])); })
109#define U2H4(n) ({ ulltoh_r((n), itoa_str[4], sizeof(itoa_str[4])); })
110#define U2H5(n) ({ ulltoh_r((n), itoa_str[5], sizeof(itoa_str[5])); })
111#define U2H6(n) ({ ulltoh_r((n), itoa_str[6], sizeof(itoa_str[6])); })
112#define U2H7(n) ({ ulltoh_r((n), itoa_str[7], sizeof(itoa_str[7])); })
113#define U2H8(n) ({ ulltoh_r((n), itoa_str[8], sizeof(itoa_str[8])); })
114#define U2H9(n) ({ ulltoh_r((n), itoa_str[9], sizeof(itoa_str[9])); })
115
Willy Tarreaubaaee002006-06-26 02:48:02 +0200116/*
Willy Tarreau91092e52007-10-25 16:58:42 +0200117 * This function simply returns a locally allocated string containing the ascii
118 * representation for number 'n' in decimal, unless n is 0 in which case it
119 * returns the alternate string (or an empty string if the alternate string is
120 * NULL). It use is intended for limits reported in reports, where it's
121 * desirable not to display anything if there is no limit. Warning! it shares
122 * the same vector as ultoa_r().
123 */
124extern const char *limit_r(unsigned long n, char *buffer, int size, const char *alt);
125
126/* Fast macros to convert up to 10 different parameters inside a same call of
127 * expression. Warning! they share the same vectors as U2A*!
128 */
129#define LIM2A0(n, alt) ({ limit_r((n), itoa_str[0], sizeof(itoa_str[0]), (alt)); })
130#define LIM2A1(n, alt) ({ limit_r((n), itoa_str[1], sizeof(itoa_str[1]), (alt)); })
131#define LIM2A2(n, alt) ({ limit_r((n), itoa_str[2], sizeof(itoa_str[2]), (alt)); })
132#define LIM2A3(n, alt) ({ limit_r((n), itoa_str[3], sizeof(itoa_str[3]), (alt)); })
133#define LIM2A4(n, alt) ({ limit_r((n), itoa_str[4], sizeof(itoa_str[4]), (alt)); })
134#define LIM2A5(n, alt) ({ limit_r((n), itoa_str[5], sizeof(itoa_str[5]), (alt)); })
135#define LIM2A6(n, alt) ({ limit_r((n), itoa_str[6], sizeof(itoa_str[6]), (alt)); })
136#define LIM2A7(n, alt) ({ limit_r((n), itoa_str[7], sizeof(itoa_str[7]), (alt)); })
137#define LIM2A8(n, alt) ({ limit_r((n), itoa_str[8], sizeof(itoa_str[8]), (alt)); })
138#define LIM2A9(n, alt) ({ limit_r((n), itoa_str[9], sizeof(itoa_str[9]), (alt)); })
139
140/*
Willy Tarreaubaaee002006-06-26 02:48:02 +0200141 * Returns non-zero if character <s> is a hex digit (0-9, a-f, A-F), else zero.
142 */
143extern int ishex(char s);
144
145/*
Willy Tarreau2e74c3f2007-12-02 18:45:09 +0100146 * Checks <name> for invalid characters. Valid chars are [A-Za-z0-9_:.-]. If an
147 * invalid character is found, a pointer to it is returned. If everything is
148 * fine, NULL is returned.
149 */
150extern const char *invalid_char(const char *name);
151
152/*
Krzysztof Piotr Oledzkiefe3b6f2008-05-23 23:49:32 +0200153 * Checks <domainname> for invalid characters. Valid chars are [A-Za-z0-9_.-].
154 * If an invalid character is found, a pointer to it is returned.
155 * If everything is fine, NULL is returned.
156 */
157extern const char *invalid_domainchar(const char *name);
158
159/*
Robert Tsai81ae1952007-12-05 10:47:29 +0100160 * converts <str> to a struct sockaddr_un* which is locally allocated.
161 * The format is "/path", where "/path" is a path to a UNIX domain socket.
162 */
Willy Tarreaucaf720d2008-03-07 10:07:04 +0100163struct sockaddr_un *str2sun(const char *str);
Robert Tsai81ae1952007-12-05 10:47:29 +0100164
165/*
Willy Tarreaubaaee002006-06-26 02:48:02 +0200166 * converts <str> to a struct sockaddr_in* which is locally allocated.
167 * The format is "addr:port", where "addr" can be a dotted IPv4 address,
168 * a host name, or empty or "*" to indicate INADDR_ANY.
169 */
170struct sockaddr_in *str2sa(char *str);
171
172/*
Willy Tarreauc6f4ce82009-06-10 11:09:37 +0200173 * converts <str> to a struct sockaddr_in* which is locally allocated, and a
174 * port range consisting in two integers. The low and high end are always set
175 * even if the port is unspecified, in which case (0,0) is returned. The low
176 * port is set in the sockaddr_in. Thus, it is enough to check the size of the
177 * returned range to know if an array must be allocated or not. The format is
178 * "addr[:port[-port]]", where "addr" can be a dotted IPv4 address, a host
179 * name, or empty or "*" to indicate INADDR_ANY.
180 */
181struct sockaddr_in *str2sa_range(char *str, int *low, int *high);
182
183/*
Willy Tarreaud077a8e2007-05-08 18:28:09 +0200184 * converts <str> to two struct in_addr* which must be pre-allocated.
Willy Tarreaubaaee002006-06-26 02:48:02 +0200185 * The format is "addr[/mask]", where "addr" cannot be empty, and mask
186 * is optionnal and either in the dotted or CIDR notation.
187 * Note: "addr" can also be a hostname. Returns 1 if OK, 0 if error.
188 */
Willy Tarreaud077a8e2007-05-08 18:28:09 +0200189int str2net(const char *str, struct in_addr *addr, struct in_addr *mask);
Willy Tarreaubaaee002006-06-26 02:48:02 +0200190
Alexandre Cassen5eb1a902007-11-29 15:43:32 +0100191/*
Willy Tarreau106f9792009-09-19 07:54:16 +0200192 * Parse IP address found in url.
193 */
194int url2ip(const char *addr, struct in_addr *dst);
195
196/*
Alexandre Cassen5eb1a902007-11-29 15:43:32 +0100197 * Resolve destination server from URL. Convert <str> to a sockaddr_in*.
198 */
199int url2sa(const char *url, int ulen, struct sockaddr_in *addr);
200
Willy Tarreaubaaee002006-06-26 02:48:02 +0200201/* will try to encode the string <string> replacing all characters tagged in
202 * <map> with the hexadecimal representation of their ASCII-code (2 digits)
203 * prefixed by <escape>, and will store the result between <start> (included)
204 * and <stop> (excluded), and will always terminate the string with a '\0'
205 * before <stop>. The position of the '\0' is returned if the conversion
206 * completes. If bytes are missing between <start> and <stop>, then the
207 * conversion will be incomplete and truncated. If <stop> <= <start>, the '\0'
208 * cannot even be stored so we return <start> without writing the 0.
209 * The input string must also be zero-terminated.
210 */
211extern const char hextab[];
212char *encode_string(char *start, char *stop,
213 const char escape, const fd_set *map,
214 const char *string);
215
Willy Tarreau6911fa42007-03-04 18:06:08 +0100216/* This one is 6 times faster than strtoul() on athlon, but does
217 * no check at all.
218 */
219static inline unsigned int __str2ui(const char *s)
220{
221 unsigned int i = 0;
222 while (*s) {
223 i = i * 10 - '0';
224 i += (unsigned char)*s++;
225 }
226 return i;
227}
228
229/* This one is 5 times faster than strtoul() on athlon with checks.
230 * It returns the value of the number composed of all valid digits read.
231 */
232static inline unsigned int __str2uic(const char *s)
233{
234 unsigned int i = 0;
235 unsigned int j;
236 while (1) {
237 j = (*s++) - '0';
238 if (j > 9)
239 break;
240 i *= 10;
241 i += j;
242 }
243 return i;
244}
245
246/* This one is 28 times faster than strtoul() on athlon, but does
247 * no check at all!
248 */
249static inline unsigned int __strl2ui(const char *s, int len)
250{
251 unsigned int i = 0;
252 while (len-- > 0) {
253 i = i * 10 - '0';
254 i += (unsigned char)*s++;
255 }
256 return i;
257}
258
259/* This one is 7 times faster than strtoul() on athlon with checks.
260 * It returns the value of the number composed of all valid digits read.
261 */
262static inline unsigned int __strl2uic(const char *s, int len)
263{
264 unsigned int i = 0;
Willy Tarreau3f0c9762007-10-25 09:42:24 +0200265 unsigned int j, k;
Willy Tarreau6911fa42007-03-04 18:06:08 +0100266
267 while (len-- > 0) {
268 j = (*s++) - '0';
Willy Tarreau3f0c9762007-10-25 09:42:24 +0200269 k = i * 10;
Willy Tarreau6911fa42007-03-04 18:06:08 +0100270 if (j > 9)
271 break;
Willy Tarreau3f0c9762007-10-25 09:42:24 +0200272 i = k + j;
Willy Tarreau6911fa42007-03-04 18:06:08 +0100273 }
274 return i;
275}
276
277extern unsigned int str2ui(const char *s);
278extern unsigned int str2uic(const char *s);
279extern unsigned int strl2ui(const char *s, int len);
280extern unsigned int strl2uic(const char *s, int len);
281extern int strl2ic(const char *s, int len);
282extern int strl2irc(const char *s, int len, int *ret);
283extern int strl2llrc(const char *s, int len, long long *ret);
284
Willy Tarreaufe944602007-10-25 10:34:16 +0200285/* This function converts the time_t value <now> into a broken out struct tm
286 * which must be allocated by the caller. It is highly recommended to use this
287 * function intead of localtime() because that one requires a time_t* which
288 * is not always compatible with tv_sec depending on OS/hardware combinations.
289 */
290static inline void get_localtime(const time_t now, struct tm *tm)
291{
292 localtime_r(&now, tm);
293}
294
Emeric Brun3a058f32009-06-30 18:26:00 +0200295/* This function converts the time_t value <now> into a broken out struct tm
296 * which must be allocated by the caller. It is highly recommended to use this
297 * function intead of gmtime() because that one requires a time_t* which
298 * is not always compatible with tv_sec depending on OS/hardware combinations.
299 */
300static inline void get_gmtime(const time_t now, struct tm *tm)
301{
302 gmtime_r(&now, tm);
303}
304
Willy Tarreaua0d37b62007-12-02 22:00:35 +0100305/* This function parses a time value optionally followed by a unit suffix among
306 * "d", "h", "m", "s", "ms" or "us". It converts the value into the unit
307 * expected by the caller. The computation does its best to avoid overflows.
308 * The value is returned in <ret> if everything is fine, and a NULL is returned
309 * by the function. In case of error, a pointer to the error is returned and
310 * <ret> is left untouched.
311 */
312extern const char *parse_time_err(const char *text, unsigned *ret, unsigned unit_flags);
313
314/* unit flags to pass to parse_time_err */
315#define TIME_UNIT_US 0x0000
316#define TIME_UNIT_MS 0x0001
317#define TIME_UNIT_S 0x0002
318#define TIME_UNIT_MIN 0x0003
319#define TIME_UNIT_HOUR 0x0004
320#define TIME_UNIT_DAY 0x0005
321#define TIME_UNIT_MASK 0x0007
322
Willy Tarreau7f062c42009-03-05 18:43:00 +0100323/* Multiply the two 32-bit operands and shift the 64-bit result right 32 bits.
324 * This is used to compute fixed ratios by setting one of the operands to
325 * (2^32*ratio).
326 */
327static inline unsigned int mul32hi(unsigned int a, unsigned int b)
328{
329 return ((unsigned long long)a * b) >> 32;
330}
331
Willy Tarreau946ba592009-05-10 15:41:18 +0200332/* copies at most <n> characters from <src> and always terminates with '\0' */
333char *my_strndup(const char *src, int n);
334
Willy Tarreau482b00d2009-10-04 22:48:42 +0200335/* This function returns the first unused key greater than or equal to <key> in
336 * ID tree <root>. Zero is returned if no place is found.
337 */
338unsigned int get_next_id(struct eb_root *root, unsigned int key);
339
Willy Tarreau2dd0d472006-06-29 17:53:05 +0200340#endif /* _COMMON_STANDARD_H */