This has two patches. First it moves interface.c to libbb (it is

support code after all).  It also contains a patch from Larry Doolittle
that removes two instances of "strlen([^)]*) *- *1", un-shadows two
variables, relaxes requirement for a sprintf(3) that returns number of
bytes written, and eliminates a duplicate subroutine.
This commit is contained in:
Eric Andersen 2001-04-19 16:55:27 +00:00
parent 3ce79338e6
commit 46cd74b9e3
7 changed files with 24 additions and 75 deletions

View File

@ -396,14 +396,6 @@
#define BB_NFSMOUNT #define BB_NFSMOUNT
#endif #endif
// //
#if defined BB_IFCONFIG
#ifdef BB_FEATURE_IFCONFIG_STATUS
#define BB_INTERFACE
#endif
#else
#undef BB_INTERFACE
#endif
//
#if defined BB_FEATURE_AUTOWIDTH #if defined BB_FEATURE_AUTOWIDTH
#ifndef BB_FEATURE_USE_TERMIOS #ifndef BB_FEATURE_USE_TERMIOS
#define BB_FEATURE_USE_TERMIOS #define BB_FEATURE_USE_TERMIOS

View File

@ -345,14 +345,6 @@
#define BB_NFSMOUNT #define BB_NFSMOUNT
#endif #endif
// //
#if defined BB_IFCONFIG
#ifdef BB_FEATURE_IFCONFIG_STATUS
#define BB_INTERFACE
#endif
#else
#undef BB_INTERFACE
#endif
//
#if defined BB_FEATURE_AUTOWIDTH #if defined BB_FEATURE_AUTOWIDTH
#ifndef BB_FEATURE_USE_TERMIOS #ifndef BB_FEATURE_USE_TERMIOS
#define BB_FEATURE_USE_TERMIOS #define BB_FEATURE_USE_TERMIOS

View File

@ -247,7 +247,7 @@ parse_mode.c parse_number.c perror_msg.c perror_msg_and_die.c print_file.c \
process_escape_sequence.c read_package_field.c read_text_file_to_buffer.c \ process_escape_sequence.c read_package_field.c read_text_file_to_buffer.c \
recursive_action.c safe_read.c safe_strncpy.c seek_ared_file.c syscalls.c \ recursive_action.c safe_read.c safe_strncpy.c seek_ared_file.c syscalls.c \
syslog_msg_with_name.c time_string.c trim.c untar.c unzip.c vdprintf.c \ syslog_msg_with_name.c time_string.c trim.c untar.c unzip.c vdprintf.c \
verror_msg.c vperror_msg.c wfopen.c xfuncs.c xgetcwd.c xregcomp.c verror_msg.c vperror_msg.c wfopen.c xfuncs.c xgetcwd.c xregcomp.c interface.c
LIBBB_OBJS=$(patsubst %.c,$(LIBBB)/%.o, $(LIBBB_CSRC)) LIBBB_OBJS=$(patsubst %.c,$(LIBBB)/%.o, $(LIBBB_CSRC))
LIBBB_CFLAGS = -I$(LIBBB) LIBBB_CFLAGS = -I$(LIBBB)

8
debian/Config.h-deb vendored
View File

@ -413,14 +413,6 @@
#define BB_NFSMOUNT #define BB_NFSMOUNT
#endif #endif
// //
#if defined BB_IFCONFIG
#ifdef BB_FEATURE_IFCONFIG_STATUS
#define BB_INTERFACE
#endif
#else
#undef BB_INTERFACE
#endif
//
#if defined BB_FEATURE_AUTOWIDTH #if defined BB_FEATURE_AUTOWIDTH
#ifndef BB_FEATURE_USE_TERMIOS #ifndef BB_FEATURE_USE_TERMIOS
#define BB_FEATURE_USE_TERMIOS #define BB_FEATURE_USE_TERMIOS

View File

@ -413,14 +413,6 @@
#define BB_NFSMOUNT #define BB_NFSMOUNT
#endif #endif
// //
#if defined BB_IFCONFIG
#ifdef BB_FEATURE_IFCONFIG_STATUS
#define BB_INTERFACE
#endif
#else
#undef BB_INTERFACE
#endif
//
#if defined BB_FEATURE_AUTOWIDTH #if defined BB_FEATURE_AUTOWIDTH
#ifndef BB_FEATURE_USE_TERMIOS #ifndef BB_FEATURE_USE_TERMIOS
#define BB_FEATURE_USE_TERMIOS #define BB_FEATURE_USE_TERMIOS

