mirror of
https://github.com/sheumann/hush.git
synced 2025-01-03 00:31:16 +00:00
networking/libiproute/*: code shrink by optimizing numeric conversions
and other misc stuff function old new delta print_tunnel 660 656 -4 format_host 5 - -5 get_unsigned 70 54 -16 get_u32 70 54 -16 do_iplink 1173 1151 -22 get_prefix 417 393 -24 print_rule 800 771 -29 print_addrinfo 1374 1342 -32 print_route 1745 1709 -36 iprule_modify 905 866 -39 iproute_modify 1105 1048 -57 get_integer 70 - -70 parse_args 1684 1440 -244 ------------------------------------------------------------------------------ (add/remove: 0/2 grow/shrink: 0/11 up/down: 0/-594) Total: -594 bytes text data bss dec hex filename 817378 476 7892 825746 c9992 busybox_old 816784 476 7892 825152 c9740 busybox_unstripped
This commit is contained in:
parent
021de3f029
commit
76140a77c9
@ -280,17 +280,16 @@ static int print_addrinfo(const struct sockaddr_nl *who UNUSED_PARAM,
|
|||||||
|
|
||||||
if (rta_tb[IFA_LOCAL]) {
|
if (rta_tb[IFA_LOCAL]) {
|
||||||
fputs(rt_addr_n2a(ifa->ifa_family,
|
fputs(rt_addr_n2a(ifa->ifa_family,
|
||||||
RTA_PAYLOAD(rta_tb[IFA_LOCAL]),
|
|
||||||
RTA_DATA(rta_tb[IFA_LOCAL]),
|
RTA_DATA(rta_tb[IFA_LOCAL]),
|
||||||
abuf, sizeof(abuf)), stdout);
|
abuf, sizeof(abuf)), stdout);
|
||||||
|
|
||||||
if (rta_tb[IFA_ADDRESS] == NULL ||
|
if (rta_tb[IFA_ADDRESS] == NULL
|
||||||
memcmp(RTA_DATA(rta_tb[IFA_ADDRESS]), RTA_DATA(rta_tb[IFA_LOCAL]), 4) == 0) {
|
|| memcmp(RTA_DATA(rta_tb[IFA_ADDRESS]), RTA_DATA(rta_tb[IFA_LOCAL]), 4) == 0
|
||||||
|
) {
|
||||||
printf("/%d ", ifa->ifa_prefixlen);
|
printf("/%d ", ifa->ifa_prefixlen);
|
||||||
} else {
|
} else {
|
||||||
printf(" peer %s/%d ",
|
printf(" peer %s/%d ",
|
||||||
rt_addr_n2a(ifa->ifa_family,
|
rt_addr_n2a(ifa->ifa_family,
|
||||||
RTA_PAYLOAD(rta_tb[IFA_ADDRESS]),
|
|
||||||
RTA_DATA(rta_tb[IFA_ADDRESS]),
|
RTA_DATA(rta_tb[IFA_ADDRESS]),
|
||||||
abuf, sizeof(abuf)),
|
abuf, sizeof(abuf)),
|
||||||
ifa->ifa_prefixlen);
|
ifa->ifa_prefixlen);
|
||||||
@ -300,14 +299,12 @@ static int print_addrinfo(const struct sockaddr_nl *who UNUSED_PARAM,
|
|||||||
if (rta_tb[IFA_BROADCAST]) {
|
if (rta_tb[IFA_BROADCAST]) {
|
||||||
printf("brd %s ",
|
printf("brd %s ",
|
||||||
rt_addr_n2a(ifa->ifa_family,
|
rt_addr_n2a(ifa->ifa_family,
|
||||||
RTA_PAYLOAD(rta_tb[IFA_BROADCAST]),
|
|
||||||
RTA_DATA(rta_tb[IFA_BROADCAST]),
|
RTA_DATA(rta_tb[IFA_BROADCAST]),
|
||||||
abuf, sizeof(abuf)));
|
abuf, sizeof(abuf)));
|
||||||
}
|
}
|
||||||
if (rta_tb[IFA_ANYCAST]) {
|
if (rta_tb[IFA_ANYCAST]) {
|
||||||
printf("any %s ",
|
printf("any %s ",
|
||||||
rt_addr_n2a(ifa->ifa_family,
|
rt_addr_n2a(ifa->ifa_family,
|
||||||
RTA_PAYLOAD(rta_tb[IFA_ANYCAST]),
|
|
||||||
RTA_DATA(rta_tb[IFA_ANYCAST]),
|
RTA_DATA(rta_tb[IFA_ANYCAST]),
|
||||||
abuf, sizeof(abuf)));
|
abuf, sizeof(abuf)));
|
||||||
}
|
}
|
||||||
|
@ -202,8 +202,7 @@ static int do_set(char **argv)
|
|||||||
NEXT_ARG();
|
NEXT_ARG();
|
||||||
if (mtu != -1)
|
if (mtu != -1)
|
||||||
duparg("mtu", *argv);
|
duparg("mtu", *argv);
|
||||||
if (get_integer(&mtu, *argv, 0))
|
mtu = get_unsigned(*argv, "mtu");
|
||||||
invarg(*argv, "mtu");
|
|
||||||
}
|
}
|
||||||
if (key == ARG_multicast) {
|
if (key == ARG_multicast) {
|
||||||
int param;
|
int param;
|
||||||
|
@ -202,7 +202,6 @@ static int print_route(const struct sockaddr_nl *who UNUSED_PARAM,
|
|||||||
if (tb[RTA_DST]) {
|
if (tb[RTA_DST]) {
|
||||||
if (r->rtm_dst_len != host_len) {
|
if (r->rtm_dst_len != host_len) {
|
||||||
printf("%s/%u ", rt_addr_n2a(r->rtm_family,
|
printf("%s/%u ", rt_addr_n2a(r->rtm_family,
|
||||||
RTA_PAYLOAD(tb[RTA_DST]),
|
|
||||||
RTA_DATA(tb[RTA_DST]),
|
RTA_DATA(tb[RTA_DST]),
|
||||||
abuf, sizeof(abuf)),
|
abuf, sizeof(abuf)),
|
||||||
r->rtm_dst_len
|
r->rtm_dst_len
|
||||||
@ -222,7 +221,6 @@ static int print_route(const struct sockaddr_nl *who UNUSED_PARAM,
|
|||||||
if (tb[RTA_SRC]) {
|
if (tb[RTA_SRC]) {
|
||||||
if (r->rtm_src_len != host_len) {
|
if (r->rtm_src_len != host_len) {
|
||||||
printf("from %s/%u ", rt_addr_n2a(r->rtm_family,
|
printf("from %s/%u ", rt_addr_n2a(r->rtm_family,
|
||||||
RTA_PAYLOAD(tb[RTA_SRC]),
|
|
||||||
RTA_DATA(tb[RTA_SRC]),
|
RTA_DATA(tb[RTA_SRC]),
|
||||||
abuf, sizeof(abuf)),
|
abuf, sizeof(abuf)),
|
||||||
r->rtm_src_len
|
r->rtm_src_len
|
||||||
@ -252,7 +250,6 @@ static int print_route(const struct sockaddr_nl *who UNUSED_PARAM,
|
|||||||
and symbolic name will not be useful.
|
and symbolic name will not be useful.
|
||||||
*/
|
*/
|
||||||
printf(" src %s ", rt_addr_n2a(r->rtm_family,
|
printf(" src %s ", rt_addr_n2a(r->rtm_family,
|
||||||
RTA_PAYLOAD(tb[RTA_PREFSRC]),
|
|
||||||
RTA_DATA(tb[RTA_PREFSRC]),
|
RTA_DATA(tb[RTA_PREFSRC]),
|
||||||
abuf, sizeof(abuf)));
|
abuf, sizeof(abuf)));
|
||||||
}
|
}
|
||||||
@ -367,8 +364,7 @@ USE_FEATURE_IP_RULE(ARG_table,)
|
|||||||
mxlock |= (1 << RTAX_MTU);
|
mxlock |= (1 << RTAX_MTU);
|
||||||
NEXT_ARG();
|
NEXT_ARG();
|
||||||
}
|
}
|
||||||
if (get_unsigned(&mtu, *argv, 0))
|
mtu = get_unsigned(*argv, "mtu");
|
||||||
invarg(*argv, "mtu");
|
|
||||||
rta_addattr32(mxrta, sizeof(mxbuf), RTAX_MTU, mtu);
|
rta_addattr32(mxrta, sizeof(mxbuf), RTAX_MTU, mtu);
|
||||||
} else if (arg == ARG_protocol) {
|
} else if (arg == ARG_protocol) {
|
||||||
uint32_t prot;
|
uint32_t prot;
|
||||||
@ -391,8 +387,7 @@ USE_FEATURE_IP_RULE(ARG_table,)
|
|||||||
} else if (arg == ARG_metric) {
|
} else if (arg == ARG_metric) {
|
||||||
uint32_t metric;
|
uint32_t metric;
|
||||||
NEXT_ARG();
|
NEXT_ARG();
|
||||||
if (get_u32(&metric, *argv, 0))
|
metric = get_u32(*argv, "metric");
|
||||||
invarg(*argv, "metric");
|
|
||||||
addattr32(&req.n, sizeof(req), RTA_PRIORITY, metric);
|
addattr32(&req.n, sizeof(req), RTA_PRIORITY, metric);
|
||||||
} else {
|
} else {
|
||||||
int type;
|
int type;
|
||||||
|
@ -78,7 +78,6 @@ static int print_rule(const struct sockaddr_nl *who UNUSED_PARAM,
|
|||||||
if (tb[RTA_SRC]) {
|
if (tb[RTA_SRC]) {
|
||||||
if (r->rtm_src_len != host_len) {
|
if (r->rtm_src_len != host_len) {
|
||||||
printf("%s/%u", rt_addr_n2a(r->rtm_family,
|
printf("%s/%u", rt_addr_n2a(r->rtm_family,
|
||||||
RTA_PAYLOAD(tb[RTA_SRC]),
|
|
||||||
RTA_DATA(tb[RTA_SRC]),
|
RTA_DATA(tb[RTA_SRC]),
|
||||||
abuf, sizeof(abuf)),
|
abuf, sizeof(abuf)),
|
||||||
r->rtm_src_len
|
r->rtm_src_len
|
||||||
@ -99,7 +98,6 @@ static int print_rule(const struct sockaddr_nl *who UNUSED_PARAM,
|
|||||||
if (tb[RTA_DST]) {
|
if (tb[RTA_DST]) {
|
||||||
if (r->rtm_dst_len != host_len) {
|
if (r->rtm_dst_len != host_len) {
|
||||||
printf("to %s/%u ", rt_addr_n2a(r->rtm_family,
|
printf("to %s/%u ", rt_addr_n2a(r->rtm_family,
|
||||||
RTA_PAYLOAD(tb[RTA_DST]),
|
|
||||||
RTA_DATA(tb[RTA_DST]),
|
RTA_DATA(tb[RTA_DST]),
|
||||||
abuf, sizeof(abuf)),
|
abuf, sizeof(abuf)),
|
||||||
r->rtm_dst_len
|
r->rtm_dst_len
|
||||||
@ -238,8 +236,7 @@ static int iprule_modify(int cmd, char **argv)
|
|||||||
key == ARG_priority) {
|
key == ARG_priority) {
|
||||||
uint32_t pref;
|
uint32_t pref;
|
||||||
NEXT_ARG();
|
NEXT_ARG();
|
||||||
if (get_u32(&pref, *argv, 0))
|
pref = get_u32(*argv, "preference");
|
||||||
invarg(*argv, "preference");
|
|
||||||
addattr32(&req.n, sizeof(req), RTA_PRIORITY, pref);
|
addattr32(&req.n, sizeof(req), RTA_PRIORITY, pref);
|
||||||
} else if (key == ARG_tos) {
|
} else if (key == ARG_tos) {
|
||||||
uint32_t tos;
|
uint32_t tos;
|
||||||
@ -250,8 +247,7 @@ static int iprule_modify(int cmd, char **argv)
|
|||||||
} else if (key == ARG_fwmark) {
|
} else if (key == ARG_fwmark) {
|
||||||
uint32_t fwmark;
|
uint32_t fwmark;
|
||||||
NEXT_ARG();
|
NEXT_ARG();
|
||||||
if (get_u32(&fwmark, *argv, 0))
|
fwmark = get_u32(*argv, "fwmark");
|
||||||
invarg(*argv, "fwmark");
|
|
||||||
addattr32(&req.n, sizeof(req), RTA_PROTOINFO, fwmark);
|
addattr32(&req.n, sizeof(req), RTA_PROTOINFO, fwmark);
|
||||||
} else if (key == ARG_realms) {
|
} else if (key == ARG_realms) {
|
||||||
uint32_t realm;
|
uint32_t realm;
|
||||||
|
@ -232,9 +232,7 @@ static void parse_args(char **argv, int cmd, struct ip_tunnel_parm *p)
|
|||||||
if (strchr(*argv, '.'))
|
if (strchr(*argv, '.'))
|
||||||
p->i_key = p->o_key = get_addr32(*argv);
|
p->i_key = p->o_key = get_addr32(*argv);
|
||||||
else {
|
else {
|
||||||
if (get_unsigned(&uval, *argv, 0) < 0) {
|
uval = get_unsigned(*argv, "key");
|
||||||
invarg(*argv, "key");
|
|
||||||
}
|
|
||||||
p->i_key = p->o_key = htonl(uval);
|
p->i_key = p->o_key = htonl(uval);
|
||||||
}
|
}
|
||||||
} else if (key == ARG_ikey) {
|
} else if (key == ARG_ikey) {
|
||||||
@ -244,9 +242,7 @@ static void parse_args(char **argv, int cmd, struct ip_tunnel_parm *p)
|
|||||||
if (strchr(*argv, '.'))
|
if (strchr(*argv, '.'))
|
||||||
p->o_key = get_addr32(*argv);
|
p->o_key = get_addr32(*argv);
|
||||||
else {
|
else {
|
||||||
if (get_unsigned(&uval, *argv, 0) < 0) {
|
uval = get_unsigned(*argv, "ikey");
|
||||||
invarg(*argv, "ikey");
|
|
||||||
}
|
|
||||||
p->i_key = htonl(uval);
|
p->i_key = htonl(uval);
|
||||||
}
|
}
|
||||||
} else if (key == ARG_okey) {
|
} else if (key == ARG_okey) {
|
||||||
@ -256,9 +252,7 @@ static void parse_args(char **argv, int cmd, struct ip_tunnel_parm *p)
|
|||||||
if (strchr(*argv, '.'))
|
if (strchr(*argv, '.'))
|
||||||
p->o_key = get_addr32(*argv);
|
p->o_key = get_addr32(*argv);
|
||||||
else {
|
else {
|
||||||
if (get_unsigned(&uval, *argv, 0) < 0) {
|
uval = get_unsigned(*argv, "okey");
|
||||||
invarg(*argv, "okey");
|
|
||||||
}
|
|
||||||
p->o_key = htonl(uval);
|
p->o_key = htonl(uval);
|
||||||
}
|
}
|
||||||
} else if (key == ARG_seq) {
|
} else if (key == ARG_seq) {
|
||||||
@ -297,8 +291,7 @@ static void parse_args(char **argv, int cmd, struct ip_tunnel_parm *p)
|
|||||||
NEXT_ARG();
|
NEXT_ARG();
|
||||||
key = index_in_strings(keywords, *argv);
|
key = index_in_strings(keywords, *argv);
|
||||||
if (key != ARG_inherit) {
|
if (key != ARG_inherit) {
|
||||||
if (get_unsigned(&uval, *argv, 0))
|
uval = get_unsigned(*argv, "TTL");
|
||||||
invarg(*argv, "TTL");
|
|
||||||
if (uval > 255)
|
if (uval > 255)
|
||||||
invarg(*argv, "TTL must be <=255");
|
invarg(*argv, "TTL must be <=255");
|
||||||
p->iph.ttl = uval;
|
p->iph.ttl = uval;
|
||||||
|
@ -115,13 +115,15 @@ int ll_proto_a2n(unsigned short *id, char *buf)
|
|||||||
unsigned i;
|
unsigned i;
|
||||||
for (i = 0; i < ARRAY_SIZE(llproto_names); i++) {
|
for (i = 0; i < ARRAY_SIZE(llproto_names); i++) {
|
||||||
if (strcasecmp(llproto_names[i].name, buf) == 0) {
|
if (strcasecmp(llproto_names[i].name, buf) == 0) {
|
||||||
*id = htons(llproto_names[i].id);
|
i = llproto_names[i].id;
|
||||||
return 0;
|
goto good;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (get_u16(id, buf, 0))
|
i = bb_strtou(buf, NULL, 0);
|
||||||
|
if (errno || i > 0xffff)
|
||||||
return -1;
|
return -1;
|
||||||
*id = htons(*id);
|
good:
|
||||||
|
*id = htons(i);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,102 +15,46 @@
|
|||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include "inet_common.h"
|
#include "inet_common.h"
|
||||||
|
|
||||||
int get_integer(int *val, char *arg, int base)
|
unsigned get_unsigned(char *arg, const char *errmsg)
|
||||||
{
|
|
||||||
long res;
|
|
||||||
char *ptr;
|
|
||||||
|
|
||||||
if (!arg || !*arg)
|
|
||||||
return -1;
|
|
||||||
res = strtol(arg, &ptr, base);
|
|
||||||
if (!ptr || ptr == arg || *ptr || res > INT_MAX || res < INT_MIN)
|
|
||||||
return -1;
|
|
||||||
*val = res;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
//XXX: FIXME: use some libbb function instead
|
|
||||||
int get_unsigned(unsigned *val, char *arg, int base)
|
|
||||||
{
|
{
|
||||||
unsigned long res;
|
unsigned long res;
|
||||||
char *ptr;
|
char *ptr;
|
||||||
|
|
||||||
if (!arg || !*arg)
|
if (*arg) {
|
||||||
return -1;
|
res = strtoul(arg, &ptr, 0);
|
||||||
res = strtoul(arg, &ptr, base);
|
if (!*ptr && res <= UINT_MAX) {
|
||||||
if (!ptr || ptr == arg || *ptr || res > UINT_MAX)
|
return res;
|
||||||
return -1;
|
}
|
||||||
*val = res;
|
}
|
||||||
return 0;
|
invarg(arg, errmsg); /* does not return */
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_u32(uint32_t *val, char *arg, int base)
|
uint32_t get_u32(char *arg, const char *errmsg)
|
||||||
{
|
{
|
||||||
unsigned long res;
|
unsigned long res;
|
||||||
char *ptr;
|
char *ptr;
|
||||||
|
|
||||||
if (!arg || !*arg)
|
if (*arg) {
|
||||||
return -1;
|
res = strtoul(arg, &ptr, 0);
|
||||||
res = strtoul(arg, &ptr, base);
|
if (!*ptr && res <= 0xFFFFFFFFUL) {
|
||||||
if (!ptr || ptr == arg || *ptr || res > 0xFFFFFFFFUL)
|
return res;
|
||||||
return -1;
|
}
|
||||||
*val = res;
|
}
|
||||||
return 0;
|
invarg(arg, errmsg); /* does not return */
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_u16(uint16_t *val, char *arg, int base)
|
uint16_t get_u16(char *arg, const char *errmsg)
|
||||||
{
|
{
|
||||||
unsigned long res;
|
unsigned long res;
|
||||||
char *ptr;
|
char *ptr;
|
||||||
|
|
||||||
if (!arg || !*arg)
|
if (*arg) {
|
||||||
return -1;
|
res = strtoul(arg, &ptr, 0);
|
||||||
res = strtoul(arg, &ptr, base);
|
if (!*ptr && res <= 0xFFFF) {
|
||||||
if (!ptr || ptr == arg || *ptr || res > 0xFFFF)
|
return res;
|
||||||
return -1;
|
}
|
||||||
*val = res;
|
}
|
||||||
return 0;
|
invarg(arg, errmsg); /* does not return */
|
||||||
}
|
|
||||||
|
|
||||||
int get_u8(uint8_t *val, char *arg, int base)
|
|
||||||
{
|
|
||||||
unsigned long res;
|
|
||||||
char *ptr;
|
|
||||||
|
|
||||||
if (!arg || !*arg)
|
|
||||||
return -1;
|
|
||||||
res = strtoul(arg, &ptr, base);
|
|
||||||
if (!ptr || ptr == arg || *ptr || res > 0xFF)
|
|
||||||
return -1;
|
|
||||||
*val = res;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int get_s16(int16_t *val, char *arg, int base)
|
|
||||||
{
|
|
||||||
long res;
|
|
||||||
char *ptr;
|
|
||||||
|
|
||||||
if (!arg || !*arg)
|
|
||||||
return -1;
|
|
||||||
res = strtol(arg, &ptr, base);
|
|
||||||
if (!ptr || ptr == arg || *ptr || res > 0x7FFF || res < -0x8000)
|
|
||||||
return -1;
|
|
||||||
*val = res;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int get_s8(int8_t *val, char *arg, int base)
|
|
||||||
{
|
|
||||||
long res;
|
|
||||||
char *ptr;
|
|
||||||
|
|
||||||
if (!arg || !*arg)
|
|
||||||
return -1;
|
|
||||||
res = strtol(arg, &ptr, base);
|
|
||||||
if (!ptr || ptr == arg || *ptr || res > 0x7F || res < -0x80)
|
|
||||||
return -1;
|
|
||||||
*val = res;
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_addr_1(inet_prefix *addr, char *name, int family)
|
int get_addr_1(inet_prefix *addr, char *name, int family)
|
||||||
@ -161,8 +105,8 @@ static int get_prefix_1(inet_prefix *dst, char *arg, int family)
|
|||||||
|| strcmp(arg, "any") == 0
|
|| strcmp(arg, "any") == 0
|
||||||
) {
|
) {
|
||||||
dst->family = family;
|
dst->family = family;
|
||||||
dst->bytelen = 0;
|
/*dst->bytelen = 0; - done by memset */
|
||||||
dst->bitlen = 0;
|
/*dst->bitlen = 0;*/
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -176,7 +120,8 @@ static int get_prefix_1(inet_prefix *dst, char *arg, int family)
|
|||||||
inet_prefix netmask_pfx;
|
inet_prefix netmask_pfx;
|
||||||
|
|
||||||
netmask_pfx.family = AF_UNSPEC;
|
netmask_pfx.family = AF_UNSPEC;
|
||||||
if ((get_unsigned(&plen, slash + 1, 0) || plen > dst->bitlen)
|
plen = bb_strtou(slash + 1, NULL, 0);
|
||||||
|
if ((errno || plen > dst->bitlen)
|
||||||
&& (get_addr_1(&netmask_pfx, slash + 1, family)))
|
&& (get_addr_1(&netmask_pfx, slash + 1, family)))
|
||||||
err = -1;
|
err = -1;
|
||||||
else if (netmask_pfx.family == AF_INET) {
|
else if (netmask_pfx.family == AF_INET) {
|
||||||
@ -262,7 +207,7 @@ int inet_addr_match(inet_prefix *a, inet_prefix *b, int bits)
|
|||||||
{
|
{
|
||||||
uint32_t *a1 = a->data;
|
uint32_t *a1 = a->data;
|
||||||
uint32_t *a2 = b->data;
|
uint32_t *a2 = b->data;
|
||||||
int words = bits >> 0x05;
|
int words = bits >> 5;
|
||||||
|
|
||||||
bits &= 0x1f;
|
bits &= 0x1f;
|
||||||
|
|
||||||
@ -286,7 +231,7 @@ int inet_addr_match(inet_prefix *a, inet_prefix *b, int bits)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *rt_addr_n2a(int af, int UNUSED_PARAM len,
|
const char *rt_addr_n2a(int af,
|
||||||
void *addr, char *buf, int buflen)
|
void *addr, char *buf, int buflen)
|
||||||
{
|
{
|
||||||
switch (af) {
|
switch (af) {
|
||||||
@ -298,9 +243,9 @@ const char *rt_addr_n2a(int af, int UNUSED_PARAM len,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef RESOLVE_HOSTNAMES
|
||||||
const char *format_host(int af, int len, void *addr, char *buf, int buflen)
|
const char *format_host(int af, int len, void *addr, char *buf, int buflen)
|
||||||
{
|
{
|
||||||
#ifdef RESOLVE_HOSTNAMES
|
|
||||||
if (resolve_hosts) {
|
if (resolve_hosts) {
|
||||||
struct hostent *h_ent;
|
struct hostent *h_ent;
|
||||||
|
|
||||||
@ -323,6 +268,6 @@ const char *format_host(int af, int len, void *addr, char *buf, int buflen)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
return rt_addr_n2a(af, addr, buf, buflen);
|
||||||
return rt_addr_n2a(af, len, addr, buf, buflen);
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
@ -64,19 +64,17 @@ extern int get_addr_1(inet_prefix *dst, char *arg, int family);
|
|||||||
extern int get_addr(inet_prefix *dst, char *arg, int family);
|
extern int get_addr(inet_prefix *dst, char *arg, int family);
|
||||||
extern int get_prefix(inet_prefix *dst, char *arg, int family);
|
extern int get_prefix(inet_prefix *dst, char *arg, int family);
|
||||||
|
|
||||||
extern int get_integer(int *val, char *arg, int base);
|
extern unsigned get_unsigned(char *arg, const char *errmsg);
|
||||||
extern int get_unsigned(unsigned *val, char *arg, int base);
|
extern uint32_t get_u32(char *arg, const char *errmsg);
|
||||||
#define get_byte get_u8
|
extern uint16_t get_u16(char *arg, const char *errmsg);
|
||||||
#define get_ushort get_u16
|
|
||||||
#define get_short get_s16
|
|
||||||
extern int get_u32(uint32_t *val, char *arg, int base);
|
|
||||||
extern int get_u16(uint16_t *val, char *arg, int base);
|
|
||||||
extern int get_s16(int16_t *val, char *arg, int base);
|
|
||||||
extern int get_u8(uint8_t *val, char *arg, int base);
|
|
||||||
extern int get_s8(int8_t *val, char *arg, int base);
|
|
||||||
|
|
||||||
|
extern const char *rt_addr_n2a(int af, void *addr, char *buf, int buflen);
|
||||||
|
#ifdef RESOLVE_HOSTNAMES
|
||||||
extern const char *format_host(int af, int len, void *addr, char *buf, int buflen);
|
extern const char *format_host(int af, int len, void *addr, char *buf, int buflen);
|
||||||
extern const char *rt_addr_n2a(int af, int len, void *addr, char *buf, int buflen);
|
#else
|
||||||
|
#define format_host(af, len, addr, buf, buflen) \
|
||||||
|
rt_addr_n2a(af, addr, buf, buflen)
|
||||||
|
#endif
|
||||||
|
|
||||||
void invarg(const char *, const char *) NORETURN;
|
void invarg(const char *, const char *) NORETURN;
|
||||||
void duparg(const char *, const char *) NORETURN;
|
void duparg(const char *, const char *) NORETURN;
|
||||||
|
@ -508,15 +508,13 @@ int tc_main(int argc UNUSED_PARAM, char **argv)
|
|||||||
if ((slash = strchr(handle, '/')) != NULL)
|
if ((slash = strchr(handle, '/')) != NULL)
|
||||||
*slash = '\0';
|
*slash = '\0';
|
||||||
*/
|
*/
|
||||||
if (get_u32(&msg.tcm_handle, *argv, 0))
|
msg.tcm_handle = get_u32(*argv, "handle");
|
||||||
invarg(*argv, "handle");
|
/* if (slash) {if (get_u32(__u32 &mask, slash+1, NULL)) inv mask; addattr32(n, MAX_MSG, TCA_FW_MASK, mask); */
|
||||||
/* if (slash) {if (get_u32(__u32 &mask, slash+1,0)) inv mask;addattr32(n, MAX_MSG, TCA_FW_MASK, mask); */
|
|
||||||
} else if (arg == ARG_classid && obj == OBJ_class && cmd == CMD_change){
|
} else if (arg == ARG_classid && obj == OBJ_class && cmd == CMD_change){
|
||||||
} else if (arg == ARG_pref || arg == ARG_prio) { /* filter::list */
|
} else if (arg == ARG_pref || arg == ARG_prio) { /* filter::list */
|
||||||
if (filter_prio)
|
if (filter_prio)
|
||||||
duparg(*argv, "priority");
|
duparg(*argv, "priority");
|
||||||
if (get_u32(&filter_prio, *argv, 0))
|
filter_prio = get_u32(*argv, "priority");
|
||||||
invarg(*argv, "priority");
|
|
||||||
} else if (arg == ARG_proto) { /* filter::list */
|
} else if (arg == ARG_proto) { /* filter::list */
|
||||||
__u16 tmp;
|
__u16 tmp;
|
||||||
if (filter_proto)
|
if (filter_proto)
|
||||||
|
Loading…
Reference in New Issue
Block a user