version 1.1.1.2, 2013/07/22 08:44:29
|
version 1.1.1.5.2.1, 2023/09/27 11:08:00
|
Line 19
|
Line 19
|
#include "netgraph.h" |
#include "netgraph.h" |
#include "util.h" |
#include "util.h" |
|
|
|
#include <sys/limits.h> |
#include <sys/types.h> |
#include <sys/types.h> |
#include <sys/sockio.h> |
#include <sys/sockio.h> |
#include <sys/sysctl.h> |
#include <sys/sysctl.h> |
Line 63
|
Line 64
|
|
|
#include <string.h> |
#include <string.h> |
|
|
|
#ifdef SIOCSIFDESCR |
|
#include <time.h> |
|
#endif |
|
|
/* |
/* |
* DEFINITIONS |
* DEFINITIONS |
*/ |
*/ |
Line 98
|
Line 103
|
static void IfaceNgIpv6Shutdown(Bund b); |
static void IfaceNgIpv6Shutdown(Bund b); |
|
|
#ifdef USE_NG_NETFLOW |
#ifdef USE_NG_NETFLOW |
static int IfaceInitNetflow(Bund b, char *path, char *hook, char in, char out, int v6); | static int IfaceInitNetflow(Bund b, char *path, char *hook, char out, int v6); |
static int IfaceSetupNetflow(Bund b, char in, char out); | static int IfaceSetupNetflow(Bund b, char in, char out, int v6); |
static void IfaceShutdownNetflow(Bund b, char in, char out); | static void IfaceShutdownNetflow(Bund b, char out, int v6); |
#endif |
#endif |
|
|
#ifdef USE_NG_IPACCT |
#ifdef USE_NG_IPACCT |
Line 129
|
Line 134
|
static void IfaceShutdownLimits(Bund b); |
static void IfaceShutdownLimits(Bund b); |
#endif |
#endif |
|
|
static int IfaceSetCommand(Context ctx, int ac, char *av[], void *arg); | static int IfaceSetCommand(Context ctx, int ac, const char *const av[], const void *arg); |
static void IfaceSessionTimeout(void *arg); |
static void IfaceSessionTimeout(void *arg); |
static void IfaceIdleTimeout(void *arg); |
static void IfaceIdleTimeout(void *arg); |
|
|
Line 140
|
Line 145
|
#ifdef USE_IPFW |
#ifdef USE_IPFW |
static int IfaceAllocACL (struct acl_pool ***ap, int start, char * ifname, int number); |
static int IfaceAllocACL (struct acl_pool ***ap, int start, char * ifname, int number); |
static int IfaceFindACL (struct acl_pool *ap, char * ifname, int number); |
static int IfaceFindACL (struct acl_pool *ap, char * ifname, int number); |
static char * IFaceParseACL (char * src, char * ifname); | static char * IfaceParseACL (char * src, IfaceState iface); |
| static char * IfaceFixAclForDelete(char *r, char *buf, size_t len); |
#endif |
#endif |
|
|
static int IfaceSetName(Bund b, const char * ifname); |
static int IfaceSetName(Bund b, const char * ifname); |
Line 161
|
Line 167
|
IfaceSetCommand, NULL, 2, (void *) SET_ADDRS }, |
IfaceSetCommand, NULL, 2, (void *) SET_ADDRS }, |
{ "route {dest}[/{width}]", "Add IP route", |
{ "route {dest}[/{width}]", "Add IP route", |
IfaceSetCommand, NULL, 2, (void *) SET_ROUTE }, |
IfaceSetCommand, NULL, 2, (void *) SET_ROUTE }, |
{ "mtu {size}", "Set max allowed interface MTU", | { "mtu {size} [override]", "Set max allowed or override interface MTU", |
IfaceSetCommand, NULL, 2, (void *) SET_MTU }, |
IfaceSetCommand, NULL, 2, (void *) SET_MTU }, |
{ "name [{name}]", "Set interface name", |
{ "name [{name}]", "Set interface name", |
IfaceSetCommand, NULL, 2, (void *) SET_NAME }, |
IfaceSetCommand, NULL, 2, (void *) SET_NAME }, |
Line 187
|
Line 193
|
IfaceSetCommand, NULL, 2, (void *) SET_ENABLE }, |
IfaceSetCommand, NULL, 2, (void *) SET_ENABLE }, |
{ "disable [opt ...]", "Disable option", |
{ "disable [opt ...]", "Disable option", |
IfaceSetCommand, NULL, 2, (void *) SET_DISABLE }, |
IfaceSetCommand, NULL, 2, (void *) SET_DISABLE }, |
{ NULL }, | { NULL, NULL, NULL, NULL, 0, NULL }, |
}; |
}; |
|
|
/* |
/* |
Line 197
|
Line 203
|
static const struct confinfo gConfList[] = { |
static const struct confinfo gConfList[] = { |
{ 0, IFACE_CONF_ONDEMAND, "on-demand" }, |
{ 0, IFACE_CONF_ONDEMAND, "on-demand" }, |
{ 0, IFACE_CONF_PROXY, "proxy-arp" }, |
{ 0, IFACE_CONF_PROXY, "proxy-arp" }, |
|
{ 0, IFACE_CONF_KEEP_TIMEOUT, "keep-timeout" }, |
#ifdef USE_NG_TCPMSS |
#ifdef USE_NG_TCPMSS |
{ 0, IFACE_CONF_TCPMSSFIX, "tcpmssfix" }, |
{ 0, IFACE_CONF_TCPMSSFIX, "tcpmssfix" }, |
#endif |
#endif |
Line 230
|
Line 237
|
|
|
#ifdef USE_NG_BPF |
#ifdef USE_NG_BPF |
/* A BPF filter that matches TCP SYN packets */ |
/* A BPF filter that matches TCP SYN packets */ |
static const struct bpf_insn gTCPSYNProg[] = { | static const struct bpf_insn gTCPSYNProg[] __attribute__((used)) = { |
/*00*/ BPF_STMT(BPF_LD+BPF_B+BPF_ABS, 9), /* A <- IP protocol */ |
/*00*/ BPF_STMT(BPF_LD+BPF_B+BPF_ABS, 9), /* A <- IP protocol */ |
/*01*/ BPF_JUMP(BPF_JMP+BPF_JEQ+BPF_K, IPPROTO_TCP, 0, 6), /* !TCP => 8 */ |
/*01*/ BPF_JUMP(BPF_JMP+BPF_JEQ+BPF_K, IPPROTO_TCP, 0, 6), /* !TCP => 8 */ |
/*02*/ BPF_STMT(BPF_LD+BPF_H+BPF_ABS, 6), /* A <- fragmentation offset */ |
/*02*/ BPF_STMT(BPF_LD+BPF_H+BPF_ABS, 6), /* A <- fragmentation offset */ |
Line 287 IfaceInit(Bund b)
|
Line 294 IfaceInit(Bund b)
|
/* Default configuration */ |
/* Default configuration */ |
iface->mtu = NG_IFACE_MTU_DEFAULT; |
iface->mtu = NG_IFACE_MTU_DEFAULT; |
iface->max_mtu = NG_IFACE_MTU_DEFAULT; |
iface->max_mtu = NG_IFACE_MTU_DEFAULT; |
|
iface->mtu_override = 0; |
#ifdef SIOCSIFDESCR |
#ifdef SIOCSIFDESCR |
iface->ifdescr = NULL; |
iface->ifdescr = NULL; |
iface->conf.ifdescr = NULL; |
iface->conf.ifdescr = NULL; |
#endif |
#endif |
Disable(&iface->options, IFACE_CONF_ONDEMAND); |
Disable(&iface->options, IFACE_CONF_ONDEMAND); |
Disable(&iface->options, IFACE_CONF_PROXY); |
Disable(&iface->options, IFACE_CONF_PROXY); |
|
Disable(&iface->options, IFACE_CONF_KEEP_TIMEOUT); |
Disable(&iface->options, IFACE_CONF_TCPMSSFIX); |
Disable(&iface->options, IFACE_CONF_TCPMSSFIX); |
#ifdef USE_NG_NAT |
#ifdef USE_NG_NAT |
NatInit(b); |
NatInit(b); |
Line 453 IfaceUp(Bund b, int ready)
|
Line 462 IfaceUp(Bund b, int ready)
|
|
|
/* Start Session timer */ |
/* Start Session timer */ |
if (b->params.session_timeout > 0) { |
if (b->params.session_timeout > 0) { |
session_timeout = b->params.session_timeout; | if (Enabled(&iface->options, IFACE_CONF_KEEP_TIMEOUT)) { |
| session_timeout = b->params.session_timeout - \ |
| (iface->last_up - b->last_up); |
| Log(LG_IFACE2, ("[%s] IFACE: keep session-timeout at: %d seconds", |
| b->name, session_timeout)); |
| } else { |
| session_timeout = b->params.session_timeout; |
| } |
} else if (iface->session_timeout > 0) { |
} else if (iface->session_timeout > 0) { |
session_timeout = iface->session_timeout; |
session_timeout = iface->session_timeout; |
} |
} |
Line 464 IfaceUp(Bund b, int ready)
|
Line 480 IfaceUp(Bund b, int ready)
|
if (session_timeout > INT_MAX / 1100) { |
if (session_timeout > INT_MAX / 1100) { |
session_timeout = INT_MAX / 1100; |
session_timeout = INT_MAX / 1100; |
Log(LG_ERR, ("[%s] IFACE: session-timeout limited to %d seconds", |
Log(LG_ERR, ("[%s] IFACE: session-timeout limited to %d seconds", |
b->name, session_timeout)); | b->name, session_timeout)); |
} |
} |
TimerInit(&iface->sessionTimer, "IfaceSession", |
TimerInit(&iface->sessionTimer, "IfaceSession", |
session_timeout * SECONDS, IfaceSessionTimeout, b); |
session_timeout * SECONDS, IfaceSessionTimeout, b); |
Line 584 IfaceUp(Bund b, int ready)
|
Line 600 IfaceUp(Bund b, int ready)
|
} |
} |
acls = b->params.acl_queue; |
acls = b->params.acl_queue; |
while (acls != NULL) { |
while (acls != NULL) { |
buf = IFaceParseACL(acls->rule,iface->ifname); | buf = IfaceParseACL(acls->rule, iface); |
ExecCmd(LG_IFACE2, b->name, "%s queue %d config %s", PATH_IPFW, acls->real_number, buf); |
ExecCmd(LG_IFACE2, b->name, "%s queue %d config %s", PATH_IPFW, acls->real_number, buf); |
Freee(buf); |
Freee(buf); |
acls = acls->next; |
acls = acls->next; |
} |
} |
acls = b->params.acl_table; |
acls = b->params.acl_table; |
while (acls != NULL) { |
while (acls != NULL) { |
acl = Mdup(MB_IPFW, acls, sizeof(struct acl) + strlen(acls->rule)); | /* allow both %aX and `peer_addr` macros */ |
| buf = IfaceParseACL(acls->rule, iface); |
| acl = Mdup2(MB_IPFW, acls, sizeof(struct acl), sizeof(struct acl) + strlen(buf)); |
| strcpy(acl->rule, buf); |
| Freee(buf); |
acl->next = iface->tables; |
acl->next = iface->tables; |
iface->tables = acl; |
iface->tables = acl; |
ExecCmd(LG_IFACE2, b->name, "%s table %d add %s", PATH_IPFW, acls->real_number, acls->rule); | if (strncmp(acl->rule, "peer_addr", 9) == 0) { |
| char hisaddr[20]; |
| ExecCmd(LG_IFACE2, b->name, "%s -q table %d add %s", |
| PATH_IPFW, acl->real_number, |
| u_addrtoa(&iface->peer_addr, hisaddr, sizeof(hisaddr))); |
| } else { |
| ExecCmd(LG_IFACE2, b->name, "%s -q table %d add %s", PATH_IPFW, acl->real_number, acl->rule); |
| } |
acls = acls->next; |
acls = acls->next; |
}; |
}; |
acls = b->params.acl_rule; |
acls = b->params.acl_rule; |
while (acls != NULL) { |
while (acls != NULL) { |
buf = IFaceParseACL(acls->rule, iface->ifname); | buf = IfaceParseACL(acls->rule, iface); |
ExecCmd(LG_IFACE2, b->name, "%s add %d %s via %s", PATH_IPFW, acls->real_number, buf, iface->ifname); |
ExecCmd(LG_IFACE2, b->name, "%s add %d %s via %s", PATH_IPFW, acls->real_number, buf, iface->ifname); |
Freee(buf); |
Freee(buf); |
acls = acls->next; |
acls = acls->next; |
Line 628 IfaceDown(Bund b)
|
Line 655 IfaceDown(Bund b)
|
IfaceState const iface = &b->iface; |
IfaceState const iface = &b->iface; |
#ifdef USE_IPFW |
#ifdef USE_IPFW |
struct acl_pool **rp, *rp1; |
struct acl_pool **rp, *rp1; |
char cb[32768]; | char cb[LINE_MAX - sizeof(PATH_IPFW) - 14]; |
struct acl *acl, *aclnext; |
struct acl *acl, *aclnext; |
#endif |
#endif |
|
|
Line 671 IfaceDown(Bund b)
|
Line 698 IfaceDown(Bund b)
|
}; |
}; |
acl = iface->tables; |
acl = iface->tables; |
while (acl != NULL) { |
while (acl != NULL) { |
ExecCmd(LG_IFACE2, b->name, "%s table %d delete %s", | if (strncmp(acl->rule, "peer_addr", 9) == 0) { |
PATH_IPFW, acl->real_number, acl->rule); | char hisaddr[20]; |
| ExecCmd(LG_IFACE2, b->name, "%s -q table %d delete %s", |
| PATH_IPFW, acl->real_number, |
| u_addrtoa(&iface->peer_addr, hisaddr, sizeof(hisaddr))); |
| } else { |
| char buf[ACL_LEN]; |
| ExecCmd(LG_IFACE2, b->name, "%s -q table %d delete %s", |
| PATH_IPFW, acl->real_number, |
| IfaceFixAclForDelete(acl->rule, buf, sizeof(buf))); |
| } |
aclnext = acl->next; |
aclnext = acl->next; |
Freee(acl); |
Freee(acl); |
acl = aclnext; |
acl = aclnext; |
Line 840 IfaceFindACL (struct acl_pool *ap, char * ifname, int
|
Line 876 IfaceFindACL (struct acl_pool *ap, char * ifname, int
|
} |
} |
|
|
/* |
/* |
* IFaceParseACL () | * IfaceParseACL () |
* |
* |
* Parces ACL and replaces %r, %p and %q macroses | * Parses ACL and replaces %r, %p and %q macroses |
* by the real numbers of rules, queues and pipes. |
* by the real numbers of rules, queues and pipes. |
|
* |
|
* Also replaces %a1 and a2 with the remote(peer) |
|
* or local(self) IP address respectively. |
*/ |
*/ |
|
|
static char * |
static char * |
IFaceParseACL (char * src, char * ifname) | IfaceParseACL (char * src, IfaceState iface) |
{ |
{ |
char *buf,*buf1; |
char *buf,*buf1; |
char *begin,*param,*end; |
char *begin,*param,*end; |
char t; |
char t; |
int num,real_number; |
int num,real_number; |
struct acl_pool *ap; |
struct acl_pool *ap; |
|
char hisaddr[20]; |
|
int ipmode = 0; /* 0 - normal macro, 1 - IP address macro */ |
|
|
buf = Malloc(MB_IPFW, ACL_LEN); |
buf = Malloc(MB_IPFW, ACL_LEN); |
buf1 = Malloc(MB_IPFW, ACL_LEN); |
buf1 = Malloc(MB_IPFW, ACL_LEN); |
Line 878 IFaceParseACL (char * src, char * ifname)
|
Line 919 IFaceParseACL (char * src, char * ifname)
|
case 't': |
case 't': |
ap = table_pool; |
ap = table_pool; |
break; |
break; |
|
case 'a': |
|
ipmode = 1; |
|
if (num == 1) |
|
u_addrtoa(&iface->peer_addr, hisaddr, sizeof(hisaddr)); |
|
else if (num == 2) |
|
u_rangetoa(&iface->self_addr, hisaddr, sizeof(hisaddr)); |
|
else |
|
ipmode = 0; |
|
ap = NULL; |
|
break; |
default: |
default: |
ap = NULL; |
ap = NULL; |
}; |
}; |
real_number = IfaceFindACL(ap,ifname,num); | if (ipmode) |
if (end != NULL) { | { |
snprintf(buf1, ACL_LEN, "%s%d %s", begin, real_number, end); | if (end != NULL) |
} else { | snprintf(buf1, ACL_LEN, "%s%s %s", begin, hisaddr, end); |
snprintf(buf1, ACL_LEN, "%s%d", begin, real_number); | else |
}; | snprintf(buf1, ACL_LEN, "%s%s", begin, hisaddr); |
| ipmode = 0; |
| } |
| else |
| { |
| real_number = IfaceFindACL(ap, iface->ifname, num); |
| if (end != NULL) |
| snprintf(buf1, ACL_LEN, "%s%d %s", begin, real_number, end); |
| else |
| snprintf(buf1, ACL_LEN, "%s%d", begin, real_number); |
| } |
strlcpy(buf, buf1, ACL_LEN); |
strlcpy(buf, buf1, ACL_LEN); |
}; |
}; |
}; |
}; |
Line 894 IFaceParseACL (char * src, char * ifname)
|
Line 955 IFaceParseACL (char * src, char * ifname)
|
Freee(buf1); |
Freee(buf1); |
return(buf); |
return(buf); |
} |
} |
|
|
|
/* |
|
* IfaceFixAclForDelete() |
|
* |
|
* Removes values from ipfw 'table-key value [...]' expression r, if any. |
|
* Returns buf pointer for modified expression or original r pointer |
|
* if no modifications were performed when no values were found or |
|
* buf found too short. |
|
* |
|
* len is size of buf. Strings are zero-terminated. |
|
* r and buf must point to non-overlapping memory areas. |
|
*/ |
|
|
|
static char* |
|
IfaceFixAclForDelete(char *r, char *buf, size_t len) |
|
{ |
|
static const char sep[] = " \t"; |
|
char *limit, *orig, *s; |
|
int i, state = 0; |
|
|
|
/* |
|
* Possible state values: |
|
* |
|
* -1: skip value (otherwise copy); |
|
* 0: first iteration, do copy; |
|
* 1: not first iteration, do copy. |
|
*/ |
|
|
|
orig = r; |
|
s = buf; |
|
limit = buf + len; |
|
|
|
for (r += strspn(r, sep); /* Skip leading spaces. */ |
|
*r; /* Check for end of string. */ |
|
r += i, r += strspn(r, sep)) /* Advance and skip spaces again. */ |
|
{ |
|
i = strcspn(r, sep); /* Find separator or end of string. */ |
|
if (state == 0 && r[i] == '\0') /* No separators in the rule? */ |
|
return r; |
|
if (state < 0) { /* Skip value. */ |
|
state = 1; |
|
continue; |
|
} |
|
if (limit - s < i + 1 + state) /* Check space. */ |
|
return orig; |
|
if (state != 0) /* Insert separator. */ |
|
*s++ = ' '; |
|
memcpy(s, r, i); /* Copy IP address from the rule. */ |
|
s += i; |
|
state = -1; |
|
} |
|
*s = '\0'; |
|
|
|
return buf; |
|
} |
#endif /* USE_IPFW */ |
#endif /* USE_IPFW */ |
|
|
/* |
/* |
Line 940 IfaceIpIfaceUp(Bund b, int ready)
|
Line 1056 IfaceIpIfaceUp(Bund b, int ready)
|
/* Proxy ARP for peer if desired and peer's address is known */ |
/* Proxy ARP for peer if desired and peer's address is known */ |
u_addrclear(&iface->proxy_addr); |
u_addrclear(&iface->proxy_addr); |
if (Enabled(&iface->options, IFACE_CONF_PROXY)) { |
if (Enabled(&iface->options, IFACE_CONF_PROXY)) { |
|
u_addrtoa(&iface->peer_addr,hisaddr,sizeof(hisaddr)); |
if (u_addrempty(&iface->peer_addr)) { |
if (u_addrempty(&iface->peer_addr)) { |
Log(LG_IFACE, | Log(LG_IFACE, ("[%s] IFACE: Can't proxy arp for %s", |
("[%s] IFACE: Can't proxy arp for %s", | b->name, hisaddr)); |
b->name, u_addrtoa(&iface->peer_addr,hisaddr,sizeof(hisaddr)))); | |
} else if (GetEther(&iface->peer_addr, &hwa) < 0) { |
} else if (GetEther(&iface->peer_addr, &hwa) < 0) { |
Log(LG_IFACE, | Log(LG_IFACE, ("[%s] IFACE: No interface to proxy arp on for %s", |
("[%s] IFACE: No interface to proxy arp on for %s", | b->name, hisaddr)); |
b->name, u_addrtoa(&iface->peer_addr,hisaddr,sizeof(hisaddr)))); | |
} else { |
} else { |
ether = (u_char *) LLADDR(&hwa); |
ether = (u_char *) LLADDR(&hwa); |
if (ExecCmdNosh(LG_IFACE2, b->name, |
if (ExecCmdNosh(LG_IFACE2, b->name, |
"%s -S %s %x:%x:%x:%x:%x:%x pub", |
"%s -S %s %x:%x:%x:%x:%x:%x pub", |
PATH_ARP, u_addrtoa(&iface->peer_addr,hisaddr,sizeof(hisaddr)), | PATH_ARP, hisaddr, |
ether[0], ether[1], ether[2], |
ether[0], ether[1], ether[2], |
ether[3], ether[4], ether[5]) == 0) |
ether[3], ether[4], ether[5]) == 0) |
iface->proxy_addr = iface->peer_addr; | iface->proxy_addr = iface->peer_addr; |
} |
} |
} |
} |
|
|
Line 993 IfaceIpIfaceUp(Bund b, int ready)
|
Line 1108 IfaceIpIfaceUp(Bund b, int ready)
|
else |
else |
ns2buf[0] = '\0'; |
ns2buf[0] = '\0'; |
|
|
res = ExecCmd(LG_IFACE2, b->name, "%s %s inet %s %s '%s' '%s' '%s' '%s'", | res = ExecCmd(LG_IFACE2, b->name, "%s %s inet %s %s '%s' '%s' '%s' '%s' '%s'", |
iface->up_script, iface->ifname, u_rangetoa(&iface->self_addr,selfbuf, sizeof(selfbuf)), | iface->up_script, iface->ifname, |
| u_rangetoa(&iface->self_addr,selfbuf, sizeof(selfbuf)), |
u_addrtoa(&iface->peer_addr, peerbuf, sizeof(peerbuf)), |
u_addrtoa(&iface->peer_addr, peerbuf, sizeof(peerbuf)), |
*b->params.authname ? b->params.authname : "-", |
*b->params.authname ? b->params.authname : "-", |
ns1buf, ns2buf, *b->params.peeraddr ? b->params.peeraddr : "-"); | ns1buf, ns2buf, *b->params.peeraddr ? b->params.peeraddr : "-", |
| #ifdef USE_RADIUS |
| b->params.filter_id ? b->params.filter_id : |
| #endif |
| "-"); |
if (res != 0) { |
if (res != 0) { |
FsmFailure(&b->ipcp.fsm, FAIL_NEGOT_FAILURE); |
FsmFailure(&b->ipcp.fsm, FAIL_NEGOT_FAILURE); |
return (-1); |
return (-1); |
Line 1023 IfaceIpIfaceDown(Bund b)
|
Line 1143 IfaceIpIfaceDown(Bund b)
|
if (*iface->down_script) { |
if (*iface->down_script) { |
char selfbuf[40],peerbuf[40]; |
char selfbuf[40],peerbuf[40]; |
|
|
ExecCmd(LG_IFACE2, b->name, "%s %s inet %s %s '%s' '%s'", | ExecCmd(LG_IFACE2, b->name, "%s %s inet %s %s '%s' '%s' '%s'", |
iface->down_script, iface->ifname, u_rangetoa(&iface->self_addr,selfbuf, sizeof(selfbuf)), | iface->down_script, iface->ifname, |
| u_rangetoa(&iface->self_addr,selfbuf, sizeof(selfbuf)), |
u_addrtoa(&iface->peer_addr, peerbuf, sizeof(peerbuf)), |
u_addrtoa(&iface->peer_addr, peerbuf, sizeof(peerbuf)), |
*b->params.authname ? b->params.authname : "-", |
*b->params.authname ? b->params.authname : "-", |
*b->params.peeraddr ? b->params.peeraddr : "-"); | *b->params.peeraddr ? b->params.peeraddr : "-", |
| #ifdef USE_RADIUS |
| b->params.filter_id ? b->params.filter_id : |
| #endif |
| "-"); |
} |
} |
|
|
/* Delete dynamic routes */ |
/* Delete dynamic routes */ |
Line 1080 IfaceIpv6IfaceUp(Bund b, int ready)
|
Line 1205 IfaceIpv6IfaceUp(Bund b, int ready)
|
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[1] = 0x0000; |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[1] = 0x0000; |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[2] = 0x0000; |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[2] = 0x0000; |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[3] = 0x0000; |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[3] = 0x0000; |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[4] = ((u_short*)b->ipv6cp.myintid)[0]; | bcopy(b->ipv6cp.myintid, &iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[4], sizeof(b->ipv6cp.myintid)); |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[5] = ((u_short*)b->ipv6cp.myintid)[1]; | bcopy(&iface->self_ipv6_addr.u.ip6, &b->ipv6cp.want_addr, sizeof(struct in6_addr)); |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[6] = ((u_short*)b->ipv6cp.myintid)[2]; | |
iface->self_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[7] = ((u_short*)b->ipv6cp.myintid)[3]; | |
} else { |
} else { |
u_addrcopy(&iface->conf.self_ipv6_addr, &iface->self_ipv6_addr); |
u_addrcopy(&iface->conf.self_ipv6_addr, &iface->self_ipv6_addr); |
} |
} |
Line 1093 IfaceIpv6IfaceUp(Bund b, int ready)
|
Line 1216 IfaceIpv6IfaceUp(Bund b, int ready)
|
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[1] = 0x0000; |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[1] = 0x0000; |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[2] = 0x0000; |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[2] = 0x0000; |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[3] = 0x0000; |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[3] = 0x0000; |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[4] = ((u_short*)b->ipv6cp.hisintid)[0]; | bcopy(b->ipv6cp.hisintid, &iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[4], sizeof(b->ipv6cp.hisintid)); |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[5] = ((u_short*)b->ipv6cp.hisintid)[1]; | bcopy(&iface->peer_ipv6_addr.u.ip6, &b->ipv6cp.peer_addr, sizeof(struct in6_addr)); |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[6] = ((u_short*)b->ipv6cp.hisintid)[2]; | |
iface->peer_ipv6_addr.u.ip6.__u6_addr.__u6_addr16[7] = ((u_short*)b->ipv6cp.hisintid)[3]; | |
} else { |
} else { |
u_addrcopy(&iface->conf.peer_ipv6_addr, &iface->peer_ipv6_addr); |
u_addrcopy(&iface->conf.peer_ipv6_addr, &iface->peer_ipv6_addr); |
} |
} |
Line 1137 IfaceIpv6IfaceUp(Bund b, int ready)
|
Line 1258 IfaceIpv6IfaceUp(Bund b, int ready)
|
char selfbuf[48],peerbuf[48]; |
char selfbuf[48],peerbuf[48]; |
int res; |
int res; |
|
|
res = ExecCmd(LG_IFACE2, b->name, "%s %s inet6 %s%%%s %s%%%s '%s' '%s'", | res = ExecCmd(LG_IFACE2, b->name, "%s %s inet6 %s%%%s %s%%%s '%s' '%s' '%s'", |
iface->up_script, iface->ifname, |
iface->up_script, iface->ifname, |
u_addrtoa(&iface->self_ipv6_addr, selfbuf, sizeof(selfbuf)), iface->ifname, |
u_addrtoa(&iface->self_ipv6_addr, selfbuf, sizeof(selfbuf)), iface->ifname, |
u_addrtoa(&iface->peer_ipv6_addr, peerbuf, sizeof(peerbuf)), iface->ifname, |
u_addrtoa(&iface->peer_ipv6_addr, peerbuf, sizeof(peerbuf)), iface->ifname, |
*b->params.authname ? b->params.authname : "-", |
*b->params.authname ? b->params.authname : "-", |
*b->params.peeraddr ? b->params.peeraddr : "-"); | *b->params.peeraddr ? b->params.peeraddr : "-", |
| #ifdef USE_RADIUS |
| b->params.filter_id ? b->params.filter_id : |
| #endif |
| "-"); |
if (res != 0) { |
if (res != 0) { |
FsmFailure(&b->ipv6cp.fsm, FAIL_NEGOT_FAILURE); |
FsmFailure(&b->ipv6cp.fsm, FAIL_NEGOT_FAILURE); |
return (-1); |
return (-1); |
Line 1169 IfaceIpv6IfaceDown(Bund b)
|
Line 1294 IfaceIpv6IfaceDown(Bund b)
|
if (*iface->down_script) { |
if (*iface->down_script) { |
char selfbuf[48],peerbuf[48]; |
char selfbuf[48],peerbuf[48]; |
|
|
ExecCmd(LG_IFACE2, b->name, "%s %s inet6 %s%%%s %s%%%s '%s' '%s'", | ExecCmd(LG_IFACE2, b->name, "%s %s inet6 %s%%%s %s%%%s '%s' '%s' '%s'", |
iface->down_script, iface->ifname, |
iface->down_script, iface->ifname, |
u_addrtoa(&iface->self_ipv6_addr, selfbuf, sizeof(selfbuf)), iface->ifname, |
u_addrtoa(&iface->self_ipv6_addr, selfbuf, sizeof(selfbuf)), iface->ifname, |
u_addrtoa(&iface->peer_ipv6_addr, peerbuf, sizeof(peerbuf)), iface->ifname, |
u_addrtoa(&iface->peer_ipv6_addr, peerbuf, sizeof(peerbuf)), iface->ifname, |
*b->params.authname ? b->params.authname : "-", |
*b->params.authname ? b->params.authname : "-", |
*b->params.peeraddr ? b->params.peeraddr : "-"); | *b->params.peeraddr ? b->params.peeraddr : "-", |
| #ifdef USE_RADIUS |
| b->params.filter_id ? b->params.filter_id : |
| #endif |
| "-"); |
} |
} |
|
|
/* Delete dynamic routes */ |
/* Delete dynamic routes */ |
Line 1331 IfaceIsDemand(int proto, Mbuf pkt)
|
Line 1460 IfaceIsDemand(int proto, Mbuf pkt)
|
if (MBLEN(pkt) < sizeof(struct ip)) |
if (MBLEN(pkt) < sizeof(struct ip)) |
return (0); |
return (0); |
|
|
ip = (struct ip *)MBDATA(pkt); | ip = (struct ip *)(void *)MBDATA(pkt); |
switch (ip->ip_p) { |
switch (ip->ip_p) { |
case IPPROTO_IGMP: /* No multicast stuff */ |
case IPPROTO_IGMP: /* No multicast stuff */ |
return(0); |
return(0); |
Line 1343 IfaceIsDemand(int proto, Mbuf pkt)
|
Line 1472 IfaceIsDemand(int proto, Mbuf pkt)
|
if (MBLEN(pkt) < (ip->ip_hl * 4 + sizeof(struct icmphdr))) |
if (MBLEN(pkt) < (ip->ip_hl * 4 + sizeof(struct icmphdr))) |
return (0); |
return (0); |
|
|
icmp = (struct icmphdr *) ((u_int32_t *) ip + ip->ip_hl); | icmp = (struct icmphdr *) ((u_int32_t *)(void *) ip + ip->ip_hl); |
|
|
switch (icmp->icmp_type) /* No ICMP replies */ |
switch (icmp->icmp_type) /* No ICMP replies */ |
{ |
{ |
Line 1364 IfaceIsDemand(int proto, Mbuf pkt)
|
Line 1493 IfaceIsDemand(int proto, Mbuf pkt)
|
if (MBLEN(pkt) < (ip->ip_hl * 4 + sizeof(struct udphdr))) |
if (MBLEN(pkt) < (ip->ip_hl * 4 + sizeof(struct udphdr))) |
return (0); |
return (0); |
|
|
udp = (struct udphdr *) ((u_int32_t *) ip + ip->ip_hl); | udp = (struct udphdr *) ((u_int32_t *)(void *) ip + ip->ip_hl); |
|
|
#define NTP_PORT 123 |
#define NTP_PORT 123 |
if (ntohs(udp->uh_dport) == NTP_PORT) /* No NTP packets */ |
if (ntohs(udp->uh_dport) == NTP_PORT) /* No NTP packets */ |
Line 1378 IfaceIsDemand(int proto, Mbuf pkt)
|
Line 1507 IfaceIsDemand(int proto, Mbuf pkt)
|
if (MBLEN(pkt) < (ip->ip_hl * 4 + sizeof(struct tcphdr))) |
if (MBLEN(pkt) < (ip->ip_hl * 4 + sizeof(struct tcphdr))) |
return (0); |
return (0); |
|
|
tcp = (struct tcphdr *) ((u_int32_t *) ip + ip->ip_hl); | tcp = (struct tcphdr *) ((u_int32_t *)(void *) ip + ip->ip_hl); |
|
|
if (tcp->th_flags & TH_RST) /* No TCP reset packets */ |
if (tcp->th_flags & TH_RST) /* No TCP reset packets */ |
return(0); |
return(0); |
Line 1400 IfaceIsDemand(int proto, Mbuf pkt)
|
Line 1529 IfaceIsDemand(int proto, Mbuf pkt)
|
*/ |
*/ |
|
|
static int |
static int |
IfaceSetCommand(Context ctx, int ac, char *av[], void *arg) | IfaceSetCommand(Context ctx, int ac, const char *const av[], const void *arg) |
{ |
{ |
IfaceState const iface = &ctx->bund->iface; |
IfaceState const iface = &ctx->bund->iface; |
int empty_arg; |
int empty_arg; |
Line 1433 IfaceSetCommand(Context ctx, int ac, char *av[], void
|
Line 1562 IfaceSetCommand(Context ctx, int ac, char *av[], void
|
struct u_range self_addr; |
struct u_range self_addr; |
struct u_addr peer_addr; |
struct u_addr peer_addr; |
int self_addr_force = 0, peer_addr_force = 0; |
int self_addr_force = 0, peer_addr_force = 0; |
char *arg; | const char *arg1; |
|
|
/* Parse */ |
/* Parse */ |
if (ac != 2) |
if (ac != 2) |
return(-1); |
return(-1); |
arg = av[0]; | arg1 = av[0]; |
if (arg[0] == '!') { | if (arg1[0] == '!') { |
self_addr_force = 1; |
self_addr_force = 1; |
arg++; | arg1++; |
} |
} |
if (!ParseRange(arg, &self_addr, ALLOW_IPV4|ALLOW_IPV6)) | if (!ParseRange(arg1, &self_addr, ALLOW_IPV4|ALLOW_IPV6)) |
Error("Bad IP address \"%s\"", av[0]); |
Error("Bad IP address \"%s\"", av[0]); |
arg = av[1]; | arg1 = av[1]; |
if (arg[0] == '!') { | if (arg1[0] == '!') { |
peer_addr_force = 1; |
peer_addr_force = 1; |
arg++; | arg1++; |
} |
} |
if (!ParseAddr(arg, &peer_addr, ALLOW_IPV4|ALLOW_IPV6)) | if (!ParseAddr(arg1, &peer_addr, ALLOW_IPV4|ALLOW_IPV6)) |
Error("Bad IP address \"%s\"", av[1]); |
Error("Bad IP address \"%s\"", av[1]); |
if (self_addr.addr.family != peer_addr.family) |
if (self_addr.addr.family != peer_addr.family) |
Error("Addresses must be from the same protocol family"); |
Error("Addresses must be from the same protocol family"); |
Line 1496 IfaceSetCommand(Context ctx, int ac, char *av[], void
|
Line 1625 IfaceSetCommand(Context ctx, int ac, char *av[], void
|
case SET_MTU: |
case SET_MTU: |
{ |
{ |
int max_mtu; |
int max_mtu; |
|
int override; |
|
|
/* Check */ |
/* Check */ |
if (ac != 1) | if (ac < 1 || ac > 2) |
return(-1); |
return(-1); |
|
|
max_mtu = atoi(av[0]); |
max_mtu = atoi(av[0]); |
|
override = 0; |
|
|
|
if (ac == 2 && av[1][0]) { |
|
if (strcmp(av[1], "override") == 0) |
|
override = 1; |
|
else |
|
Error("Invalid keyword %s", av[1]); |
|
} |
|
|
if (max_mtu < IFACE_MIN_MTU || max_mtu > IFACE_MAX_MTU) |
if (max_mtu < IFACE_MIN_MTU || max_mtu > IFACE_MAX_MTU) |
Error("Invalid interface mtu %d", max_mtu); | if (!override || max_mtu != 0) |
iface->max_mtu = max_mtu; | Error("Invalid interface mtu %d", max_mtu); |
| |
| if (max_mtu != 0) |
| iface->max_mtu = max_mtu; |
| if (override) |
| iface->mtu_override = max_mtu; |
} |
} |
break; |
break; |
|
|
Line 1519 IfaceSetCommand(Context ctx, int ac, char *av[], void
|
Line 1663 IfaceSetCommand(Context ctx, int ac, char *av[], void
|
break; |
break; |
case 1: |
case 1: |
if (strcmp(iface->ifname, av[0]) != 0) { |
if (strcmp(iface->ifname, av[0]) != 0) { |
int ifmaxlen = IF_NAMESIZE - ctx->bund->tmpl * IFNUMLEN; | unsigned ifmaxlen = IF_NAMESIZE - ctx->bund->tmpl * IFNUMLEN; |
if (strlen(av[0]) >= ifmaxlen) |
if (strlen(av[0]) >= ifmaxlen) |
Error("Interface name too long, >%d characters", ifmaxlen-1); | Error("Interface name too long, >%u characters", ifmaxlen-1); |
if ((strncmp(av[0], "ng", 2) == 0) && |
if ((strncmp(av[0], "ng", 2) == 0) && |
((ctx->bund->tmpl && av[0][2] == 0) || |
((ctx->bund->tmpl && av[0][2] == 0) || |
(av[0][2] >= '0' && av[0][2] <= '9'))) |
(av[0][2] >= '0' && av[0][2] <= '9'))) |
Line 1610 IfaceSetCommand(Context ctx, int ac, char *av[], void
|
Line 1754 IfaceSetCommand(Context ctx, int ac, char *av[], void
|
*/ |
*/ |
|
|
int |
int |
IfaceStat(Context ctx, int ac, char *av[], void *arg) | IfaceStat(Context ctx, int ac, const char *const av[], const void *arg) |
{ |
{ |
Bund const b = ctx->bund; |
Bund const b = ctx->bund; |
IfaceState const iface = &b->iface; |
IfaceState const iface = &b->iface; |
Line 1623 IfaceStat(Context ctx, int ac, char *av[], void *arg)
|
Line 1767 IfaceStat(Context ctx, int ac, char *av[], void *arg)
|
struct acl *a; |
struct acl *a; |
#endif |
#endif |
|
|
|
(void)ac; |
|
(void)av; |
|
(void)arg; |
|
|
Printf("Interface configuration:\r\n"); |
Printf("Interface configuration:\r\n"); |
Printf("\tName : %s\r\n", iface->conf.ifname); |
Printf("\tName : %s\r\n", iface->conf.ifname); |
#ifdef SIOCSIFDESCR |
#ifdef SIOCSIFDESCR |
Line 1633 IfaceStat(Context ctx, int ac, char *av[], void *arg)
|
Line 1781 IfaceStat(Context ctx, int ac, char *av[], void *arg)
|
Printf("\tGroup : %s\r\n", iface->conf.ifgroup); |
Printf("\tGroup : %s\r\n", iface->conf.ifgroup); |
#endif |
#endif |
Printf("\tMaximum MTU : %d bytes\r\n", iface->max_mtu); |
Printf("\tMaximum MTU : %d bytes\r\n", iface->max_mtu); |
|
Printf("\tMTU override : %d bytes\r\n", iface->mtu_override); |
Printf("\tIdle timeout : %d seconds\r\n", iface->idle_timeout); |
Printf("\tIdle timeout : %d seconds\r\n", iface->idle_timeout); |
Printf("\tSession timeout : %d seconds\r\n", iface->session_timeout); |
Printf("\tSession timeout : %d seconds\r\n", iface->session_timeout); |
if (!u_rangeempty(&iface->conf.self_addr)) { |
if (!u_rangeempty(&iface->conf.self_addr)) { |
Line 1758 IfaceSetMTU(Bund b, int mtu)
|
Line 1907 IfaceSetMTU(Bund b, int mtu)
|
int s; |
int s; |
|
|
/* Get socket */ |
/* Get socket */ |
if ((s = socket(PF_INET, SOCK_DGRAM, 0)) < 0) { | if ((s = socket(PF_LOCAL, SOCK_DGRAM, 0)) < 0) { |
Perror("[%s] IFACE: Can't get socket to set MTU", b->name); |
Perror("[%s] IFACE: Can't get socket to set MTU", b->name); |
return; |
return; |
} |
} |
|
|
if ((b->params.mtu > 0) && (mtu > b->params.mtu)) { | if (!iface->mtu_override && (b->params.mtu > 0) && (mtu > b->params.mtu)) { |
mtu = b->params.mtu; |
mtu = b->params.mtu; |
Log(LG_IFACE2, ("[%s] IFACE: forcing MTU of auth backend: %d bytes", |
Log(LG_IFACE2, ("[%s] IFACE: forcing MTU of auth backend: %d bytes", |
b->name, mtu)); |
b->name, mtu)); |
} |
} |
|
|
/* Limit MTU to configured maximum */ | /* Limit MTU to configured maximum/override */ |
if (mtu > iface->max_mtu) | if (iface->mtu_override) { |
| mtu = iface->mtu_override; |
| Log(LG_IFACE2, ("[%s] IFACE: forcing MTU override: %d bytes", |
| b->name, mtu)); |
| } else if (mtu > iface->max_mtu) |
mtu = iface->max_mtu; |
mtu = iface->max_mtu; |
|
|
/* Set MTU on interface */ |
/* Set MTU on interface */ |
Line 1803 IfaceChangeFlags(Bund b, int clear, int set)
|
Line 1956 IfaceChangeFlags(Bund b, int clear, int set)
|
Log(LG_IFACE2, ("[%s] IFACE: Change interface %s flags: -%d +%d", |
Log(LG_IFACE2, ("[%s] IFACE: Change interface %s flags: -%d +%d", |
b->name, b->iface.ifname, clear, set)); |
b->name, b->iface.ifname, clear, set)); |
|
|
if ((s = socket(PF_INET, SOCK_DGRAM, 0)) < 0) { | if ((s = socket(PF_LOCAL, SOCK_DGRAM, 0)) < 0) { |
Perror("[%s] IFACE: Can't get socket to change interface flags", b->name); |
Perror("[%s] IFACE: Can't get socket to change interface flags", b->name); |
return; |
return; |
} |
} |
Line 1811 IfaceChangeFlags(Bund b, int clear, int set)
|
Line 1964 IfaceChangeFlags(Bund b, int clear, int set)
|
memset(&ifrq, '\0', sizeof(ifrq)); |
memset(&ifrq, '\0', sizeof(ifrq)); |
strlcpy(ifrq.ifr_name, b->iface.ifname, sizeof(ifrq.ifr_name)); |
strlcpy(ifrq.ifr_name, b->iface.ifname, sizeof(ifrq.ifr_name)); |
if (ioctl(s, SIOCGIFFLAGS, &ifrq) < 0) { |
if (ioctl(s, SIOCGIFFLAGS, &ifrq) < 0) { |
Perror("[%s] IFACE: ioctl(SIOCGIFFLAGS, %s)", b->name, b->iface.ifname); | Perror("[%s] IFACE: ioctl(%s, %s)", b->name, b->iface.ifname, "SIOCGIFFLAGS"); |
close(s); |
close(s); |
return; |
return; |
} |
} |
Line 1824 IfaceChangeFlags(Bund b, int clear, int set)
|
Line 1977 IfaceChangeFlags(Bund b, int clear, int set)
|
ifrq.ifr_flagshigh = new_flags >> 16; |
ifrq.ifr_flagshigh = new_flags >> 16; |
|
|
if (ioctl(s, SIOCSIFFLAGS, &ifrq) < 0) { |
if (ioctl(s, SIOCSIFFLAGS, &ifrq) < 0) { |
Perror("[%s] IFACE: ioctl(SIOCSIFFLAGS, %s)", b->name, b->iface.ifname); | Perror("[%s] IFACE: ioctl(%s, %s)", b->name, b->iface.ifname, "SIOCSIFFLAGS"); |
close(s); |
close(s); |
return; |
return; |
} |
} |
Line 1839 add_scope(struct sockaddr *sa, int ifindex)
|
Line 1992 add_scope(struct sockaddr *sa, int ifindex)
|
|
|
if (sa->sa_family != AF_INET6) |
if (sa->sa_family != AF_INET6) |
return; |
return; |
sa6 = (struct sockaddr_in6 *)sa; | sa6 = (struct sockaddr_in6 *)(void *)sa; |
if (!IN6_IS_ADDR_LINKLOCAL(&sa6->sin6_addr) && |
if (!IN6_IS_ADDR_LINKLOCAL(&sa6->sin6_addr) && |
!IN6_IS_ADDR_MC_LINKLOCAL(&sa6->sin6_addr)) |
!IN6_IS_ADDR_MC_LINKLOCAL(&sa6->sin6_addr)) |
return; |
return; |
if (*(u_int16_t *)&sa6->sin6_addr.s6_addr[2] != 0) | if (sa6->sin6_addr.__u6_addr.__u6_addr16[1] != 0) |
return; |
return; |
*(u_int16_t *)&sa6->sin6_addr.s6_addr[2] = htons(ifindex); | sa6->sin6_addr.__u6_addr.__u6_addr16[1] = htons(ifindex); |
} |
} |
#endif |
#endif |
|
|
Line 1879 IfaceChangeAddr(Bund b, int add, struct u_range *self,
|
Line 2032 IfaceChangeAddr(Bund b, int add, struct u_range *self,
|
memset(&ifra, '\0', sizeof(ifra)); |
memset(&ifra, '\0', sizeof(ifra)); |
strlcpy(ifra.ifra_name, b->iface.ifname, sizeof(ifra.ifra_name)); |
strlcpy(ifra.ifra_name, b->iface.ifname, sizeof(ifra.ifra_name)); |
|
|
me4 = (struct sockaddr_in *)&ifra.ifra_addr; | me4 = (struct sockaddr_in *)(void *)&ifra.ifra_addr; |
memcpy(me4, &ssself, sizeof(*me4)); |
memcpy(me4, &ssself, sizeof(*me4)); |
|
|
msk4 = (struct sockaddr_in *)&ifra.ifra_mask; | msk4 = (struct sockaddr_in *)(void *)&ifra.ifra_mask; |
memcpy(msk4, &ssmsk, sizeof(*msk4)); |
memcpy(msk4, &ssmsk, sizeof(*msk4)); |
|
|
peer4 = (struct sockaddr_in *)&ifra.ifra_broadaddr; | peer4 = (struct sockaddr_in *)(void *)&ifra.ifra_broadaddr; |
if (peer == NULL || peer->family == AF_UNSPEC) { |
if (peer == NULL || peer->family == AF_UNSPEC) { |
peer4->sin_family = AF_INET; |
peer4->sin_family = AF_INET; |
peer4->sin_len = sizeof(*peer4); |
peer4->sin_len = sizeof(*peer4); |
Line 2036 IfaceCorrectMSS(Mbuf pkt, uint16_t maxmss)
|
Line 2189 IfaceCorrectMSS(Mbuf pkt, uint16_t maxmss)
|
if (pkt == NULL) |
if (pkt == NULL) |
return; |
return; |
|
|
iphdr = (struct ip *)MBDATAU(pkt); | iphdr = (struct ip *)(void *)MBDATAU(pkt); |
hlen = iphdr->ip_hl << 2; |
hlen = iphdr->ip_hl << 2; |
pktlen = MBLEN(pkt) - hlen; |
pktlen = MBLEN(pkt) - hlen; |
tc = (struct tcphdr *)(MBDATAU(pkt) + hlen); | tc = (struct tcphdr *)(void *)(MBDATAU(pkt) + hlen); |
hlen = tc->th_off << 2; |
hlen = tc->th_off << 2; |
|
|
/* Invalid header length or header without options. */ |
/* Invalid header length or header without options. */ |
Line 2063 IfaceCorrectMSS(Mbuf pkt, uint16_t maxmss)
|
Line 2216 IfaceCorrectMSS(Mbuf pkt, uint16_t maxmss)
|
if (*opt == TCPOPT_MAXSEG) { |
if (*opt == TCPOPT_MAXSEG) { |
if (optlen != TCPOLEN_MAXSEG) |
if (optlen != TCPOLEN_MAXSEG) |
continue; |
continue; |
mss = (u_int16_t *)(opt + 2); | mss = (u_int16_t *)(void *)(opt + 2); |
if (ntohs(*mss) > maxmss) { |
if (ntohs(*mss) > maxmss) { |
accumulate = *mss; |
accumulate = *mss; |
*mss = htons(maxmss); |
*mss = htons(maxmss); |
Line 2090 IfaceNgIpInit(Bund b, int ready)
|
Line 2243 IfaceNgIpInit(Bund b, int ready)
|
snprintf(hook, sizeof(hook), "4%d", b->id); |
snprintf(hook, sizeof(hook), "4%d", b->id); |
|
|
} else { |
} else { |
|
|
snprintf(path, sizeof(path), "[%x]:", b->nodeID); |
snprintf(path, sizeof(path), "[%x]:", b->nodeID); |
strcpy(hook, NG_PPP_HOOK_INET); |
strcpy(hook, NG_PPP_HOOK_INET); |
|
|
Line 2125 IfaceNgIpInit(Bund b, int ready)
|
Line 2277 IfaceNgIpInit(Bund b, int ready)
|
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN) || |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN) || |
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)) { |
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)) { |
if (IfaceInitNetflow(b, path, hook, |
if (IfaceInitNetflow(b, path, hook, |
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)?1:0, |
|
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)?1:0, 0)) |
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)?1:0, 0)) |
goto fail; |
goto fail; |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)) |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)) |
Line 2136 IfaceNgIpInit(Bund b, int ready)
|
Line 2287 IfaceNgIpInit(Bund b, int ready)
|
#else /* NG_NETFLOW_CONF_INGRESS */ |
#else /* NG_NETFLOW_CONF_INGRESS */ |
/* Connect a netflow node if configured */ |
/* Connect a netflow node if configured */ |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)) { |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)) { |
if (IfaceInitNetflow(b, path, hook, 1, 0, 0)) | if (IfaceInitNetflow(b, path, hook, 0, 0)) |
goto fail; |
goto fail; |
b->iface.nfin_up = 1; |
b->iface.nfin_up = 1; |
} |
} |
|
|
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)) { |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)) { |
if (IfaceInitNetflow(b, path, hook, 0, 1, 0)) | if (IfaceInitNetflow(b, path, hook, 1, 0)) |
goto fail; |
goto fail; |
b->iface.nfout_up = 1; |
b->iface.nfout_up = 1; |
} |
} |
Line 2180 IfaceNgIpInit(Bund b, int ready)
|
Line 2331 IfaceNgIpInit(Bund b, int ready)
|
#ifdef USE_NG_NETFLOW |
#ifdef USE_NG_NETFLOW |
#ifdef NG_NETFLOW_CONF_INGRESS |
#ifdef NG_NETFLOW_CONF_INGRESS |
if (b->iface.nfin_up || b->iface.nfout_up) |
if (b->iface.nfin_up || b->iface.nfout_up) |
IfaceSetupNetflow(b, b->iface.nfin_up, b->iface.nfout_up); | IfaceSetupNetflow(b, b->iface.nfin_up, b->iface.nfout_up, 0); |
#else /* NG_NETFLOW_CONF_INGRESS */ |
#else /* NG_NETFLOW_CONF_INGRESS */ |
if (b->iface.nfin_up) |
if (b->iface.nfin_up) |
IfaceSetupNetflow(b, 1, 0); | IfaceSetupNetflow(b, 1, 0, 0); |
|
|
if (b->iface.nfout_up) |
if (b->iface.nfout_up) |
IfaceSetupNetflow(b, 0, 1); | IfaceSetupNetflow(b, 0, 1, 0); |
#endif /* NG_NETFLOW_CONF_INGRESS */ |
#endif /* NG_NETFLOW_CONF_INGRESS */ |
#endif /* USE_NG_NETFLOW */ |
#endif /* USE_NG_NETFLOW */ |
} |
} |
Line 2230 IfaceNgIpShutdown(Bund b)
|
Line 2381 IfaceNgIpShutdown(Bund b)
|
#ifdef USE_NG_NETFLOW |
#ifdef USE_NG_NETFLOW |
#ifdef NG_NETFLOW_CONF_INGRESS |
#ifdef NG_NETFLOW_CONF_INGRESS |
if (b->iface.nfin_up || b->iface.nfout_up) |
if (b->iface.nfin_up || b->iface.nfout_up) |
IfaceShutdownNetflow(b, b->iface.nfin_up, b->iface.nfout_up); | IfaceShutdownNetflow(b, b->iface.nfout_up, 0); |
b->iface.nfin_up = 0; |
b->iface.nfin_up = 0; |
b->iface.nfout_up = 0; |
b->iface.nfout_up = 0; |
#else /* NG_NETFLOW_CONF_INGRESS */ |
#else /* NG_NETFLOW_CONF_INGRESS */ |
if (b->iface.nfin_up) |
if (b->iface.nfin_up) |
IfaceShutdownNetflow(b, 1, 0); | IfaceShutdownNetflow(b, 0, 0); |
b->iface.nfin_up = 0; |
b->iface.nfin_up = 0; |
if (b->iface.nfout_up) |
if (b->iface.nfout_up) |
IfaceShutdownNetflow(b, 0, 1); | IfaceShutdownNetflow(b, 1, 0); |
b->iface.nfout_up = 0; |
b->iface.nfout_up = 0; |
#endif /* NG_NETFLOW_CONF_INGRESS */ |
#endif /* NG_NETFLOW_CONF_INGRESS */ |
#endif |
#endif |
Line 2289 IfaceNgIpv6Init(Bund b, int ready)
|
Line 2440 IfaceNgIpv6Init(Bund b, int ready)
|
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN) || |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN) || |
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)) { |
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)) { |
if (IfaceInitNetflow(b, path, hook, |
if (IfaceInitNetflow(b, path, hook, |
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)?1:0, |
|
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)?1:0, 1)) |
Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)?1:0, 1)) |
goto fail; |
goto fail; |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)) |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)) |
Line 2299 IfaceNgIpv6Init(Bund b, int ready)
|
Line 2449 IfaceNgIpv6Init(Bund b, int ready)
|
} |
} |
#else /* NG_NETFLOW_CONF_INGRESS */ |
#else /* NG_NETFLOW_CONF_INGRESS */ |
/* Connect a netflow node if configured */ |
/* Connect a netflow node if configured */ |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN, 1)) { | if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_IN)) { |
if (IfaceInitNetflow(b, path, hook, 1, 0)) | if (IfaceInitNetflow(b, path, hook, 0, 1)) |
goto fail; |
goto fail; |
b->iface.nfin_up = 1; |
b->iface.nfin_up = 1; |
} |
} |
|
|
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)) { |
if (Enabled(&b->iface.options, IFACE_CONF_NETFLOW_OUT)) { |
if (IfaceInitNetflow(b, path, hook, 0, 1, 1)) | if (IfaceInitNetflow(b, path, hook, 1, 1)) |
goto fail; |
goto fail; |
b->iface.nfout_up = 1; |
b->iface.nfout_up = 1; |
} |
} |
Line 2314 IfaceNgIpv6Init(Bund b, int ready)
|
Line 2464 IfaceNgIpv6Init(Bund b, int ready)
|
#endif /* USE_NG_NETFLOW */ |
#endif /* USE_NG_NETFLOW */ |
} |
} |
|
|
|
#ifdef USE_NG_BPF |
|
if (IfaceInitLimits(b, path, hook)) |
|
goto fail; |
|
#endif |
|
|
/* Connect graph to the iface node. */ |
/* Connect graph to the iface node. */ |
strcpy(cn.ourhook, hook); |
strcpy(cn.ourhook, hook); |
snprintf(cn.path, sizeof(cn.path), "%s:", b->iface.ngname); |
snprintf(cn.path, sizeof(cn.path), "%s:", b->iface.ngname); |
Line 2329 IfaceNgIpv6Init(Bund b, int ready)
|
Line 2484 IfaceNgIpv6Init(Bund b, int ready)
|
#ifdef USE_NG_NETFLOW |
#ifdef USE_NG_NETFLOW |
#ifdef NG_NETFLOW_CONF_INGRESS |
#ifdef NG_NETFLOW_CONF_INGRESS |
if (b->iface.nfin_up || b->iface.nfout_up) |
if (b->iface.nfin_up || b->iface.nfout_up) |
IfaceSetupNetflow(b, b->iface.nfin_up, b->iface.nfout_up); | IfaceSetupNetflow(b, b->iface.nfin_up, b->iface.nfout_up, 1); |
#else /* NG_NETFLOW_CONF_INGRESS */ |
#else /* NG_NETFLOW_CONF_INGRESS */ |
if (b->iface.nfin_up) |
if (b->iface.nfin_up) |
IfaceSetupNetflow(b, 1, 0); | IfaceSetupNetflow(b, 1, 0, 1); |
|
|
if (b->iface.nfout_up) |
if (b->iface.nfout_up) |
IfaceSetupNetflow(b, 0, 1); | IfaceSetupNetflow(b, 0, 1, 1); |
#endif /* NG_NETFLOW_CONF_INGRESS */ |
#endif /* NG_NETFLOW_CONF_INGRESS */ |
#endif /* USE_NG_NETFLOW */ |
#endif /* USE_NG_NETFLOW */ |
} |
} |
|
|
|
#ifdef USE_NG_BPF |
|
IfaceSetupLimits(b); |
|
#endif |
|
|
/* OK */ |
/* OK */ |
return(0); |
return(0); |
|
|
Line 2356 IfaceNgIpv6Shutdown(Bund b)
|
Line 2515 IfaceNgIpv6Shutdown(Bund b)
|
{ |
{ |
char path[NG_PATHSIZ]; |
char path[NG_PATHSIZ]; |
|
|
|
#ifdef USE_NG_BPF |
|
IfaceShutdownLimits(b); /* Limits must shutdown first to save final stats. */ |
|
#endif |
if (b->iface.tee6_up) |
if (b->iface.tee6_up) |
IfaceShutdownTee(b, 1); |
IfaceShutdownTee(b, 1); |
b->iface.tee6_up = 0; |
b->iface.tee6_up = 0; |
#ifdef USE_NG_NETFLOW |
#ifdef USE_NG_NETFLOW |
#ifdef NG_NETFLOW_CONF_INGRESS |
#ifdef NG_NETFLOW_CONF_INGRESS |
if (b->iface.nfin_up || b->iface.nfout_up) |
if (b->iface.nfin_up || b->iface.nfout_up) |
IfaceShutdownNetflow(b, b->iface.nfin_up, b->iface.nfout_up); | IfaceShutdownNetflow(b, b->iface.nfout_up, 1); |
b->iface.nfin_up = 0; |
b->iface.nfin_up = 0; |
b->iface.nfout_up = 0; |
b->iface.nfout_up = 0; |
#else /* NG_NETFLOW_CONF_INGRESS */ |
#else /* NG_NETFLOW_CONF_INGRESS */ |
if (b->iface.nfin_up) |
if (b->iface.nfin_up) |
IfaceShutdownNetflow(b, 1, 0); | IfaceShutdownNetflow(b, 0, 1); |
b->iface.nfin_up = 0; |
b->iface.nfin_up = 0; |
if (b->iface.nfout_up) |
if (b->iface.nfout_up) |
IfaceShutdownNetflow(b, 0, 1); | IfaceShutdownNetflow(b, 1, 1); |
b->iface.nfout_up = 0; |
b->iface.nfout_up = 0; |
#endif /* NG_NETFLOW_CONF_INGRESS */ |
#endif /* NG_NETFLOW_CONF_INGRESS */ |
#endif |
#endif |
Line 2469 IfaceSetupNAT(Bund b)
|
Line 2631 IfaceSetupNAT(Bund b)
|
uint32_t *const nat_id = (uint32_t *)(void *)u.reply.data; |
uint32_t *const nat_id = (uint32_t *)(void *)u.reply.data; |
#endif |
#endif |
|
|
|
snprintf(path, sizeof(path), "mpd%d-%s-nat:", gPid, b->name); |
if (u_addrempty(&nat->alias_addr)) { |
if (u_addrempty(&nat->alias_addr)) { |
snprintf(path, sizeof(path), "mpd%d-%s-nat:", gPid, b->name); |
|
if (NgSendMsg(gLinksCsock, path, |
if (NgSendMsg(gLinksCsock, path, |
NGM_NAT_COOKIE, NGM_NAT_SET_IPADDR, |
NGM_NAT_COOKIE, NGM_NAT_SET_IPADDR, |
&b->iface.self_addr.addr.u.ip4, |
&b->iface.self_addr.addr.u.ip4, |
Line 2699 IfaceShutdownIpacct(Bund b)
|
Line 2861 IfaceShutdownIpacct(Bund b)
|
|
|
#ifdef USE_NG_NETFLOW |
#ifdef USE_NG_NETFLOW |
static int |
static int |
IfaceInitNetflow(Bund b, char *path, char *hook, char in, char out, int v6) | IfaceInitNetflow(Bund b, char *path, char *hook, char out, int v6) |
{ |
{ |
struct ngm_connect cn; |
struct ngm_connect cn; |
int nif; |
int nif; |
|
|
#ifdef NG_NETFLOW_CONF_INGRESS |
#ifdef NG_NETFLOW_CONF_INGRESS |
nif = gNetflowIface + b->id; | nif = gNetflowIface + b->id*2; |
#else |
#else |
nif = gNetflowIface + b->id*2 + out; | nif = gNetflowIface + b->id*4 + out*2; |
#endif |
#endif |
|
nif += v6 ? 1 : 0; |
|
|
Log(LG_IFACE2, ("[%s] IFACE: Connecting netflow%s (%s)", |
Log(LG_IFACE2, ("[%s] IFACE: Connecting netflow%s (%s)", |
b->name, v6?"6":"", out?"out":"in")); |
b->name, v6?"6":"", out?"out":"in")); |
Line 2754 IfaceInitNetflow(Bund b, char *path, char *hook, char
|
Line 2917 IfaceInitNetflow(Bund b, char *path, char *hook, char
|
} |
} |
|
|
static int |
static int |
IfaceSetupNetflow(Bund b, char in, char out) | IfaceSetupNetflow(Bund b, char in, char out, int v6) |
{ |
{ |
char path[NG_PATHSIZ]; |
char path[NG_PATHSIZ]; |
struct ng_netflow_setdlt nf_setdlt; |
struct ng_netflow_setdlt nf_setdlt; |
Line 2765 IfaceSetupNetflow(Bund b, char in, char out)
|
Line 2928 IfaceSetupNetflow(Bund b, char in, char out)
|
int nif; |
int nif; |
|
|
#ifdef NG_NETFLOW_CONF_INGRESS |
#ifdef NG_NETFLOW_CONF_INGRESS |
nif = gNetflowIface + b->id; | nif = gNetflowIface + b->id*2; |
#else |
#else |
nif = gNetflowIface + b->id*2 + out; | nif = gNetflowIface + b->id*4 + out*2; |
#endif |
#endif |
| nif += v6 ? 1 : 0; |
| |
/* Configure data link type and interface index. */ |
/* Configure data link type and interface index. */ |
snprintf(path, sizeof(path), "[%x]:", gNetflowNodeID); |
snprintf(path, sizeof(path), "[%x]:", gNetflowNodeID); |
nf_setdlt.iface = nif; |
nf_setdlt.iface = nif; |
Line 2811 fail:
|
Line 2975 fail:
|
} |
} |
|
|
static void |
static void |
IfaceShutdownNetflow(Bund b, char in, char out) | IfaceShutdownNetflow(Bund b, char out, int v6) |
{ |
{ |
char path[NG_PATHSIZ]; |
char path[NG_PATHSIZ]; |
char hook[NG_HOOKSIZ]; |
char hook[NG_HOOKSIZ]; |
int nif; |
int nif; |
|
|
#ifdef NG_NETFLOW_CONF_INGRESS |
#ifdef NG_NETFLOW_CONF_INGRESS |
nif = gNetflowIface + b->id; | (void)out; |
| nif = gNetflowIface + b->id*2; |
#else |
#else |
nif = gNetflowIface + b->id*2 + out; | nif = gNetflowIface + b->id*4 + out*2; |
#endif |
#endif |
|
nif += v6 ? 1 : 0; |
|
|
snprintf(path, NG_PATHSIZ, "[%x]:", gNetflowNodeID); |
snprintf(path, NG_PATHSIZ, "[%x]:", gNetflowNodeID); |
snprintf(hook, NG_HOOKSIZ, "%s%d", NG_NETFLOW_HOOK_DATA, nif); |
snprintf(hook, NG_HOOKSIZ, "%s%d", NG_NETFLOW_HOOK_DATA, nif); |
Line 2937 IfaceSetupMSS(Bund b, uint16_t maxMSS)
|
Line 3103 IfaceSetupMSS(Bund b, uint16_t maxMSS)
|
memset(&tcpmsscfg, 0, sizeof(tcpmsscfg)); |
memset(&tcpmsscfg, 0, sizeof(tcpmsscfg)); |
tcpmsscfg.maxMSS = maxMSS; |
tcpmsscfg.maxMSS = maxMSS; |
|
|
|
Log(LG_IFACE2, ("[%s] IFACE: Configuring ng_tcpmss %s %u", |
|
b->name, path, (unsigned)tcpmsscfg.maxMSS)); |
|
|
snprintf(tcpmsscfg.inHook, sizeof(tcpmsscfg.inHook), "in"); |
snprintf(tcpmsscfg.inHook, sizeof(tcpmsscfg.inHook), "in"); |
snprintf(tcpmsscfg.outHook, sizeof(tcpmsscfg.outHook), "out"); |
snprintf(tcpmsscfg.outHook, sizeof(tcpmsscfg.outHook), "out"); |
if (NgSendMsg(gLinksCsock, path, NGM_TCPMSS_COOKIE, NGM_TCPMSS_CONFIG, |
if (NgSendMsg(gLinksCsock, path, NGM_TCPMSS_COOKIE, NGM_TCPMSS_CONFIG, |
Line 3605 IfaceSetName(Bund b, const char * ifname)
|
Line 3774 IfaceSetName(Bund b, const char * ifname)
|
return(0); |
return(0); |
|
|
/* Get socket */ |
/* Get socket */ |
if ((s = socket(PF_INET, SOCK_DGRAM, 0)) < 0) { | if ((s = socket(PF_LOCAL, SOCK_DGRAM, 0)) < 0) { |
Perror("[%s] IFACE: Can't get socket to set name", b->name); |
Perror("[%s] IFACE: Can't get socket to set name", b->name); |
return(-1); |
return(-1); |
} |
} |
Line 3613 IfaceSetName(Bund b, const char * ifname)
|
Line 3782 IfaceSetName(Bund b, const char * ifname)
|
/* Set name of interface */ |
/* Set name of interface */ |
memset(&ifr, 0, sizeof(ifr)); |
memset(&ifr, 0, sizeof(ifr)); |
strlcpy(ifr.ifr_name, iface->ifname, sizeof(ifr.ifr_name)); |
strlcpy(ifr.ifr_name, iface->ifname, sizeof(ifr.ifr_name)); |
ifr.ifr_data = (caddr_t)ifname; | |
| #ifdef __clang__ |
| #pragma clang diagnostic push |
| #pragma clang diagnostic ignored "-Wcast-qual" |
| #endif |
| ifr.ifr_data = (char *)ifname; |
| #ifdef __clang__ |
| #pragma clang diagnostic pop |
| #endif |
| |
Log(LG_IFACE2, ("[%s] IFACE: setting \"%s\" name to \"%s\"", |
Log(LG_IFACE2, ("[%s] IFACE: setting \"%s\" name to \"%s\"", |
b->name, iface->ifname, ifname)); |
b->name, iface->ifname, ifname)); |
|
|
if (ioctl(s, SIOCSIFNAME, (caddr_t)&ifr) < 0) { |
if (ioctl(s, SIOCSIFNAME, (caddr_t)&ifr) < 0) { |
Perror("[%s] IFACE: ioctl(%s, SIOCSIFNAME)", b->name, iface->ifname); | if (errno != EEXIST) { |
close(s); | Perror("[%s] IFACE: ioctl(%s, %s)", b->name, iface->ifname, "SIOCSIFNAME"); |
return(-1); | close(s); |
| return(-1); |
| } |
} |
} |
|
|
close(s); |
close(s); |
Line 3645 IfaceSetName(Bund b, const char * ifname)
|
Line 3825 IfaceSetName(Bund b, const char * ifname)
|
* %I for interface name; |
* %I for interface name; |
* %l for name of bundle's first link |
* %l for name of bundle's first link |
* %M for peer MAC address of bundle's first link |
* %M for peer MAC address of bundle's first link |
|
* %o for local outer ("physical") address of bundle's first link |
|
* %O for peer outer ("physical") address of bundle's first link |
|
* %P for peer outer ("physical") port of bundle's first link |
|
* %s for last interface description change time, in unixtime (seconds) |
* %S for interface status (DoD/UP/DOWN) |
* %S for interface status (DoD/UP/DOWN) |
* %t for type of bundle's first link (pppoe, pptp, l2tp etc.) |
* %t for type of bundle's first link (pppoe, pptp, l2tp etc.) |
* %u for self auth name (or dash if self auth name not used) |
* %u for self auth name (or dash if self auth name not used) |
Line 3673 IfaceSetDescr(Bund b, const char * template)
|
Line 3857 IfaceSetDescr(Bund b, const char * template)
|
*/ |
*/ |
if (mib[0] < 0 && sysctlnametomib("net.ifdescr_maxlen", mib, &miblen) < 0) { |
if (mib[0] < 0 && sysctlnametomib("net.ifdescr_maxlen", mib, &miblen) < 0) { |
mib[0] = 0; |
mib[0] = 0; |
Perror("[%s] IFACE: sysctl net.ifdescr_maxlen failed", b->name); | Perror("[%s] IFACE: sysctl net.ifdescr_maxlen failed", b->name); |
} |
} |
|
|
/* |
/* |
Line 3748 IfaceSetDescr(Bund b, const char * template)
|
Line 3932 IfaceSetDescr(Bund b, const char * template)
|
/* peer address */ |
/* peer address */ |
case 'A': |
case 'A': |
{ |
{ |
u_addrtoa (&iface->peer_addr, buf, sizeof(buf)); | u_addrtoa(&iface->peer_addr, buf, sizeof(buf)); |
DST_COPY(buf); |
DST_COPY(buf); |
} |
} |
break; |
break; |
/* interface index */ |
/* interface index */ |
case 'i': |
case 'i': |
{ |
{ |
snprintf (buf, sizeof(buf), "%u", iface->ifindex); | snprintf(buf, sizeof(buf), "%u", iface->ifindex); |
DST_COPY(buf); |
DST_COPY(buf); |
} |
} |
break; |
break; |
Line 3767 IfaceSetDescr(Bund b, const char * template)
|
Line 3951 IfaceSetDescr(Bund b, const char * template)
|
case 'l': |
case 'l': |
DST_COPY(b->links[0] ? b->links[0]->name : NULL); |
DST_COPY(b->links[0] ? b->links[0]->name : NULL); |
break; |
break; |
|
/* peer MAC address */ |
case 'M': |
case 'M': |
if(b->links[0]) { | if (b->links[0]) { |
PhysType const pt = b->links[0]->type; | const struct phystype * pt = b->links[0]->type; |
if (pt && pt->peermacaddr) { |
if (pt && pt->peermacaddr) { |
(*pt->peermacaddr)(b->links[0], buf, sizeof(buf)); | (*pt->peermacaddr)(b->links[0], buf, sizeof(buf)); |
DST_COPY(buf); | DST_COPY(buf); |
} else { |
} else { |
DST_COPY("-"); |
DST_COPY("-"); |
} |
} |
Line 3780 IfaceSetDescr(Bund b, const char * template)
|
Line 3965 IfaceSetDescr(Bund b, const char * template)
|
DST_COPY("-"); |
DST_COPY("-"); |
} |
} |
break; |
break; |
|
/* local "physical" address */ |
|
case 'o': |
|
if (b->links[0] && PhysGetSelfAddr(b->links[0], buf, sizeof(buf)) == 0) { |
|
DST_COPY(buf); |
|
} else { |
|
DST_COPY("-"); |
|
} |
|
break; |
|
/* peer "physical" address */ |
|
case 'O': |
|
if (b->links[0] && PhysGetPeerAddr(b->links[0], buf, sizeof(buf)) == 0) { |
|
DST_COPY(buf); |
|
} else { |
|
DST_COPY("-"); |
|
} |
|
break; |
|
/* peer port */ |
|
case 'P': |
|
if (b->links[0] && PhysGetPeerPort(b->links[0], buf, sizeof(buf)) == 0) { |
|
DST_COPY(buf); |
|
} else { |
|
DST_COPY("-"); |
|
} |
|
break; |
|
/* timestamp of interface description change */ |
|
case 's': |
|
snprintf(buf, sizeof(buf), "%jd", (intmax_t)time(NULL)); |
|
DST_COPY(buf); |
|
break; |
/* interface status */ |
/* interface status */ |
case 'S': |
case 'S': |
DST_COPY(iface->up ? (iface->dod ? "DoD" : "UP") : "DOWN"); |
DST_COPY(iface->up ? (iface->dod ? "DoD" : "UP") : "DOWN"); |
Line 3827 IfaceSetDescr(Bund b, const char * template)
|
Line 4041 IfaceSetDescr(Bund b, const char * template)
|
return(0); /* we have not set system interface name yet */ |
return(0); /* we have not set system interface name yet */ |
|
|
/* Get socket */ |
/* Get socket */ |
if ((s = socket(PF_INET, SOCK_DGRAM, 0)) < 0) { | if ((s = socket(PF_LOCAL, SOCK_DGRAM, 0)) < 0) { |
Perror("[%s] IFACE: Can't get socket to set description for %s", |
Perror("[%s] IFACE: Can't get socket to set description for %s", |
b->name, ifname); |
b->name, ifname); |
return(-1); |
return(-1); |
Line 3880 IfaceAddGroup(Bund b, const char * ifgroup)
|
Line 4094 IfaceAddGroup(Bund b, const char * ifgroup)
|
} |
} |
|
|
/* Get socket */ |
/* Get socket */ |
if ((s = socket(PF_INET, SOCK_DGRAM, 0)) < 0) { | if ((s = socket(PF_LOCAL, SOCK_DGRAM, 0)) < 0) { |
Perror("[%s] IFACE: Can't get socket to add group", b->name); |
Perror("[%s] IFACE: Can't get socket to add group", b->name); |
return(-1); |
return(-1); |
} |
} |
Line 3895 IfaceAddGroup(Bund b, const char * ifgroup)
|
Line 4109 IfaceAddGroup(Bund b, const char * ifgroup)
|
|
|
i = ioctl(s, SIOCAIFGROUP, (caddr_t)&ifgr); |
i = ioctl(s, SIOCAIFGROUP, (caddr_t)&ifgr); |
if (i < 0 && i != EEXIST) { |
if (i < 0 && i != EEXIST) { |
Perror("[%s] IFACE: ioctl(%s, SIOCAIFGROUP)", b->name, iface->ifname); | Perror("[%s] IFACE: ioctl(%s, %s)", b->name, iface->ifname, "SIOCAIFGROUP"); |
close(s); |
close(s); |
return(-1); |
return(-1); |
} |
} |
Line 3915 IfaceDelGroup(Bund b, const char * ifgroup)
|
Line 4129 IfaceDelGroup(Bund b, const char * ifgroup)
|
int s; |
int s; |
|
|
/* Get socket */ |
/* Get socket */ |
if ((s = socket(PF_INET, SOCK_DGRAM, 0)) < 0) { | if ((s = socket(PF_LOCAL, SOCK_DGRAM, 0)) < 0) { |
Perror("[%s] IFACE: Can't get socket to delete from group", b->name); |
Perror("[%s] IFACE: Can't get socket to delete from group", b->name); |
return(-1); |
return(-1); |
} |
} |
Line 3934 IfaceDelGroup(Bund b, const char * ifgroup)
|
Line 4148 IfaceDelGroup(Bund b, const char * ifgroup)
|
b->name, iface->ifname, ifgroup)); |
b->name, iface->ifname, ifgroup)); |
|
|
if (ioctl(s, SIOCDIFGROUP, (caddr_t)&ifgr) == -1) { |
if (ioctl(s, SIOCDIFGROUP, (caddr_t)&ifgr) == -1) { |
Perror("[%s] IFACE: ioctl(%s, SIOCDIFGROUP)", b->name, iface->ifname); | Perror("[%s] IFACE: ioctl(%s, %s)", b->name, iface->ifname, "SIOCDIFGROUP"); |
close(s); |
close(s); |
return(-1); |
return(-1); |
} |
} |