Statistics
| Branch: | Tag: | Revision:

root / tools / net-common.in @ 1fe10404

History | View | Annotate | Download (2.6 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 4855760b Dimitris Aragiorgis
function check {
24 4855760b Dimitris Aragiorgis
25 4855760b Dimitris Aragiorgis
  if [ -z "$INTERFACE" ]; then
26 4855760b Dimitris Aragiorgis
    echo "No network interface specified"
27 4855760b Dimitris Aragiorgis
    exit 1
28 4855760b Dimitris Aragiorgis
  fi
29 4855760b Dimitris Aragiorgis
30 4855760b Dimitris Aragiorgis
  if [ -z "$MODE" ]; then
31 4855760b Dimitris Aragiorgis
    echo "MODE not specified"
32 4855760b Dimitris Aragiorgis
    exit 1
33 4855760b Dimitris Aragiorgis
  fi
34 4855760b Dimitris Aragiorgis
35 4855760b Dimitris Aragiorgis
}
36 4855760b Dimitris Aragiorgis
37 4855760b Dimitris Aragiorgis
function fix_mac {
38 4855760b Dimitris Aragiorgis
39 4855760b Dimitris Aragiorgis
  # Fix the autogenerated MAC to have the first octet set to "fe"
40 4855760b Dimitris Aragiorgis
  # to discourage the bridge from using the TAP dev's MAC
41 4855760b Dimitris Aragiorgis
  FIXED_MAC=$(ip link show $INTERFACE | \
42 4855760b Dimitris Aragiorgis
    awk '{if ($1 == "link/ether") printf("fe%s",substr($2,3,15))}')
43 4855760b Dimitris Aragiorgis
  # in case of a vif (xen_netback device) this action is not allowed
44 4855760b Dimitris Aragiorgis
  ip link set $INTERFACE address $FIXED_MAC || true
45 4855760b Dimitris Aragiorgis
46 4855760b Dimitris Aragiorgis
}
47 4855760b Dimitris Aragiorgis
48 4855760b Dimitris Aragiorgis
function setup_bridge {
49 4855760b Dimitris Aragiorgis
50 4855760b Dimitris Aragiorgis
  if [ "$MODE" = "bridged" ]; then
51 4855760b Dimitris Aragiorgis
    fix_mac
52 4855760b Dimitris Aragiorgis
    ip link set $INTERFACE up
53 4855760b Dimitris Aragiorgis
    ip link set $INTERFACE mtu $(</sys/class/net/${BRIDGE}/mtu)
54 4855760b Dimitris Aragiorgis
55 4855760b Dimitris Aragiorgis
    # Connect the interface to the bridge
56 4855760b Dimitris Aragiorgis
    brctl addif $BRIDGE $INTERFACE
57 4855760b Dimitris Aragiorgis
  fi
58 4855760b Dimitris Aragiorgis
59 4855760b Dimitris Aragiorgis
}
60 4855760b Dimitris Aragiorgis
61 4855760b Dimitris Aragiorgis
function setup_ovs {
62 4855760b Dimitris Aragiorgis
  if [ "$MODE" = "openvswitch" ]; then
63 4855760b Dimitris Aragiorgis
    ovs-vsctl add-port ${LINK} $INTERFACE
64 4855760b Dimitris Aragiorgis
  fi
65 4855760b Dimitris Aragiorgis
}
66 4855760b Dimitris Aragiorgis
67 4855760b Dimitris Aragiorgis
function setup_route {
68 4855760b Dimitris Aragiorgis
  if [ "$MODE" = "openvswitch" ]; then
69 4855760b Dimitris Aragiorgis
    ip link set $INTERFACE up
70 4855760b Dimitris Aragiorgis
71 4855760b Dimitris Aragiorgis
    if [ -z "$IP" ]; then
72 4855760b Dimitris Aragiorgis
      echo "Routed NIC but no IP address specified"
73 4855760b Dimitris Aragiorgis
      exit 1
74 4855760b Dimitris Aragiorgis
    fi
75 4855760b Dimitris Aragiorgis
76 4855760b Dimitris Aragiorgis
    # Route traffic targeted at the IP to the interface
77 4855760b Dimitris Aragiorgis
    if [ -n "$LINK" ]; then
78 4855760b Dimitris Aragiorgis
      while ip rule del dev $INTERFACE; do :; done
79 4855760b Dimitris Aragiorgis
      ip rule add dev $INTERFACE table $LINK
80 4855760b Dimitris Aragiorgis
      ip route replace $IP table $LINK proto static dev $INTERFACE
81 4855760b Dimitris Aragiorgis
82 4855760b Dimitris Aragiorgis
    else
83 4855760b Dimitris Aragiorgis
      ip route replace $IP proto static dev $INTERFACE
84 4855760b Dimitris Aragiorgis
    fi
85 4855760b Dimitris Aragiorgis
86 4855760b Dimitris Aragiorgis
    # Allow routing and arp proxying, or ndp proxying (IPv6)
87 4855760b Dimitris Aragiorgis
    if [ -d "/proc/sys/net/ipv4/conf/$INTERFACE" ]; then
88 4855760b Dimitris Aragiorgis
      echo 1 > /proc/sys/net/ipv4/conf/$INTERFACE/proxy_arp
89 4855760b Dimitris Aragiorgis
      echo 1 > /proc/sys/net/ipv4/conf/$INTERFACE/forwarding
90 4855760b Dimitris Aragiorgis
    fi
91 4855760b Dimitris Aragiorgis
92 4855760b Dimitris Aragiorgis
    if [ -d "/proc/sys/net/ipv6/conf/$INTERFACE" ]; then
93 4855760b Dimitris Aragiorgis
      echo 1 > /proc/sys/net/ipv6/conf/$INTERFACE/proxy_ndp
94 4855760b Dimitris Aragiorgis
      echo 1 > /proc/sys/net/ipv6/conf/$INTERFACE/forwarding
95 4855760b Dimitris Aragiorgis
    fi
96 4855760b Dimitris Aragiorgis
  fi
97 4855760b Dimitris Aragiorgis
}