blob: 1ab38e012f4b41caa1b26f35ecf08a873a74416d [file] [log] [blame]
#!/bin/bash
#
# Copyright (C) 2011, 2012, 2013 Google Inc.
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
# 1. Redistributions of source code must retain the above copyright notice,
# this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
# IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
# PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
@SHELL_ENV_INIT@
readonly GANETI_TAP="gnt.com"
function check {
if [ -z "$INTERFACE" ]; then
echo "No network interface specified"
exit 1
fi
if [ -z "$MODE" ]; then
echo "MODE not specified"
exit 1
fi
}
function is_instance_communication_tap {
COMMUNICATION=$(echo "$INTERFACE" | cut -d "." -f 1-2)
if [ "$MODE" = "routed" -a "$COMMUNICATION" = "$GANETI_TAP" ]
then
return 0
else
return 1
fi
}
function fix_mac {
# Fix the autogenerated MAC to have the first octet set to "fe"
# to discourage the bridge from using the TAP dev's MAC
FIXED_MAC=$(ip link show $INTERFACE | \
awk '{if ($1 == "link/ether") printf("fe%s",substr($2,3,15))}')
# in case of a vif (xen_netback device) this action is not allowed
ip link set $INTERFACE address $FIXED_MAC || true
}
function setup_bridge {
if [ "$MODE" = "bridged" ]; then
fix_mac
ip link set $INTERFACE up
ip link set $INTERFACE mtu $(</sys/class/net/${LINK}/mtu)
# Connect the interface to the bridge
brctl addif $LINK $INTERFACE
fi
}
function setup_ovs {
if [ "$MODE" = "openvswitch" ]; then
# Remove stale port
ovs-vsctl del-port $INTERFACE || true
# Bring interface up
ip link set $INTERFACE up
# Add port
ovs-vsctl add-port ${LINK} $INTERFACE
# Set up access port
# From gnt-instance man page vlan should be either .VLAN_ID or VLAN_ID
ACPORT=${VLAN%%:*} # remove any trunk info
[ -n "$ACPORT" ] && ovs-vsctl set port $INTERFACE tag=${ACPORT#.}
# Set up trunk port
# From gnt-instance man page vlan should be :VLAN_ID[:VLAN_ID2..]
TRUNKS=${VLAN#.*:} # remove any access info
[ -n "$TRUNKS" ] && ovs-vsctl set port $INTERFACE trunks=${TRUNKS//:/,}
fi
}
function setup_route {
if [ "$MODE" = "routed" ]; then
ip link set $INTERFACE up
if [ -z "$IP" ]; then
echo "Routed NIC but no IP address specified"
exit 1
fi
# Route traffic targeted at the IP to the interface
if [ -n "$LINK" ]; then
while ip rule del dev $INTERFACE; do :; done
ip rule add dev $INTERFACE table $LINK
ip route replace $IP table $LINK proto static dev $INTERFACE
else
ip route replace $IP proto static dev $INTERFACE
fi
# Allow routing and arp proxying, or ndp proxying (IPv6)
if [ -d "/proc/sys/net/ipv4/conf/$INTERFACE" ]; then
echo 1 > /proc/sys/net/ipv4/conf/$INTERFACE/proxy_arp
echo 1 > /proc/sys/net/ipv4/conf/$INTERFACE/forwarding
fi
if [ -d "/proc/sys/net/ipv6/conf/$INTERFACE" ]; then
echo 1 > /proc/sys/net/ipv6/conf/$INTERFACE/proxy_ndp
echo 1 > /proc/sys/net/ipv6/conf/$INTERFACE/forwarding
fi
fi
}