xref: /titanic_52/usr/src/cmd/svc/milestone/net-loopback (revision 9512fe850e98fdd448c638ca63fdd92a8a510255)
1#!/sbin/sh
2#
3# CDDL HEADER START
4#
5# The contents of this file are subject to the terms of the
6# Common Development and Distribution License (the "License").
7# You may not use this file except in compliance with the License.
8#
9# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10# or http://www.opensolaris.org/os/licensing.
11# See the License for the specific language governing permissions
12# and limitations under the License.
13#
14# When distributing Covered Code, include this CDDL HEADER in each
15# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16# If applicable, add the following below this CDDL HEADER, with the
17# fields enclosed by brackets "[]" replaced with your own identifying
18# information: Portions Copyright [yyyy] [name of copyright owner]
19#
20# CDDL HEADER END
21#
22#
23# Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
24# Use is subject to license terms.
25#
26#ident	"%Z%%M%	%I%	%E% SMI"
27
28. /lib/svc/share/smf_include.sh
29
30#
31# In a zone we need this service to be up, but all of the work
32# it tries to do is irrelevant (and will actually lead to the service
33# failing if we try to do it), so just bail out.
34#
35smf_is_globalzone || exit $SMF_EXIT_OK
36
37#
38# Cause ifconfig to not automatically start in.mpathd when IPMP groups are
39# configured.  This is not strictly necessary but makes it so that in.mpathd
40# will always be started explicitly from /lib/svc/method/net-init (the
41# svc:/network/initial service), when we're sure that /usr is mounted.
42#
43SUNW_NO_MPATHD=; export SUNW_NO_MPATHD
44
45#
46# Before any interfaces are configured, we need to set the system
47# default IP forwarding behavior.  This will be the setting for
48# interfaces that don't modify the per-interface setting with the
49# router or -router ifconfig command in their /etc/hostname.<intf>
50# files.  The -F option tells routeadm to only update the forwarding
51# configuration for the system, and not dynamic routing.  We don't
52# want routing daemons started until later in the boot process (see
53# the net-init method for that).
54#
55/sbin/routeadm -u -F
56
57# IPv4 loopback
58/sbin/ifconfig lo0 plumb 127.0.0.1 up
59
60# Configure the v6 loopback if any IPv6 interfaces are configured.
61interface_names="`echo /etc/hostname6.*[0-9] 2>/dev/null`"
62if [ "$interface_names" != "/etc/hostname6.*[0-9]" ]; then
63        ORIGIFS="$IFS"
64        IFS="$IFS."
65        set -- $interface_names
66        IFS="$ORIGIFS"
67        while [ $# -ge 2 ]; do
68                shift
69                if [ $# -gt 1 -a "$2" != "/etc/hostname6" ]; then
70                        while [ $# -gt 1 -a "$1" != "/etc/hostname6" ]; do
71                                shift
72                        done
73                else
74                        inet6_list="$inet6_list $1"
75                        shift
76                fi
77        done
78fi
79
80if [ -n "$inet6_list" ]; then
81	/sbin/ifconfig lo0 inet6 plumb ::1 up
82else
83	exit $SMF_EXIT_OK
84fi
85