160
struct xtables_rule_match {
161
struct xtables_rule_match *next;
162
struct xtables_match *match;
163
/* Multiple matches of the same type: the ones before
164
the current one are completed from parsing point of view */
169
* struct xtables_pprot -
171
* A few hardcoded protocols for 'all' and in case the user has no
174
struct xtables_pprot {
179
enum xtables_tryload {
183
XTF_LOAD_MUST_SUCCEED,
186
enum xtables_exittype {
197
struct xtables_globals
199
unsigned int option_offset;
200
const char *program_name, *program_version;
201
struct option *orig_opts;
203
void (*exit_err)(enum xtables_exittype status, const char *msg, ...) __attribute__((noreturn, format(printf,2,3)));
206
extern const char *xtables_modprobe_program;
207
extern struct xtables_match *xtables_matches;
208
extern struct xtables_target *xtables_targets;
210
extern void xtables_init(void);
211
extern void xtables_set_nfproto(uint8_t);
212
extern void *xtables_calloc(size_t, size_t);
213
extern void *xtables_malloc(size_t);
215
extern int xtables_insmod(const char *, const char *, bool);
216
extern int xtables_load_ko(const char *, bool);
217
extern int xtables_set_params(struct xtables_globals *xtp);
218
extern void xtables_set_revision(char *name, u_int8_t revision);
219
extern void xtables_free_opts(int reset_offset);
220
extern struct option *xtables_merge_options(struct option *oldopts,
221
const struct option *newopts, unsigned int *option_offset);
223
extern int xtables_init_all(struct xtables_globals *xtp, uint8_t nfproto);
224
extern struct xtables_match *xtables_find_match(const char *name,
225
enum xtables_tryload, struct xtables_rule_match **match);
226
extern struct xtables_target *xtables_find_target(const char *name,
227
enum xtables_tryload);
138
229
/* Your shared library should call one of these. */
139
230
extern void xtables_register_match(struct xtables_match *me);
140
231
extern void xtables_register_target(struct xtables_target *me);
142
extern int string_to_number_ll(const char *s,
143
unsigned long long min,
144
unsigned long long max,
145
unsigned long long *ret);
146
extern int string_to_number_l(const char *s,
150
extern int string_to_number(const char *s,
154
extern bool strtonuml(const char *, char **, unsigned long *,
233
extern bool xtables_strtoul(const char *, char **, unsigned long *,
155
234
unsigned long, unsigned long);
156
extern bool strtonum(const char *, char **, unsigned int *,
235
extern bool xtables_strtoui(const char *, char **, unsigned int *,
157
236
unsigned int, unsigned int);
158
extern int service_to_port(const char *name, const char *proto);
159
extern u_int16_t parse_port(const char *port, const char *proto);
237
extern int xtables_service_to_port(const char *name, const char *proto);
238
extern u_int16_t xtables_parse_port(const char *port, const char *proto);
161
parse_interface(const char *arg, char *vianame, unsigned char *mask);
240
xtables_parse_interface(const char *arg, char *vianame, unsigned char *mask);
174
242
/* this is a special 64bit data type that is 8-byte aligned */
175
243
#define aligned_u64 u_int64_t __attribute__((aligned(8)))
177
int check_inverse(const char option[], int *invert, int *my_optind, int argc);
178
void exit_error(enum exittype, const char *, ...)__attribute__((noreturn,
179
format(printf,2,3)));
180
extern void param_act(unsigned int, const char *, ...);
181
extern const char *program_name, *program_version;
183
extern const char *ipaddr_to_numeric(const struct in_addr *);
184
extern const char *ipaddr_to_anyname(const struct in_addr *);
185
extern const char *ipmask_to_numeric(const struct in_addr *);
186
extern struct in_addr *numeric_to_ipaddr(const char *);
187
extern struct in_addr *numeric_to_ipmask(const char *);
188
extern void ipparse_hostnetworkmask(const char *, struct in_addr **,
245
int xtables_check_inverse(const char option[], int *invert,
246
int *my_optind, int argc);
247
extern struct xtables_globals *xt_params;
248
#define xtables_error (xt_params->exit_err)
250
extern void xtables_param_act(unsigned int, const char *, ...);
252
extern const char *xtables_ipaddr_to_numeric(const struct in_addr *);
253
extern const char *xtables_ipaddr_to_anyname(const struct in_addr *);
254
extern const char *xtables_ipmask_to_numeric(const struct in_addr *);
255
extern struct in_addr *xtables_numeric_to_ipaddr(const char *);
256
extern struct in_addr *xtables_numeric_to_ipmask(const char *);
257
extern void xtables_ipparse_any(const char *, struct in_addr **,
189
258
struct in_addr *, unsigned int *);
191
extern struct in6_addr *numeric_to_ip6addr(const char *);
192
extern const char *ip6addr_to_numeric(const struct in6_addr *);
193
extern const char *ip6addr_to_anyname(const struct in6_addr *);
194
extern const char *ip6mask_to_numeric(const struct in6_addr *);
195
extern void ip6parse_hostnetworkmask(const char *, struct in6_addr **,
260
extern struct in6_addr *xtables_numeric_to_ip6addr(const char *);
261
extern const char *xtables_ip6addr_to_numeric(const struct in6_addr *);
262
extern const char *xtables_ip6addr_to_anyname(const struct in6_addr *);
263
extern const char *xtables_ip6mask_to_numeric(const struct in6_addr *);
264
extern void xtables_ip6parse_any(const char *, struct in6_addr **,
196
265
struct in6_addr *, unsigned int *);
199
268
* Print the specified value to standard output, quoting dangerous
200
269
* characters if required.
202
extern void save_string(const char *value);
271
extern void xtables_save_string(const char *value);
204
273
#ifdef NO_SHARED_LIBS