summaryrefslogtreecommitdiff
path: root/sbin/ifconfig/ifconfig.c
diff options
context:
space:
mode:
authorClaudio Jeker <claudio@cvs.openbsd.org>2010-06-04 08:53:25 +0000
committerClaudio Jeker <claudio@cvs.openbsd.org>2010-06-04 08:53:25 +0000
commit544ea68fb9ac50630b3d67b3336b4eb578254f33 (patch)
tree09dc86ae9d263e196ab7cb8f67bf6c1763c49f75 /sbin/ifconfig/ifconfig.c
parente1efc32c5109f8b8660ab489edce65a5e670df3a (diff)
Merge interface flags and xflags before printing them. So it is possible to
see if a interface is using the INET6_PRIVACY or is MPLS enabled. If xflags uses more then 16 flags something else must be figured out. OK stsp@ deraadt@
Diffstat (limited to 'sbin/ifconfig/ifconfig.c')
-rw-r--r--sbin/ifconfig/ifconfig.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/sbin/ifconfig/ifconfig.c b/sbin/ifconfig/ifconfig.c
index ac95c98f46e..c5aac5a0b1a 100644
--- a/sbin/ifconfig/ifconfig.c
+++ b/sbin/ifconfig/ifconfig.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ifconfig.c,v 1.234 2010/06/03 21:57:12 stsp Exp $ */
+/* $OpenBSD: ifconfig.c,v 1.235 2010/06/04 08:53:24 claudio Exp $ */
/* $NetBSD: ifconfig.c,v 1.40 1997/10/01 02:19:43 enami Exp $ */
/*
@@ -121,7 +121,7 @@ struct netrange at_nr; /* AppleTalk net range */
#endif /* SMALL */
char name[IFNAMSIZ];
-int flags, setaddr, setipdst, doalias;
+int flags, xflags, setaddr, setipdst, doalias;
u_long metric, mtu;
int rdomainid;
int clearaddr, s;
@@ -479,7 +479,6 @@ int printgroup(char *, int);
void printgroupattribs(char *);
void setgroupattribs(char *, int, char *[]);
void printif(char *, int);
-void printb(char *, unsigned short, char *);
void printb_status(unsigned short, char *);
const char *get_linkstate(int, int);
void status(int, struct sockaddr_dl *, int);
@@ -790,7 +789,10 @@ getinfo(struct ifreq *ifr, int create)
if (ioctl(s, SIOCGIFFLAGS, (caddr_t)ifr) < 0)
return (-1);
}
- flags = ifr->ifr_flags;
+ flags = ifr->ifr_flags & 0xffff;
+ if (ioctl(s, SIOCGIFXFLAGS, (caddr_t)ifr) < 0)
+ ifr->ifr_flags = 0;
+ xflags = ifr->ifr_flags;
if (ioctl(s, SIOCGIFMETRIC, (caddr_t)ifr) < 0)
metric = 0;
else
@@ -1203,14 +1205,14 @@ setifxflags(const char *vname, int value)
if (ioctl(s, SIOCGIFXFLAGS, (caddr_t)&my_ifr) < 0)
warn("SIOCGIFXFLAGS");
(void) strlcpy(my_ifr.ifr_name, name, sizeof(my_ifr.ifr_name));
- flags = my_ifr.ifr_flags;
+ xflags = my_ifr.ifr_flags;
if (value < 0) {
value = -value;
- flags &= ~value;
+ xflags &= ~value;
} else
- flags |= value;
- my_ifr.ifr_flags = flags;
+ xflags |= value;
+ my_ifr.ifr_flags = xflags;
if (ioctl(s, SIOCSIFXFLAGS, (caddr_t)&my_ifr) < 0)
warn("SIOCSIFXFLAGS");
}
@@ -2708,7 +2710,7 @@ status(int link, struct sockaddr_dl *sdl, int ls)
char ifdescr[IFDESCRSIZE];
printf("%s: ", name);
- printb("flags", flags, IFFBITS);
+ printb("flags", flags | (xflags << 16), IFFBITS);
if (rdomainid)
printf(" rdomain %i", rdomainid);
if (metric)
@@ -4512,7 +4514,7 @@ in_getprefix(const char *plen, int which)
* Print a value a la the %b format of the kernel's printf
*/
void
-printb(char *s, unsigned short v, char *bits)
+printb(char *s, unsigned int v, char *bits)
{
int i, any = 0;
char c;