char *program_version;
char *program_name;
struct option *opts;
- void (*exit_error)(enum xtables_exittype status, const char *msg, ...);
+ void (*exit_err)(enum xtables_exittype status, const char *msg, ...) __attribute__((noreturn, format(printf,2,3)));
};
extern const char *xtables_program_name;
extern int xtables_insmod(const char *, const char *, bool);
extern int xtables_load_ko(const char *, bool);
-int xtables_set_params(struct xtables_globals *xtp);
+extern int xtables_set_params(struct xtables_globals *xtp);
void xtables_free_opts(int reset_offset, struct option *original_opts);
extern struct xtables_match *xtables_find_match(const char *name,
int xtables_check_inverse(const char option[], int *invert,
int *my_optind, int argc);
-void exit_error(enum xtables_exittype, const char *, ...)
- __attribute__((noreturn, format(printf,2,3)));
+extern struct xtables_globals *xt_params;
+#define exit_error xt_params->exit_err
extern void xtables_param_act(unsigned int, const char *, ...);
extern const char *xtables_ipaddr_to_numeric(const struct in_addr *);
#define PROC_SYS_MODPROBE "/proc/sys/kernel/modprobe"
#endif
+void basic_exit_err(enum xtables_exittype status, const char *msg, ...) __attribute__((noreturn, format(printf,2,3)));
+
struct xtables_globals *xt_params = NULL;
-void basic_exit_error(enum xtables_exittype status, const char *msg, ...)
+void basic_exit_err(enum xtables_exittype status, const char *msg, ...)
{
va_list args;
exit(status);
}
+
/**
* xtables_set_params - set the global parameters used by xtables
* @xtp: input xtables_globals structure
xt_params = xtp;
- if (!xt_params->exit_error)
- xt_params->exit_error = basic_exit_error;
+ if (!xt_params->exit_err)
+ xt_params->exit_err = basic_exit_err;
return 0;
}
(portnum = xtables_service_to_port(port, proto)) != (unsigned)-1)
return portnum;
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"invalid port/service `%s' specified", port);
}
memset(vianame, 0, IFNAMSIZ);
if (vialen + 1 > IFNAMSIZ)
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"interface name `%s' must be shorter than IFNAMSIZ"
" (%i)", arg, IFNAMSIZ-1);
name, false);
if (ptr == NULL && tryload == XTF_LOAD_MUST_SUCCEED)
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"Couldn't load match `%s':%s\n",
name, dlerror());
}
ptr = NULL;
}
if(!ptr && (tryload == XTF_LOAD_MUST_SUCCEED)) {
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"Couldn't find match `%s'\n", name);
}
#endif
name, true);
if (ptr == NULL && tryload == XTF_LOAD_MUST_SUCCEED)
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"Couldn't load target `%s':%s\n",
name, dlerror());
}
ptr = NULL;
}
if(!ptr && (tryload == LOAD_MUST_SUCCEED)) {
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"Couldn't find target `%s'\n", name);
}
#endif
b = va_arg(args, unsigned int);
if (!b)
return;
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"%s: \"%s\" option may only be specified once",
p1, p2);
break;
b = va_arg(args, unsigned int);
if (!b)
return;
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"%s: \"%s\" option cannot be inverted", p1, p2);
break;
case XTF_BAD_VALUE:
p2 = va_arg(args, const char *);
p3 = va_arg(args, const char *);
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"%s: Bad value for \"%s\" option: \"%s\"",
p1, p2, p3);
break;
b = va_arg(args, unsigned int);
if (!b)
return;
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"%s: At most one action is possible", p1);
break;
default:
- xt_params->exit_error(status, p1, args);
+ xt_params->exit_err(status, p1, args);
break;
}
if ((addrptmp = host_to_ipaddr(name, naddrs)) != NULL)
return addrptmp;
- xt_params->exit_error(PARAMETER_PROBLEM, "host/network `%s' not found", name);
+ xt_params->exit_err(PARAMETER_PROBLEM, "host/network `%s' not found", name);
}
static struct in_addr *parse_ipmask(const char *mask)
/* dotted_to_addr already returns a network byte order addr */
return addrp;
if (!xtables_strtoui(mask, NULL, &bits, 0, 32))
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"invalid mask `%s' specified", mask);
if (bits != 0) {
maskaddr.s_addr = htonl(0xFFFFFFFF << (32 - bits));
if ((addrp = host_to_ip6addr(name, naddrs)) != NULL)
return addrp;
- xt_params->exit_error(PARAMETER_PROBLEM, "host/network `%s' not found", name);
+ xt_params->exit_err(PARAMETER_PROBLEM, "host/network `%s' not found", name);
}
static struct in6_addr *parse_ip6mask(char *mask)
if ((addrp = xtables_numeric_to_ip6addr(mask)) != NULL)
return addrp;
if (!xtables_strtoui(mask, NULL, &bits, 0, 128))
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"invalid mask `%s' specified", mask);
if (bits != 0) {
char *p = (void *)&maskaddr;
"extrapositioned (`! --option this`).\n");
if (*invert)
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"Multiple `!' flags not allowed");
*invert = true;
if (my_optind != NULL) {
++*my_optind;
if (argc && *my_optind > argc)
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"no argument following `!'");
}
}
}
if (i == ARRAY_SIZE(xtables_chain_protos))
- xt_params->exit_error(PARAMETER_PROBLEM,
+ xt_params->exit_err(PARAMETER_PROBLEM,
"unknown protocol `%s' specified",
s);
}