| Sean Dague | e263c82 | 2014-12-05 14:25:28 -0500 | [diff] [blame] | 1 | #!/bin/bash | 
|  | 2 | # | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 3 | # common functions for ovs based plugin | 
|  | 4 | # ------------------------------------- | 
|  | 5 |  | 
|  | 6 | # Save trace setting | 
| Ian Wienand | 523f488 | 2015-10-13 11:03:03 +1100 | [diff] [blame] | 7 | _XTRACE_NEUTRON_OVS_BASE=$(set +o | grep xtrace) | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 8 | set +o xtrace | 
|  | 9 |  | 
| JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 10 | OVS_BRIDGE=${OVS_BRIDGE:-br-int} | 
| Michal Ptacek | c160555 | 2015-09-23 21:02:02 +0100 | [diff] [blame] | 11 | # OVS recognize default 'system' datapath or 'netdev' for userspace datapath | 
|  | 12 | OVS_DATAPATH_TYPE=${OVS_DATAPATH_TYPE:-system} | 
| Hirofumi Ichihara | d48d672 | 2015-07-04 22:58:44 +0900 | [diff] [blame] | 13 | OVS_TUNNEL_BRIDGE=${OVS_TUNNEL_BRIDGE:-br-tun} | 
| JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 14 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 15 | function is_neutron_ovs_base_plugin { | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 16 | # Yes, we use OVS. | 
|  | 17 | return 0 | 
|  | 18 | } | 
|  | 19 |  | 
| Waldemar Znoinski | d4c8928 | 2015-05-07 17:14:21 +0100 | [diff] [blame] | 20 | function _neutron_ovs_base_add_bridge { | 
|  | 21 | local bridge=$1 | 
|  | 22 | local addbr_cmd="sudo ovs-vsctl --no-wait -- --may-exist add-br $bridge" | 
|  | 23 |  | 
| Michal Ptacek | c160555 | 2015-09-23 21:02:02 +0100 | [diff] [blame] | 24 | if [ "$OVS_DATAPATH_TYPE" != "system" ] ; then | 
| Waldemar Znoinski | d4c8928 | 2015-05-07 17:14:21 +0100 | [diff] [blame] | 25 | addbr_cmd="$addbr_cmd -- set Bridge $bridge datapath_type=${OVS_DATAPATH_TYPE}" | 
|  | 26 | fi | 
|  | 27 |  | 
|  | 28 | $addbr_cmd | 
|  | 29 | } | 
|  | 30 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 31 | function _neutron_ovs_base_setup_bridge { | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 32 | local bridge=$1 | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 33 | neutron-ovs-cleanup | 
| Waldemar Znoinski | d4c8928 | 2015-05-07 17:14:21 +0100 | [diff] [blame] | 34 | _neutron_ovs_base_add_bridge $bridge | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 35 | sudo ovs-vsctl --no-wait br-set-external-id $bridge bridge-id $bridge | 
|  | 36 | } | 
|  | 37 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 38 | function neutron_ovs_base_cleanup { | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 39 | # remove all OVS ports that look like Neutron created ports | 
| Zhenzan Zhou | 9a70448 | 2015-01-27 10:48:24 +0800 | [diff] [blame] | 40 | for port in $(sudo ovs-vsctl list port | grep -o -e [a-zA-Z\-]*tap[0-9a-f\-]* -e q[rg]-[0-9a-f\-]*); do | 
| JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 41 | sudo ovs-vsctl del-port ${port} | 
|  | 42 | done | 
|  | 43 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 44 | # remove all OVS bridges created by Neutron | 
| Hirofumi Ichihara | 7ab3e39 | 2015-07-04 23:11:52 +0900 | [diff] [blame] | 45 | for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${OVS_BRIDGE} -e ${PUBLIC_BRIDGE} -e ${OVS_TUNNEL_BRIDGE}); do | 
| JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 46 | sudo ovs-vsctl del-br ${bridge} | 
|  | 47 | done | 
|  | 48 | } | 
|  | 49 |  | 
| Kyle Mestery | 86af4a0 | 2014-06-24 11:07:54 +0000 | [diff] [blame] | 50 | function _neutron_ovs_base_install_ubuntu_dkms { | 
|  | 51 | # install Dynamic Kernel Module Support packages if needed | 
| Ian Wienand | ada886d | 2015-10-07 14:06:26 +1100 | [diff] [blame] | 52 | local kernel_version | 
|  | 53 | kernel_version=$(uname -r) | 
|  | 54 | local kernel_major_minor | 
|  | 55 | kernel_major_minor=`echo $kernel_version | cut -d. -f1-2` | 
| Kyle Mestery | 86af4a0 | 2014-06-24 11:07:54 +0000 | [diff] [blame] | 56 | # From kernel 3.13 on, openvswitch-datapath-dkms is not needed | 
|  | 57 | if [ `vercmp_numbers "$kernel_major_minor" "3.13"` -lt "0" ]; then | 
|  | 58 | install_package "dkms openvswitch-datapath-dkms linux-headers-$kernel_version" | 
|  | 59 | fi | 
|  | 60 | } | 
|  | 61 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 62 | function _neutron_ovs_base_install_agent_packages { | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 63 | # Install deps | 
| Kyle Mestery | 86af4a0 | 2014-06-24 11:07:54 +0000 | [diff] [blame] | 64 | install_package $(get_packages "openvswitch") | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 65 | if is_ubuntu; then | 
| Kyle Mestery | 86af4a0 | 2014-06-24 11:07:54 +0000 | [diff] [blame] | 66 | _neutron_ovs_base_install_ubuntu_dkms | 
| Sean M. Collins | d738a9e | 2014-08-28 15:32:44 -0400 | [diff] [blame] | 67 | restart_service openvswitch-switch | 
| Gary Kotton | 5452b18 | 2013-02-25 13:02:38 +0000 | [diff] [blame] | 68 | elif is_fedora; then | 
| Gary Kotton | 5452b18 | 2013-02-25 13:02:38 +0000 | [diff] [blame] | 69 | restart_service openvswitch | 
| Zhang Jinnan | 4d8c03a | 2015-08-20 10:00:20 -0400 | [diff] [blame] | 70 | sudo systemctl enable openvswitch | 
| Gary Kotton | 5452b18 | 2013-02-25 13:02:38 +0000 | [diff] [blame] | 71 | elif is_suse; then | 
| Vincent Untz | cf6d809 | 2013-07-04 09:59:34 +0200 | [diff] [blame] | 72 | restart_service openvswitch-switch | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 73 | fi | 
|  | 74 | } | 
|  | 75 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 76 | function _neutron_ovs_base_configure_debug_command { | 
| YAMAMOTO Takashi | 98a0ad4 | 2014-11-21 10:42:18 +0900 | [diff] [blame] | 77 | if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then | 
|  | 78 | iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge "" | 
|  | 79 | else | 
|  | 80 | iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE | 
|  | 81 | fi | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 82 | } | 
|  | 83 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 84 | function _neutron_ovs_base_configure_firewall_driver { | 
| Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 85 | if [[ "$Q_USE_SECGROUP" == "True" ]]; then | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 86 | iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver | 
| Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 87 | else | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 88 | iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver | 
| Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 89 | fi | 
|  | 90 | } | 
|  | 91 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 92 | function _neutron_ovs_base_configure_l3_agent { | 
| YAMAMOTO Takashi | 6a633fd | 2014-07-23 12:02:18 +0900 | [diff] [blame] | 93 | if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then | 
|  | 94 | iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge "" | 
|  | 95 | else | 
|  | 96 | iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE | 
|  | 97 | fi | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 98 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 99 | neutron-ovs-cleanup | 
| YAMAMOTO Takashi | 0f18c23 | 2014-09-12 23:44:58 +0900 | [diff] [blame] | 100 | if [[ "$Q_USE_PUBLIC_VETH" = "True" ]]; then | 
|  | 101 | ip link show $Q_PUBLIC_VETH_INT > /dev/null 2>&1 || | 
|  | 102 | sudo ip link add $Q_PUBLIC_VETH_INT type veth \ | 
|  | 103 | peer name $Q_PUBLIC_VETH_EX | 
|  | 104 | sudo ip link set $Q_PUBLIC_VETH_INT up | 
|  | 105 | sudo ip link set $Q_PUBLIC_VETH_EX up | 
|  | 106 | sudo ip addr flush dev $Q_PUBLIC_VETH_EX | 
|  | 107 | else | 
| Waldemar Znoinski | d4c8928 | 2015-05-07 17:14:21 +0100 | [diff] [blame] | 108 | _neutron_ovs_base_add_bridge $PUBLIC_BRIDGE | 
| YAMAMOTO Takashi | 0f18c23 | 2014-09-12 23:44:58 +0900 | [diff] [blame] | 109 | sudo ovs-vsctl br-set-external-id $PUBLIC_BRIDGE bridge-id $PUBLIC_BRIDGE | 
| YAMAMOTO Takashi | 0f18c23 | 2014-09-12 23:44:58 +0900 | [diff] [blame] | 110 | fi | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 111 | } | 
|  | 112 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 113 | function _neutron_ovs_base_configure_nova_vif_driver { | 
| Aaron Rosen | 4540d00 | 2013-10-24 13:59:33 -0700 | [diff] [blame] | 114 | : | 
| Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 115 | } | 
|  | 116 |  | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 117 | # Restore xtrace | 
| Ian Wienand | 523f488 | 2015-10-13 11:03:03 +1100 | [diff] [blame] | 118 | $_XTRACE_NEUTRON_OVS_BASE |