Make ifup and ifdown individually selectable.

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
Denys Vlasenko 2016-11-14 18:31:07 +01:00
parent f417ffd88f
commit a8c696bf09
4 changed files with 127 additions and 116 deletions

View File

@ -160,10 +160,8 @@ IF_HEXDUMP(APPLET_NOEXEC(hexdump, hexdump, BB_DIR_USR_BIN, BB_SUID_DROP, hexdump
IF_HTTPD(APPLET(httpd, BB_DIR_USR_SBIN, BB_SUID_DROP)) IF_HTTPD(APPLET(httpd, BB_DIR_USR_SBIN, BB_SUID_DROP))
IF_HWCLOCK(APPLET(hwclock, BB_DIR_SBIN, BB_SUID_DROP)) IF_HWCLOCK(APPLET(hwclock, BB_DIR_SBIN, BB_SUID_DROP))
IF_IFCONFIG(APPLET(ifconfig, BB_DIR_SBIN, BB_SUID_DROP)) IF_IFCONFIG(APPLET(ifconfig, BB_DIR_SBIN, BB_SUID_DROP))
IF_IFUPDOWN(APPLET_ODDNAME(ifdown, ifupdown, BB_DIR_SBIN, BB_SUID_DROP, ifdown))
IF_IFENSLAVE(APPLET(ifenslave, BB_DIR_SBIN, BB_SUID_DROP)) IF_IFENSLAVE(APPLET(ifenslave, BB_DIR_SBIN, BB_SUID_DROP))
IF_IFPLUGD(APPLET(ifplugd, BB_DIR_USR_SBIN, BB_SUID_DROP)) IF_IFPLUGD(APPLET(ifplugd, BB_DIR_USR_SBIN, BB_SUID_DROP))
IF_IFUPDOWN(APPLET_ODDNAME(ifup, ifupdown, BB_DIR_SBIN, BB_SUID_DROP, ifup))
IF_INETD(APPLET(inetd, BB_DIR_USR_SBIN, BB_SUID_DROP)) IF_INETD(APPLET(inetd, BB_DIR_USR_SBIN, BB_SUID_DROP))
IF_INOTIFYD(APPLET(inotifyd, BB_DIR_SBIN, BB_SUID_DROP)) IF_INOTIFYD(APPLET(inotifyd, BB_DIR_SBIN, BB_SUID_DROP))
IF_INSTALL(APPLET(install, BB_DIR_USR_BIN, BB_SUID_DROP)) IF_INSTALL(APPLET(install, BB_DIR_USR_BIN, BB_SUID_DROP))

View File

@ -342,111 +342,6 @@ config IFPLUGD
help help
Network interface plug detection daemon. Network interface plug detection daemon.
config IFUPDOWN
bool "ifupdown"
default y
help
Activate or deactivate the specified interfaces. This applet makes
use of either "ifconfig" and "route" or the "ip" command to actually
configure network interfaces. Therefore, you will probably also want
to enable either IFCONFIG and ROUTE, or enable
FEATURE_IFUPDOWN_IP and the various IP options. Of
course you could use non-busybox versions of these programs, so
against my better judgement (since this will surely result in plenty
of support questions on the mailing list), I do not force you to
enable these additional options. It is up to you to supply either
"ifconfig", "route" and "run-parts" or the "ip" command, either
via busybox or via standalone utilities.
config IFUPDOWN_IFSTATE_PATH
string "Absolute path to ifstate file"
default "/var/run/ifstate"
depends on IFUPDOWN
help
ifupdown keeps state information in a file called ifstate.
Typically it is located in /var/run/ifstate, however
some distributions tend to put it in other places
(debian, for example, uses /etc/network/run/ifstate).
This config option defines location of ifstate.
config FEATURE_IFUPDOWN_IP
bool "Use ip applet"
default y
depends on IFUPDOWN
help
Use the iproute "ip" command to implement "ifup" and "ifdown", rather
than the default of using the older 'ifconfig' and 'route' utilities.
config FEATURE_IFUPDOWN_IP_BUILTIN
bool "Use busybox ip applet"
default y
depends on FEATURE_IFUPDOWN_IP
select PLATFORM_LINUX
select IP
select FEATURE_IP_ADDRESS
select FEATURE_IP_LINK
select FEATURE_IP_ROUTE
help
Use the busybox iproute "ip" applet to implement "ifupdown".
If left disabled, you must install the full-blown iproute2
utility or the "ifup" and "ifdown" applets will not work.
config FEATURE_IFUPDOWN_IFCONFIG_BUILTIN
bool "Use busybox ifconfig and route applets"
default n
depends on IFUPDOWN && !FEATURE_IFUPDOWN_IP
select IFCONFIG
select ROUTE
help
Use the busybox iproute "ifconfig" and "route" applets to
implement the "ifup" and "ifdown" utilities.
If left disabled, you must install the full-blown ifconfig
and route utilities, or the "ifup" and "ifdown" applets will not
work.
config FEATURE_IFUPDOWN_IPV4
bool "Support for IPv4"
default y
depends on IFUPDOWN
help
If you want ifup/ifdown to talk IPv4, leave this on.
config FEATURE_IFUPDOWN_IPV6
bool "Support for IPv6"
default y
depends on IFUPDOWN && FEATURE_IPV6
help
If you need support for IPv6, turn this option on.
### UNUSED
###config FEATURE_IFUPDOWN_IPX
### bool "Support for IPX"
### default y
### depends on IFUPDOWN
### help
### If this option is selected you can use busybox to work with IPX
### networks.
config FEATURE_IFUPDOWN_MAPPING
bool "Enable mapping support"
default y
depends on IFUPDOWN
help
This enables support for the "mapping" stanza, unless you have
a weird network setup you don't need it.
config FEATURE_IFUPDOWN_EXTERNAL_DHCP
bool "Support for external dhcp clients"
default n
depends on IFUPDOWN
help
This enables support for the external dhcp clients. Clients are
tried in the following order: dhcpcd, dhclient, pump and udhcpc.
Otherwise, if udhcpc applet is enabled, it is used.
Otherwise, ifup/ifdown will have no support for DHCP.
config INETD config INETD
bool "inetd" bool "inetd"
default y default y

View File

@ -20,7 +20,6 @@ lib-$(CONFIG_HTTPD) += httpd.o
lib-$(CONFIG_IFCONFIG) += ifconfig.o interface.o lib-$(CONFIG_IFCONFIG) += ifconfig.o interface.o
lib-$(CONFIG_IFENSLAVE) += ifenslave.o interface.o lib-$(CONFIG_IFENSLAVE) += ifenslave.o interface.o
lib-$(CONFIG_IFPLUGD) += ifplugd.o lib-$(CONFIG_IFPLUGD) += ifplugd.o
lib-$(CONFIG_IFUPDOWN) += ifupdown.o
lib-$(CONFIG_INETD) += inetd.o lib-$(CONFIG_INETD) += inetd.o
lib-$(CONFIG_IP) += ip.o lib-$(CONFIG_IP) += ip.o
lib-$(CONFIG_IPCALC) += ipcalc.o lib-$(CONFIG_IPCALC) += ipcalc.o

View File

@ -1,6 +1,6 @@
/* vi: set sw=4 ts=4: */ /* vi: set sw=4 ts=4: */
/* /*
* ifupdown for busybox * ifup/ifdown for busybox
* Copyright (c) 2002 Glenn McGrath * Copyright (c) 2002 Glenn McGrath
* Copyright (c) 2003-2004 Erik Andersen <andersen@codepoet.org> * Copyright (c) 2003-2004 Erik Andersen <andersen@codepoet.org>
* *
@ -17,10 +17,127 @@
* Licensed under GPLv2 or later, see file LICENSE in this source tree. * Licensed under GPLv2 or later, see file LICENSE in this source tree.
*/ */
//config:config IFUP
//config: bool "ifup"
//config: default y
//config: help
//config: Activate the specified interfaces. This applet makes use
//config: of either "ifconfig" and "route" or the "ip" command to actually
//config: configure network interfaces. Therefore, you will probably also want
//config: to enable either IFCONFIG and ROUTE, or enable
//config: FEATURE_IFUPDOWN_IP and the various IP options. Of
//config: course you could use non-busybox versions of these programs, so
//config: against my better judgement (since this will surely result in plenty
//config: of support questions on the mailing list), I do not force you to
//config: enable these additional options. It is up to you to supply either
//config: "ifconfig", "route" and "run-parts" or the "ip" command, either
//config: via busybox or via standalone utilities.
//config:
//config:config IFDOWN
//config: bool "ifdown"
//config: default y
//config: help
//config: Deactivate the specified interfaces.
//config:
//config:config IFUPDOWN_IFSTATE_PATH
//config: string "Absolute path to ifstate file"
//config: default "/var/run/ifstate"
//config: depends on IFUP || IFDOWN
//config: help
//config: ifupdown keeps state information in a file called ifstate.
//config: Typically it is located in /var/run/ifstate, however
//config: some distributions tend to put it in other places
//config: (debian, for example, uses /etc/network/run/ifstate).
//config: This config option defines location of ifstate.
//config:
//config:config FEATURE_IFUPDOWN_IP
//config: bool "Use ip applet"
//config: default y
//config: depends on IFUP || IFDOWN
//config: help
//config: Use the iproute "ip" command to implement "ifup" and "ifdown", rather
//config: than the default of using the older 'ifconfig' and 'route' utilities.
//config:
//config:config FEATURE_IFUPDOWN_IP_BUILTIN
//config: bool "Use busybox ip applet"
//config: default y
//config: depends on FEATURE_IFUPDOWN_IP
//config: select PLATFORM_LINUX
//config: select IP
//config: select FEATURE_IP_ADDRESS
//config: select FEATURE_IP_LINK
//config: select FEATURE_IP_ROUTE
//config: help
//config: Use the busybox iproute "ip" applet to implement "ifupdown".
//config:
//config: If left disabled, you must install the full-blown iproute2
//config: utility or the "ifup" and "ifdown" applets will not work.
//config:
//config:config FEATURE_IFUPDOWN_IFCONFIG_BUILTIN
//config: bool "Use busybox ifconfig and route applets"
//config: default n
//config: depends on (IFUP || IFDOWN) && !FEATURE_IFUPDOWN_IP
//config: select IFCONFIG
//config: select ROUTE
//config: help
//config: Use the busybox iproute "ifconfig" and "route" applets to
//config: implement the "ifup" and "ifdown" utilities.
//config:
//config: If left disabled, you must install the full-blown ifconfig
//config: and route utilities, or the "ifup" and "ifdown" applets will not
//config: work.
//config:
//config:config FEATURE_IFUPDOWN_IPV4
//config: bool "Support for IPv4"
//config: default y
//config: depends on IFUP || IFDOWN
//config: help
//config: If you want ifup/ifdown to talk IPv4, leave this on.
//config:
//config:config FEATURE_IFUPDOWN_IPV6
//config: bool "Support for IPv6"
//config: default y
//config: depends on (IFUP || IFDOWN) && FEATURE_IPV6
//config: help
//config: If you need support for IPv6, turn this option on.
//config:
//UNUSED:
////////:config FEATURE_IFUPDOWN_IPX
////////: bool "Support for IPX"
////////: default y
////////: depends on IFUP || IFDOWN
////////: help
////////: If this option is selected you can use busybox to work with IPX
////////: networks.
//config:
//config:config FEATURE_IFUPDOWN_MAPPING
//config: bool "Enable mapping support"
//config: default y
//config: depends on IFUP || IFDOWN
//config: help
//config: This enables support for the "mapping" stanza, unless you have
//config: a weird network setup you don't need it.
//config:
//config:config FEATURE_IFUPDOWN_EXTERNAL_DHCP
//config: bool "Support for external dhcp clients"
//config: default n
//config: depends on IFUP || IFDOWN
//config: help
//config: This enables support for the external dhcp clients. Clients are
//config: tried in the following order: dhcpcd, dhclient, pump and udhcpc.
//config: Otherwise, if udhcpc applet is enabled, it is used.
//config: Otherwise, ifup/ifdown will have no support for DHCP.
//applet:IF_IFUP(APPLET_ODDNAME(ifup, ifupdown, BB_DIR_SBIN, BB_SUID_DROP, ifup))
//applet:IF_IFDOWN(APPLET_ODDNAME(ifdown, ifupdown, BB_DIR_SBIN, BB_SUID_DROP, ifdown))
//kbuild:lib-$(CONFIG_IFUP) += ifupdown.o
//kbuild:lib-$(CONFIG_IFDOWN) += ifupdown.o
//usage:#define ifup_trivial_usage //usage:#define ifup_trivial_usage
//usage: "[-an"IF_FEATURE_IFUPDOWN_MAPPING("m")"vf] [-i FILE] IFACE..." //usage: "[-an"IF_FEATURE_IFUPDOWN_MAPPING("m")"vf] [-i FILE] IFACE..."
//usage:#define ifup_full_usage "\n\n" //usage:#define ifup_full_usage "\n\n"
//usage: " -a De/configure all interfaces automatically" //usage: " -a Configure all interfaces"
//usage: "\n -i FILE Use FILE instead of /etc/network/interfaces" //usage: "\n -i FILE Use FILE instead of /etc/network/interfaces"
//usage: "\n -n Print out what would happen, but don't do it" //usage: "\n -n Print out what would happen, but don't do it"
//usage: IF_FEATURE_IFUPDOWN_MAPPING( //usage: IF_FEATURE_IFUPDOWN_MAPPING(
@ -28,12 +145,12 @@
//usage: "\n -m Don't run any mappings" //usage: "\n -m Don't run any mappings"
//usage: ) //usage: )
//usage: "\n -v Print out what would happen before doing it" //usage: "\n -v Print out what would happen before doing it"
//usage: "\n -f Force de/configuration" //usage: "\n -f Force configuration"
//usage: //usage:
//usage:#define ifdown_trivial_usage //usage:#define ifdown_trivial_usage
//usage: "[-an"IF_FEATURE_IFUPDOWN_MAPPING("m")"vf] [-i FILE] IFACE..." //usage: "[-an"IF_FEATURE_IFUPDOWN_MAPPING("m")"vf] [-i FILE] IFACE..."
//usage:#define ifdown_full_usage "\n\n" //usage:#define ifdown_full_usage "\n\n"
//usage: " -a De/configure all interfaces automatically" //usage: " -a Deconfigure all interfaces"
//usage: "\n -i FILE Use FILE for interface definitions" //usage: "\n -i FILE Use FILE for interface definitions"
//usage: "\n -n Print out what would happen, but don't do it" //usage: "\n -n Print out what would happen, but don't do it"
//usage: IF_FEATURE_IFUPDOWN_MAPPING( //usage: IF_FEATURE_IFUPDOWN_MAPPING(
@ -41,7 +158,7 @@
//usage: "\n -m Don't run any mappings" //usage: "\n -m Don't run any mappings"
//usage: ) //usage: )
//usage: "\n -v Print out what would happen before doing it" //usage: "\n -v Print out what would happen before doing it"
//usage: "\n -f Force de/configuration" //usage: "\n -f Force deconfiguration"
#include "libbb.h" #include "libbb.h"
#include "common_bufsiz.h" #include "common_bufsiz.h"
@ -1248,7 +1365,6 @@ static FILE *open_new_state_file(void)
return xfdopen_for_write(fd); return xfdopen_for_write(fd);
} }
int ifupdown_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; int ifupdown_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
int ifupdown_main(int argc UNUSED_PARAM, char **argv) int ifupdown_main(int argc UNUSED_PARAM, char **argv)
{ {
@ -1263,10 +1379,13 @@ int ifupdown_main(int argc UNUSED_PARAM, char **argv)
G.startup_PATH = getenv("PATH"); G.startup_PATH = getenv("PATH");
G.shell = xstrdup(get_shell_name()); G.shell = xstrdup(get_shell_name());
cmds = iface_down; if (ENABLE_IFUP
if (applet_name[2] == 'u') { && (!ENABLE_IFDOWN || applet_name[2] == 'u')
) {
/* ifup command */ /* ifup command */
cmds = iface_up; cmds = iface_up;
} else {
cmds = iface_down;
} }
getopt32(argv, OPTION_STR, &interfaces); getopt32(argv, OPTION_STR, &interfaces);