blob: 80f6d2a28acb7f04def69df832ffe695c5ae408c [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 Tarreau6911fa42007-03-04 18:06:08 +01005 Copyright (C) 2000-2007 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 Tarreauca28d1e2007-01-24 18:20:50 +010030#include <proto/fd.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020031
32/****** string-specific macros and functions ******/
33/* if a > max, then bound <a> to <max>. The macro returns the new <a> */
34#define UBOUND(a, max) ({ typeof(a) b = (max); if ((a) > b) (a) = b; (a); })
35
36/* if a < min, then bound <a> to <min>. The macro returns the new <a> */
37#define LBOUND(a, min) ({ typeof(a) b = (min); if ((a) < b) (a) = b; (a); })
38
39/* returns 1 only if only zero or one bit is set in X, which means that X is a
40 * power of 2, and 0 otherwise */
41#define POWEROF2(x) (((x) & ((x)-1)) == 0)
42
Willy Tarreau7d58a632007-01-13 23:06:06 +010043/*
44 * Gcc >= 3 provides the ability for the programme to give hints to the
45 * compiler about what branch of an if is most likely to be taken. This
46 * helps the compiler produce the most compact critical paths, which is
47 * generally better for the cache and to reduce the number of jumps.
48 */
49#if __GNUC__ < 3
50#define __builtin_expect(x,y) (x)
51#endif
52
53#define likely(x) (__builtin_expect((x) != 0, 1))
54#define unlikely(x) (__builtin_expect((x) != 0, 0))
55
Willy Tarreaubaaee002006-06-26 02:48:02 +020056
57/*
58 * copies at most <size-1> chars from <src> to <dst>. Last char is always
59 * set to 0, unless <size> is 0. The number of chars copied is returned
60 * (excluding the terminating zero).
61 * This code has been optimized for size and speed : on x86, it's 45 bytes
62 * long, uses only registers, and consumes only 4 cycles per char.
63 */
64extern int strlcpy2(char *dst, const char *src, int size);
65
66/*
Willy Tarreau72d759c2007-10-25 12:14:10 +020067 * This function simply returns a locally allocated string containing
Willy Tarreaubaaee002006-06-26 02:48:02 +020068 * the ascii representation for number 'n' in decimal.
69 */
Willy Tarreau72d759c2007-10-25 12:14:10 +020070extern char itoa_str[][21];
71extern const char *ultoa_r(unsigned long n, char *buffer, int size);
72static inline const char *ultoa(unsigned long n)
73{
74 return ultoa_r(n, itoa_str[0], sizeof(itoa_str[0]));
75}
76
77/* Fast macros to convert up to 10 different parameters inside a same call of
78 * expression.
79 */
80#define U2A0(n) ({ ultoa_r((n), itoa_str[0], sizeof(itoa_str[0])); })
81#define U2A1(n) ({ ultoa_r((n), itoa_str[1], sizeof(itoa_str[1])); })
82#define U2A2(n) ({ ultoa_r((n), itoa_str[2], sizeof(itoa_str[2])); })
83#define U2A3(n) ({ ultoa_r((n), itoa_str[3], sizeof(itoa_str[3])); })
84#define U2A4(n) ({ ultoa_r((n), itoa_str[4], sizeof(itoa_str[4])); })
85#define U2A5(n) ({ ultoa_r((n), itoa_str[5], sizeof(itoa_str[5])); })
86#define U2A6(n) ({ ultoa_r((n), itoa_str[6], sizeof(itoa_str[6])); })
87#define U2A7(n) ({ ultoa_r((n), itoa_str[7], sizeof(itoa_str[7])); })
88#define U2A8(n) ({ ultoa_r((n), itoa_str[8], sizeof(itoa_str[8])); })
89#define U2A9(n) ({ ultoa_r((n), itoa_str[9], sizeof(itoa_str[9])); })
Willy Tarreaubaaee002006-06-26 02:48:02 +020090
91/*
Willy Tarreau91092e52007-10-25 16:58:42 +020092 * This function simply returns a locally allocated string containing the ascii
93 * representation for number 'n' in decimal, unless n is 0 in which case it
94 * returns the alternate string (or an empty string if the alternate string is
95 * NULL). It use is intended for limits reported in reports, where it's
96 * desirable not to display anything if there is no limit. Warning! it shares
97 * the same vector as ultoa_r().
98 */
99extern const char *limit_r(unsigned long n, char *buffer, int size, const char *alt);
100
101/* Fast macros to convert up to 10 different parameters inside a same call of
102 * expression. Warning! they share the same vectors as U2A*!
103 */
104#define LIM2A0(n, alt) ({ limit_r((n), itoa_str[0], sizeof(itoa_str[0]), (alt)); })
105#define LIM2A1(n, alt) ({ limit_r((n), itoa_str[1], sizeof(itoa_str[1]), (alt)); })
106#define LIM2A2(n, alt) ({ limit_r((n), itoa_str[2], sizeof(itoa_str[2]), (alt)); })
107#define LIM2A3(n, alt) ({ limit_r((n), itoa_str[3], sizeof(itoa_str[3]), (alt)); })
108#define LIM2A4(n, alt) ({ limit_r((n), itoa_str[4], sizeof(itoa_str[4]), (alt)); })
109#define LIM2A5(n, alt) ({ limit_r((n), itoa_str[5], sizeof(itoa_str[5]), (alt)); })
110#define LIM2A6(n, alt) ({ limit_r((n), itoa_str[6], sizeof(itoa_str[6]), (alt)); })
111#define LIM2A7(n, alt) ({ limit_r((n), itoa_str[7], sizeof(itoa_str[7]), (alt)); })
112#define LIM2A8(n, alt) ({ limit_r((n), itoa_str[8], sizeof(itoa_str[8]), (alt)); })
113#define LIM2A9(n, alt) ({ limit_r((n), itoa_str[9], sizeof(itoa_str[9]), (alt)); })
114
115/*
Willy Tarreaubaaee002006-06-26 02:48:02 +0200116 * Returns non-zero if character <s> is a hex digit (0-9, a-f, A-F), else zero.
117 */
118extern int ishex(char s);
119
120/*
121 * converts <str> to a struct sockaddr_in* which is locally allocated.
122 * The format is "addr:port", where "addr" can be a dotted IPv4 address,
123 * a host name, or empty or "*" to indicate INADDR_ANY.
124 */
125struct sockaddr_in *str2sa(char *str);
126
127/*
Willy Tarreaud077a8e2007-05-08 18:28:09 +0200128 * converts <str> to two struct in_addr* which must be pre-allocated.
Willy Tarreaubaaee002006-06-26 02:48:02 +0200129 * The format is "addr[/mask]", where "addr" cannot be empty, and mask
130 * is optionnal and either in the dotted or CIDR notation.
131 * Note: "addr" can also be a hostname. Returns 1 if OK, 0 if error.
132 */
Willy Tarreaud077a8e2007-05-08 18:28:09 +0200133int str2net(const char *str, struct in_addr *addr, struct in_addr *mask);
Willy Tarreaubaaee002006-06-26 02:48:02 +0200134
Alexandre Cassen5eb1a902007-11-29 15:43:32 +0100135/*
136 * Resolve destination server from URL. Convert <str> to a sockaddr_in*.
137 */
138int url2sa(const char *url, int ulen, struct sockaddr_in *addr);
139
Willy Tarreaubaaee002006-06-26 02:48:02 +0200140/* will try to encode the string <string> replacing all characters tagged in
141 * <map> with the hexadecimal representation of their ASCII-code (2 digits)
142 * prefixed by <escape>, and will store the result between <start> (included)
143 * and <stop> (excluded), and will always terminate the string with a '\0'
144 * before <stop>. The position of the '\0' is returned if the conversion
145 * completes. If bytes are missing between <start> and <stop>, then the
146 * conversion will be incomplete and truncated. If <stop> <= <start>, the '\0'
147 * cannot even be stored so we return <start> without writing the 0.
148 * The input string must also be zero-terminated.
149 */
150extern const char hextab[];
151char *encode_string(char *start, char *stop,
152 const char escape, const fd_set *map,
153 const char *string);
154
Willy Tarreau6911fa42007-03-04 18:06:08 +0100155/* This one is 6 times faster than strtoul() on athlon, but does
156 * no check at all.
157 */
158static inline unsigned int __str2ui(const char *s)
159{
160 unsigned int i = 0;
161 while (*s) {
162 i = i * 10 - '0';
163 i += (unsigned char)*s++;
164 }
165 return i;
166}
167
168/* This one is 5 times faster than strtoul() on athlon with checks.
169 * It returns the value of the number composed of all valid digits read.
170 */
171static inline unsigned int __str2uic(const char *s)
172{
173 unsigned int i = 0;
174 unsigned int j;
175 while (1) {
176 j = (*s++) - '0';
177 if (j > 9)
178 break;
179 i *= 10;
180 i += j;
181 }
182 return i;
183}
184
185/* This one is 28 times faster than strtoul() on athlon, but does
186 * no check at all!
187 */
188static inline unsigned int __strl2ui(const char *s, int len)
189{
190 unsigned int i = 0;
191 while (len-- > 0) {
192 i = i * 10 - '0';
193 i += (unsigned char)*s++;
194 }
195 return i;
196}
197
198/* This one is 7 times faster than strtoul() on athlon with checks.
199 * It returns the value of the number composed of all valid digits read.
200 */
201static inline unsigned int __strl2uic(const char *s, int len)
202{
203 unsigned int i = 0;
Willy Tarreau3f0c9762007-10-25 09:42:24 +0200204 unsigned int j, k;
Willy Tarreau6911fa42007-03-04 18:06:08 +0100205
206 while (len-- > 0) {
207 j = (*s++) - '0';
Willy Tarreau3f0c9762007-10-25 09:42:24 +0200208 k = i * 10;
Willy Tarreau6911fa42007-03-04 18:06:08 +0100209 if (j > 9)
210 break;
Willy Tarreau3f0c9762007-10-25 09:42:24 +0200211 i = k + j;
Willy Tarreau6911fa42007-03-04 18:06:08 +0100212 }
213 return i;
214}
215
216extern unsigned int str2ui(const char *s);
217extern unsigned int str2uic(const char *s);
218extern unsigned int strl2ui(const char *s, int len);
219extern unsigned int strl2uic(const char *s, int len);
220extern int strl2ic(const char *s, int len);
221extern int strl2irc(const char *s, int len, int *ret);
222extern int strl2llrc(const char *s, int len, long long *ret);
223
Willy Tarreaufe944602007-10-25 10:34:16 +0200224/* This function converts the time_t value <now> into a broken out struct tm
225 * which must be allocated by the caller. It is highly recommended to use this
226 * function intead of localtime() because that one requires a time_t* which
227 * is not always compatible with tv_sec depending on OS/hardware combinations.
228 */
229static inline void get_localtime(const time_t now, struct tm *tm)
230{
231 localtime_r(&now, tm);
232}
233
Willy Tarreau2dd0d472006-06-29 17:53:05 +0200234#endif /* _COMMON_STANDARD_H */