View File

@ -413,14 +413,6 @@
#define BB_NFSMOUNT #define BB_NFSMOUNT
#endif #endif
// //
#if defined BB_IFCONFIG
#ifdef BB_FEATURE_IFCONFIG_STATUS
#define BB_INTERFACE
#endif
#else
#undef BB_INTERFACE
#endif
//
#if defined BB_FEATURE_AUTOWIDTH #if defined BB_FEATURE_AUTOWIDTH
#ifndef BB_FEATURE_USE_TERMIOS #ifndef BB_FEATURE_USE_TERMIOS
#define BB_FEATURE_USE_TERMIOS #define BB_FEATURE_USE_TERMIOS

View File

@ -3,7 +3,7 @@
* that either displays or sets the characteristics of * that either displays or sets the characteristics of
* one or more of the system's networking interfaces. * one or more of the system's networking interfaces.
* *
* Version: $Id: interface.c,v 1.6 2001/04/09 23:52:18 andersen Exp $ * Version: $Id: interface.c,v 1.1 2001/04/19 16:55:27 andersen Exp $
* *
* Author: Fred N. van Kempen, <waltje@uwalt.nl.mugnet.org> * Author: Fred N. van Kempen, <waltje@uwalt.nl.mugnet.org>
* and others. Copyright 1993 MicroWalt Corporation * and others. Copyright 1993 MicroWalt Corporation
@ -37,7 +37,7 @@
/* #define KEEP_UNUSED */ /* #define KEEP_UNUSED */
#include "busybox.h" #include "libbb.h"
/* /*
* *
@ -353,7 +353,7 @@ static int INET_resolve(char *name, struct sockaddr_in *sin, int hostfirst)
* & 0x4000: host instead of net, * & 0x4000: host instead of net,
* & 0x0fff: don't resolve * & 0x0fff: don't resolve
*/ */
static int INET_rresolve(char *name, size_t len, struct sockaddr_in *sin, static int INET_rresolve(char *name, size_t len, struct sockaddr_in *s_in,
int numeric, unsigned int netmask) int numeric, unsigned int netmask)
{ {
struct hostent *ent; struct hostent *ent;
@ -363,14 +363,14 @@ static int INET_rresolve(char *name, size_t len, struct sockaddr_in *sin,
int host = 0; int host = 0;
/* Grmpf. -FvK */ /* Grmpf. -FvK */
if (sin->sin_family != AF_INET) { if (s_in->sin_family != AF_INET) {
#ifdef DEBUG #ifdef DEBUG
fprintf(stderr, _("rresolve: unsupport address family %d !\n"), sin->sin_family); fprintf(stderr, _("rresolve: unsupport address family %d !\n"), s_in->sin_family);
#endif #endif
errno = EAFNOSUPPORT; errno = EAFNOSUPPORT;
return (-1); return (-1);
} }
ad = (unsigned long) sin->sin_addr.s_addr; ad = (unsigned long) s_in->sin_addr.s_addr;
#ifdef DEBUG #ifdef DEBUG
fprintf (stderr, "rresolve: %08lx, mask %08x, num %08x \n", ad, netmask, numeric); fprintf (stderr, "rresolve: %08lx, mask %08x, num %08x \n", ad, netmask, numeric);
#endif #endif
@ -384,7 +384,7 @@ static int INET_rresolve(char *name, size_t len, struct sockaddr_in *sin,
} }
} }
if (numeric & 0x0FFF) { if (numeric & 0x0FFF) {
safe_strncpy(name, inet_ntoa(sin->sin_addr), len); safe_strncpy(name, inet_ntoa(s_in->sin_addr), len);
return (0); return (0);
} }
@ -424,9 +424,9 @@ static int INET_rresolve(char *name, size_t len, struct sockaddr_in *sin,
safe_strncpy(name, np->n_name, len); safe_strncpy(name, np->n_name, len);
} }
if ((ent == NULL) && (np == NULL)) if ((ent == NULL) && (np == NULL))
safe_strncpy(name, inet_ntoa(sin->sin_addr), len); safe_strncpy(name, inet_ntoa(s_in->sin_addr), len);
pn = (struct addr *) xmalloc(sizeof(struct addr)); pn = (struct addr *) xmalloc(sizeof(struct addr));
pn->addr = *sin; pn->addr = *s_in;
pn->next = INET_nn; pn->next = INET_nn;
pn->host = host; pn->host = host;
pn->name = (char *) xmalloc(strlen(name) + 1); pn->name = (char *) xmalloc(strlen(name) + 1);
@ -570,15 +570,18 @@ static struct aftype inet_aftype =
/* Display an UNSPEC address. */ /* Display an UNSPEC address. */
static char *UNSPEC_print(unsigned char *ptr) static char *UNSPEC_print(unsigned char *ptr)
{ {
static char buff[64]; static char buff[sizeof(struct sockaddr)*3+1];
char *pos; char *pos;
unsigned int i; unsigned int i;
pos = buff; pos = buff;
for (i = 0; i < sizeof(struct sockaddr); i++) { for (i = 0; i < sizeof(struct sockaddr); i++) {
pos += sprintf(pos, "%02X-", (*ptr++ & 0377)); /* careful -- not every libc's sprintf returns # bytes written */
sprintf(pos, "%02X-", (*ptr++ & 0377));
pos += 3;
} }
buff[strlen(buff) - 1] = '\0'; /* Erase trailing "-". Works as long as sizeof(struct sockaddr) != 0 */
*--pos = '\0';
return (buff); return (buff);
} }
@ -1029,17 +1032,18 @@ static int if_readconf(void)
struct ifconf ifc; struct ifconf ifc;
struct ifreq *ifr; struct ifreq *ifr;
int n, err = -1; int n, err = -1;
int skfd; /* XXX Should this re-use the global skfd? */
int skfd2;
/* SIOCGIFCONF currently seems to only work properly on AF_INET sockets /* SIOCGIFCONF currently seems to only work properly on AF_INET sockets
(as of 2.1.128) */ (as of 2.1.128) */
skfd = get_socket_for_af(AF_INET); skfd2 = get_socket_for_af(AF_INET);
if (skfd < 0) { if (skfd2 < 0) {
fprintf(stderr, _("warning: no inet socket available: %s\n"), fprintf(stderr, _("warning: no inet socket available: %s\n"),
strerror(errno)); strerror(errno));
/* Try to soldier on with whatever socket we can get hold of. */ /* Try to soldier on with whatever socket we can get hold of. */
skfd = sockets_open(0); skfd2 = sockets_open(0);
if (skfd < 0) if (skfd2 < 0)
return -1; return -1;
} }
@ -1048,7 +1052,7 @@ static int if_readconf(void)
ifc.ifc_len = sizeof(struct ifreq) * numreqs; ifc.ifc_len = sizeof(struct ifreq) * numreqs;
ifc.ifc_buf = xrealloc(ifc.ifc_buf, ifc.ifc_len); ifc.ifc_buf = xrealloc(ifc.ifc_buf, ifc.ifc_len);
if (ioctl(skfd, SIOCGIFCONF, &ifc) < 0) { if (ioctl(skfd2, SIOCGIFCONF, &ifc) < 0) {
perror("SIOCGIFCONF"); perror("SIOCGIFCONF");
goto out; goto out;
} }
@ -1466,25 +1470,10 @@ struct hwtype {
int suppress_null_addr; int suppress_null_addr;
}; };
/* Display an UNSPEC address. */
static char *pr_unspec(unsigned char *ptr)
{
static char buff[64];
char *pos;
unsigned int i;
pos = buff;
for (i = 0; i < sizeof(struct sockaddr); i++) {
pos += sprintf(pos, "%02X-", (*ptr++ & 0377));
}
buff[strlen(buff) - 1] = '\0';
return (buff);
}
static struct hwtype unspec_hwtype = static struct hwtype unspec_hwtype =
{ {
"unspec", "UNSPEC", -1, 0, "unspec", "UNSPEC", -1, 0,
pr_unspec, NULL, NULL UNSPEC_print, NULL, NULL
}; };
static struct hwtype loop_hwtype = static struct hwtype loop_hwtype =