Patch from Lars Kellogg-Stedman:

I'm building BusyBox using a development kit for MontaVista Hardhat Linux
(PPC) -- which, at least in this instance, is based around kernel 2.2.14.
I've had to massage a few files in networking/libiproute/ to make it
compile.  Specifically:

  (1) Added a #include <sys/uio.h> for the iovec structure in
      libnetlink.c,

  (2) Put ifdefs in ll_types.c and ll_proto.c around various
      constants (ETH_P_xxx and ARPHRD_xxx) that weren't defined,

  (3) Make do_changename() in iplink.c require a kernel >=
      2.4.0 -- the ifr structure in my environment doesn't
      have the ifr_name attribute.  I've assumed this is
      a kernel dependency -- let me know if I ought to be
      checking something else.

      In the absence of the correct kernel, do_changename()
      always returns 0.

Attached is a patch against the current CVS that will make these changes.

-- Lars
This commit is contained in:
Eric Andersen 2003-06-20 09:05:00 +00:00
parent 8876fb2f59
commit 0f08e53535
4 changed files with 22 additions and 0 deletions

View File

@ -12,6 +12,7 @@
#include <sys/ioctl.h> #include <sys/ioctl.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <linux/version.h>
#include <errno.h> #include <errno.h>
#include <stdlib.h> #include <stdlib.h>
@ -95,6 +96,7 @@ static int do_chflags(char *dev, __u32 flags, __u32 mask)
static int do_changename(char *dev, char *newdev) static int do_changename(char *dev, char *newdev)
{ {
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 4, 0)
struct ifreq ifr; struct ifreq ifr;
int fd; int fd;
int err; int err;
@ -112,6 +114,8 @@ static int do_changename(char *dev, char *newdev)
} }
close(fd); close(fd);
return err; return err;
#endif
return 0;
} }
static int set_qlen(char *dev, int qlen) static int set_qlen(char *dev, int qlen)

View File

@ -18,6 +18,8 @@
#include <time.h> #include <time.h>
#include <unistd.h> #include <unistd.h>
#include <sys/uio.h>
#include "libnetlink.h" #include "libnetlink.h"
#include "libbb.h" #include "libbb.h"

View File

@ -51,10 +51,18 @@ __PF(ATALK,atalk)
__PF(AARP,aarp) __PF(AARP,aarp)
__PF(IPX,ipx) __PF(IPX,ipx)
__PF(IPV6,ipv6) __PF(IPV6,ipv6)
#ifdef ETH_P_PPP_DISC
__PF(PPP_DISC,ppp_disc) __PF(PPP_DISC,ppp_disc)
#endif
#ifdef ETH_P_PPP_SES
__PF(PPP_SES,ppp_ses) __PF(PPP_SES,ppp_ses)
#endif
#ifdef ETH_P_ATMMPOA
__PF(ATMMPOA,atmmpoa) __PF(ATMMPOA,atmmpoa)
#endif
#ifdef ETH_P_ATMFATE
__PF(ATMFATE,atmfate) __PF(ATMFATE,atmfate)
#endif
__PF(802_3,802_3) __PF(802_3,802_3)
__PF(AX25,ax25) __PF(AX25,ax25)
@ -70,7 +78,9 @@ __PF(TR_802_2,tr_802_2)
__PF(MOBITEX,mobitex) __PF(MOBITEX,mobitex)
__PF(CONTROL,control) __PF(CONTROL,control)
__PF(IRDA,irda) __PF(IRDA,irda)
#ifdef ETH_P_ECONET
__PF(ECONET,econet) __PF(ECONET,econet)
#endif
{ 0x8100, "802.1Q" }, { 0x8100, "802.1Q" },
{ ETH_P_IP, "ipv4" }, { ETH_P_IP, "ipv4" },

View File

@ -34,7 +34,9 @@ __PF(IEEE802,tr)
__PF(ARCNET,arcnet) __PF(ARCNET,arcnet)
__PF(APPLETLK,atalk) __PF(APPLETLK,atalk)
__PF(DLCI,dlci) __PF(DLCI,dlci)
#ifdef ARPHRD_ATM
__PF(ATM,atm) __PF(ATM,atm)
#endif
__PF(METRICOM,metricom) __PF(METRICOM,metricom)
#ifdef ARPHRD_IEEE1394 #ifdef ARPHRD_IEEE1394
__PF(IEEE1394,ieee1394) __PF(IEEE1394,ieee1394)
@ -48,12 +50,16 @@ __PF(RSRVD,rsrvd)
__PF(ADAPT,adapt) __PF(ADAPT,adapt)
__PF(ROSE,rose) __PF(ROSE,rose)
__PF(X25,x25) __PF(X25,x25)
#ifdef ARPHRD_HWX25
__PF(HWX25,hwx25) __PF(HWX25,hwx25)
#endif
__PF(PPP,ppp) __PF(PPP,ppp)
__PF(HDLC,hdlc) __PF(HDLC,hdlc)
__PF(LAPB,lapb) __PF(LAPB,lapb)
#ifdef ARPHRD_DDCMP
__PF(DDCMP,ddcmp) __PF(DDCMP,ddcmp)
__PF(RAWHDLC,rawhdlc) __PF(RAWHDLC,rawhdlc)
#endif
__PF(TUNNEL,ipip) __PF(TUNNEL,ipip)
__PF(TUNNEL6,tunnel6) __PF(TUNNEL6,tunnel6)