Statistics
| Branch: | Tag: | Revision:

root / tools / net-common.in @ 4fe43605

History | View | Annotate | Download (2.8 kB)

1 4855760b Dimitris Aragiorgis
#!/bin/bash
2 4855760b Dimitris Aragiorgis
#
3 4855760b Dimitris Aragiorgis
4 4855760b Dimitris Aragiorgis
# Copyright (C) 2011, 2012, 2013 Google Inc.
5 4855760b Dimitris Aragiorgis
#
6 4855760b Dimitris Aragiorgis
# This program is free software; you can redistribute it and/or modify
7 4855760b Dimitris Aragiorgis
# it under the terms of the GNU General Public License as published by
8 4855760b Dimitris Aragiorgis
# the Free Software Foundation; either version 2 of the License, or
9 4855760b Dimitris Aragiorgis
# (at your option) any later version.
10 4855760b Dimitris Aragiorgis
#
11 4855760b Dimitris Aragiorgis
# This program is distributed in the hope that it will be useful, but
12 4855760b Dimitris Aragiorgis
# WITHOUT ANY WARRANTY; without even the implied warranty of
13 4855760b Dimitris Aragiorgis
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 4855760b Dimitris Aragiorgis
# General Public License for more details.
15 4855760b Dimitris Aragiorgis
#
16 4855760b Dimitris Aragiorgis
# You should have received a copy of the GNU General Public License
17 4855760b Dimitris Aragiorgis
# along with this program; if not, write to the Free Software
18 4855760b Dimitris Aragiorgis
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 4855760b Dimitris Aragiorgis
# 02110-1301, USA.
20 4855760b Dimitris Aragiorgis
21 4855760b Dimitris Aragiorgis
@SHELL_ENV_INIT@
22 4855760b Dimitris Aragiorgis
23 dc1fe8df Jose A. Lopes
readonly GANETI_TAP="gnt.com"
24 4855760b Dimitris Aragiorgis
25 dc1fe8df Jose A. Lopes
function check {
26 4855760b Dimitris Aragiorgis
  if [ -z "$INTERFACE" ]; then
27 4855760b Dimitris Aragiorgis
    echo "No network interface specified"
28 4855760b Dimitris Aragiorgis
    exit 1
29 4855760b Dimitris Aragiorgis
  fi
30 4855760b Dimitris Aragiorgis
31 4855760b Dimitris Aragiorgis
  if [ -z "$MODE" ]; then
32 4855760b Dimitris Aragiorgis
    echo "MODE not specified"
33 4855760b Dimitris Aragiorgis
    exit 1
34 4855760b Dimitris Aragiorgis
  fi
35 dc1fe8df Jose A. Lopes
}
36 4855760b Dimitris Aragiorgis
37 dc1fe8df Jose A. Lopes
function is_instance_communication_tap {
38 dc1fe8df Jose A. Lopes
  COMMUNICATION=$(echo "$INTERFACE" | cut -d "." -f 1-2)
39 dc1fe8df Jose A. Lopes
40 dc1fe8df Jose A. Lopes
  if [ "$MODE" = "routed" -a "$COMMUNICATION" = "$GANETI_TAP" ]
41 dc1fe8df Jose A. Lopes
  then
42 dc1fe8df Jose A. Lopes
    return 0
43 dc1fe8df Jose A. Lopes
  else
44 dc1fe8df Jose A. Lopes
    return 1
45 dc1fe8df Jose A. Lopes
  fi
46 4855760b Dimitris Aragiorgis
}
47 4855760b Dimitris Aragiorgis
48 4855760b Dimitris Aragiorgis
function fix_mac {
49 4855760b Dimitris Aragiorgis
  # Fix the autogenerated MAC to have the first octet set to "fe"
50 4855760b Dimitris Aragiorgis
  # to discourage the bridge from using the TAP dev's MAC
51 4855760b Dimitris Aragiorgis
  FIXED_MAC=$(ip link show $INTERFACE | \
52 4855760b Dimitris Aragiorgis
    awk '{if ($1 == "link/ether") printf("fe%s",substr($2,3,15))}')
53 4855760b Dimitris Aragiorgis
  # in case of a vif (xen_netback device) this action is not allowed
54 4855760b Dimitris Aragiorgis
  ip link set $INTERFACE address $FIXED_MAC || true
55 4855760b Dimitris Aragiorgis
}
56 4855760b Dimitris Aragiorgis
57 4855760b Dimitris Aragiorgis
function setup_bridge {
58 4855760b Dimitris Aragiorgis
  if [ "$MODE" = "bridged" ]; then
59 4855760b Dimitris Aragiorgis
    fix_mac
60 4855760b Dimitris Aragiorgis
    ip link set $INTERFACE up
61 e46de62a Sebastian Gebhard
    ip link set $INTERFACE mtu $(</sys/class/net/${LINK}/mtu)
62 4855760b Dimitris Aragiorgis
63 4855760b Dimitris Aragiorgis
    # Connect the interface to the bridge
64 e46de62a Sebastian Gebhard
    brctl addif $LINK $INTERFACE
65 4855760b Dimitris Aragiorgis
  fi
66 4855760b Dimitris Aragiorgis
}
67 4855760b Dimitris Aragiorgis
68 4855760b Dimitris Aragiorgis
function setup_ovs {
69 4855760b Dimitris Aragiorgis
  if [ "$MODE" = "openvswitch" ]; then
70 4855760b Dimitris Aragiorgis
    ovs-vsctl add-port ${LINK} $INTERFACE
71 4855760b Dimitris Aragiorgis
  fi
72 4855760b Dimitris Aragiorgis
}
73 4855760b Dimitris Aragiorgis
74 4855760b Dimitris Aragiorgis
function setup_route {
75 49c60905 Dimitris Aragiorgis
  if [ "$MODE" = "routed" ]; then
76 4855760b Dimitris Aragiorgis
    ip link set $INTERFACE up
77 4855760b Dimitris Aragiorgis
78 4855760b Dimitris Aragiorgis
    if [ -z "$IP" ]; then
79 4855760b Dimitris Aragiorgis
      echo "Routed NIC but no IP address specified"
80 4855760b Dimitris Aragiorgis
      exit 1
81 4855760b Dimitris Aragiorgis
    fi
82 4855760b Dimitris Aragiorgis
83 4855760b Dimitris Aragiorgis
    # Route traffic targeted at the IP to the interface
84 4855760b Dimitris Aragiorgis
    if [ -n "$LINK" ]; then
85 4855760b Dimitris Aragiorgis
      while ip rule del dev $INTERFACE; do :; done
86 4855760b Dimitris Aragiorgis
      ip rule add dev $INTERFACE table $LINK
87 4855760b Dimitris Aragiorgis
      ip route replace $IP table $LINK proto static dev $INTERFACE
88 4855760b Dimitris Aragiorgis
89 4855760b Dimitris Aragiorgis
    else
90 4855760b Dimitris Aragiorgis
      ip route replace $IP proto static dev $INTERFACE
91 4855760b Dimitris Aragiorgis
    fi
92 4855760b Dimitris Aragiorgis
93 4855760b Dimitris Aragiorgis
    # Allow routing and arp proxying, or ndp proxying (IPv6)
94 4855760b Dimitris Aragiorgis
    if [ -d "/proc/sys/net/ipv4/conf/$INTERFACE" ]; then
95 4855760b Dimitris Aragiorgis
      echo 1 > /proc/sys/net/ipv4/conf/$INTERFACE/proxy_arp
96 4855760b Dimitris Aragiorgis
      echo 1 > /proc/sys/net/ipv4/conf/$INTERFACE/forwarding
97 4855760b Dimitris Aragiorgis
    fi
98 4855760b Dimitris Aragiorgis
99 4855760b Dimitris Aragiorgis
    if [ -d "/proc/sys/net/ipv6/conf/$INTERFACE" ]; then
100 4855760b Dimitris Aragiorgis
      echo 1 > /proc/sys/net/ipv6/conf/$INTERFACE/proxy_ndp
101 4855760b Dimitris Aragiorgis
      echo 1 > /proc/sys/net/ipv6/conf/$INTERFACE/forwarding
102 4855760b Dimitris Aragiorgis
    fi
103 4855760b Dimitris Aragiorgis
  fi
104 4855760b Dimitris Aragiorgis
}