3 # Copyright (c) 2003 The FreeBSD Project. All rights reserved.
5 # Redistribution and use in source and binary forms, with or without
6 # modification, are permitted provided that the following conditions
8 # 1. Redistributions of source code must retain the above copyright
9 # notice, this list of conditions and the following disclaimer.
10 # 2. Redistributions in binary form must reproduce the above copyright
11 # notice, this list of conditions and the following disclaimer in the
12 # documentation and/or other materials provided with the distribution.
14 # THIS SOFTWARE IS PROVIDED BY THE PROJECT ``AS IS'' AND ANY EXPRESS OR
15 # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16 # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17 # IN NO EVENT SHALL THE PROJECT BE LIABLE FOR ANY DIRECT, INDIRECT,
18 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19 # NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23 # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 # $FreeBSD: src/etc/rc.d/netif,v 1.2 2003/06/29 05:34:41 mtm Exp $
26 # $DragonFly: src/etc/rc.d/netif,v 1.4 2005/11/19 21:47:32 swildner Exp $
30 # REQUIRE: atm1 ipfilter mountcritlocal serial sppp sysctl tty
36 start_cmd
="network_start"
37 stop_cmd
="network_stop"
38 cloneup_cmd
="clone_up"
39 clonedown_cmd
="clone_down"
40 extra_commands
="cloneup clonedown"
45 if [ -z "$_cmdifn" ]; then
47 # We're operating as a general network start routine.
50 # Create cloned interfaces
53 # Create IPv6<-->IPv4 tunnels
57 # Configure the interface(s).
58 network_common ifn_start verbose
61 /etc
/rc.d
/ipfilter resync
66 echo -n "Stopping network:"
68 # Deconfigure the interface(s)
69 network_common ifn_stop
73 # network_common routine verbose
74 # Common configuration subroutine for network interfaces. This
75 # routine takes all the preparatory steps needed for configuriing
76 # an interface and then calls $routine. If $verbose is specified,
77 # it will call ifconfig(8) to show, in long format, the configured
78 # interfaces. If $verbose is not given, it will simply output the
79 # configured interface(s).
86 err
"network_common(): No function name specified."
90 [ -n "$2" ] && _verbose
=yes
92 # Get a list of network interfaces. Do not include dhcp interfaces.
93 _ifn_list
="`list_net_interfaces nodhcp`"
95 # Set the scope of the command (all interfaces or just one).
97 _cooked_list
="$_ifn_list"
98 if [ -n "$_cmdifn" ]; then
99 eval _cooked_list
=\"`expr "$_ifn_list" : ".*\($_cmdifn\).*"`\"
100 if [ -z "$_cooked_list" ]; then
101 err
"No such network interface: $_cmdifn"
106 for ifn
in ${_cooked_list}; do
107 if ${_func} ${ifn} ; then
114 # Display interfaces configured by this script
116 for ifn
in ${_cooked_list}; do
117 eval showstat
=\
$showstat_${ifn}
118 if [ ! -z ${showstat} ]; then
119 if [ -n "$_verbose" ]; then
126 debug
"The following interfaces were not configured: $_fail"
135 [ -z "$ifn" ] && return 1
137 ifscript_up
${ifn} && cfg
=0
138 ifconfig_up
${ifn} && cfg
=0
139 ifalias_up
${ifn} && cfg
=0
140 ipx_up
${ifn} && cfg
=0
151 [ -z "$ifn" ] && return 1
153 ipx_down
${ifn} && cfg
=0
154 ifalias_down
${ifn} && cfg
=0
155 ifconfig_down
${ifn} && cfg
=0
156 ifscript_down
${ifn} && cfg
=0