blob: 8efda8a4b46b4194acbc37430c509999d498a548 [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 Tarreau938b3032007-05-10 06:39:03 +020026#include <sys/types.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020027#include <netinet/in.h>
Willy Tarreaue3ba5f02006-06-29 18:54:54 +020028#include <common/config.h>
Willy Tarreauca28d1e2007-01-24 18:20:50 +010029#include <proto/fd.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020030
31/****** string-specific macros and functions ******/
32/* if a > max, then bound <a> to <max>. The macro returns the new <a> */
33#define UBOUND(a, max) ({ typeof(a) b = (max); if ((a) > b) (a) = b; (a); })
34
35/* if a < min, then bound <a> to <min>. The macro returns the new <a> */
36#define LBOUND(a, min) ({ typeof(a) b = (min); if ((a) < b) (a) = b; (a); })
37
38/* returns 1 only if only zero or one bit is set in X, which means that X is a
39 * power of 2, and 0 otherwise */
40#define POWEROF2(x) (((x) & ((x)-1)) == 0)
41
Willy Tarreau7d58a632007-01-13 23:06:06 +010042/*
43 * Gcc >= 3 provides the ability for the programme to give hints to the
44 * compiler about what branch of an if is most likely to be taken. This
45 * helps the compiler produce the most compact critical paths, which is
46 * generally better for the cache and to reduce the number of jumps.
47 */
48#if __GNUC__ < 3
49#define __builtin_expect(x,y) (x)
50#endif
51
52#define likely(x) (__builtin_expect((x) != 0, 1))
53#define unlikely(x) (__builtin_expect((x) != 0, 0))
54
Willy Tarreaubaaee002006-06-26 02:48:02 +020055
56/*
57 * copies at most <size-1> chars from <src> to <dst>. Last char is always
58 * set to 0, unless <size> is 0. The number of chars copied is returned
59 * (excluding the terminating zero).
60 * This code has been optimized for size and speed : on x86, it's 45 bytes
61 * long, uses only registers, and consumes only 4 cycles per char.
62 */
63extern int strlcpy2(char *dst, const char *src, int size);
64
65/*
66 * This function simply returns a statically allocated string containing
67 * the ascii representation for number 'n' in decimal.
68 */
69extern char *ultoa(unsigned long n);
70
71/*
72 * Returns non-zero if character <s> is a hex digit (0-9, a-f, A-F), else zero.
73 */
74extern int ishex(char s);
75
76/*
77 * converts <str> to a struct sockaddr_in* which is locally allocated.
78 * The format is "addr:port", where "addr" can be a dotted IPv4 address,
79 * a host name, or empty or "*" to indicate INADDR_ANY.
80 */
81struct sockaddr_in *str2sa(char *str);
82
83/*
Willy Tarreaud077a8e2007-05-08 18:28:09 +020084 * converts <str> to two struct in_addr* which must be pre-allocated.
Willy Tarreaubaaee002006-06-26 02:48:02 +020085 * The format is "addr[/mask]", where "addr" cannot be empty, and mask
86 * is optionnal and either in the dotted or CIDR notation.
87 * Note: "addr" can also be a hostname. Returns 1 if OK, 0 if error.
88 */
Willy Tarreaud077a8e2007-05-08 18:28:09 +020089int str2net(const char *str, struct in_addr *addr, struct in_addr *mask);
Willy Tarreaubaaee002006-06-26 02:48:02 +020090
91/* will try to encode the string <string> replacing all characters tagged in
92 * <map> with the hexadecimal representation of their ASCII-code (2 digits)
93 * prefixed by <escape>, and will store the result between <start> (included)
94 * and <stop> (excluded), and will always terminate the string with a '\0'
95 * before <stop>. The position of the '\0' is returned if the conversion
96 * completes. If bytes are missing between <start> and <stop>, then the
97 * conversion will be incomplete and truncated. If <stop> <= <start>, the '\0'
98 * cannot even be stored so we return <start> without writing the 0.
99 * The input string must also be zero-terminated.
100 */
101extern const char hextab[];
102char *encode_string(char *start, char *stop,
103 const char escape, const fd_set *map,
104 const char *string);
105
Willy Tarreau6911fa42007-03-04 18:06:08 +0100106/* This one is 6 times faster than strtoul() on athlon, but does
107 * no check at all.
108 */
109static inline unsigned int __str2ui(const char *s)
110{
111 unsigned int i = 0;
112 while (*s) {
113 i = i * 10 - '0';
114 i += (unsigned char)*s++;
115 }
116 return i;
117}
118
119/* This one is 5 times faster than strtoul() on athlon with checks.
120 * It returns the value of the number composed of all valid digits read.
121 */
122static inline unsigned int __str2uic(const char *s)
123{
124 unsigned int i = 0;
125 unsigned int j;
126 while (1) {
127 j = (*s++) - '0';
128 if (j > 9)
129 break;
130 i *= 10;
131 i += j;
132 }
133 return i;
134}
135
136/* This one is 28 times faster than strtoul() on athlon, but does
137 * no check at all!
138 */
139static inline unsigned int __strl2ui(const char *s, int len)
140{
141 unsigned int i = 0;
142 while (len-- > 0) {
143 i = i * 10 - '0';
144 i += (unsigned char)*s++;
145 }
146 return i;
147}
148
149/* This one is 7 times faster than strtoul() on athlon with checks.
150 * It returns the value of the number composed of all valid digits read.
151 */
152static inline unsigned int __strl2uic(const char *s, int len)
153{
154 unsigned int i = 0;
155 unsigned int j;
156
157 while (len-- > 0) {
158 j = (*s++) - '0';
159 i = i * 10;
160 if (j > 9)
161 break;
162 i += j;
163 }
164 return i;
165}
166
167extern unsigned int str2ui(const char *s);
168extern unsigned int str2uic(const char *s);
169extern unsigned int strl2ui(const char *s, int len);
170extern unsigned int strl2uic(const char *s, int len);
171extern int strl2ic(const char *s, int len);
172extern int strl2irc(const char *s, int len, int *ret);
173extern int strl2llrc(const char *s, int len, long long *ret);
174
Willy Tarreau2dd0d472006-06-29 17:53:05 +0200175#endif /* _COMMON_STANDARD_H */