blob: 2997c6c25afca62fdf84d3d68ca832b4d2a61b85 [file] [log] [blame]
Sean Daguee263c822014-12-05 14:25:28 -05001#!/bin/bash
2#
Isaku Yamahata0dd34df2012-12-28 13:15:31 +09003# common functions for ovs based plugin
4# -------------------------------------
5
6# Save trace setting
Dean Troyere3a91602014-03-28 12:40:56 -05007OVSB_XTRACE=$(set +o | grep xtrace)
Isaku Yamahata0dd34df2012-12-28 13:15:31 +09008set +o xtrace
9
JordanP614202f2013-05-16 11:16:13 +020010OVS_BRIDGE=${OVS_BRIDGE:-br-int}
11PUBLIC_BRIDGE=${PUBLIC_BRIDGE:-br-ex}
James Chapmanc83cc752014-06-11 19:29:26 +010012OVS_DATAPATH_TYPE=${OVS_DATAPATH_TYPE:-""}
JordanP614202f2013-05-16 11:16:13 +020013
Ian Wienandaee18c72014-02-21 15:35:08 +110014function is_neutron_ovs_base_plugin {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090015 # Yes, we use OVS.
16 return 0
17}
18
Ian Wienandaee18c72014-02-21 15:35:08 +110019function _neutron_ovs_base_setup_bridge {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090020 local bridge=$1
Mark McClainb05c8762013-07-06 23:29:39 -040021 neutron-ovs-cleanup
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090022 sudo ovs-vsctl --no-wait -- --may-exist add-br $bridge
James Chapmanc83cc752014-06-11 19:29:26 +010023 if [[ $OVS_DATAPATH_TYPE != "" ]]; then
24 sudo ovs-vsctl set Bridge $bridge datapath_type=${OVS_DATAPATH_TYPE}
25 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090026 sudo ovs-vsctl --no-wait br-set-external-id $bridge bridge-id $bridge
27}
28
Ian Wienandaee18c72014-02-21 15:35:08 +110029function neutron_ovs_base_cleanup {
Mark McClainb05c8762013-07-06 23:29:39 -040030 # remove all OVS ports that look like Neutron created ports
Zhenzan Zhou9a704482015-01-27 10:48:24 +080031 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
JordanP614202f2013-05-16 11:16:13 +020032 sudo ovs-vsctl del-port ${port}
33 done
34
Mark McClainb05c8762013-07-06 23:29:39 -040035 # remove all OVS bridges created by Neutron
JordanP614202f2013-05-16 11:16:13 +020036 for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${OVS_BRIDGE} -e ${PUBLIC_BRIDGE}); do
37 sudo ovs-vsctl del-br ${bridge}
38 done
39}
40
Kyle Mestery86af4a02014-06-24 11:07:54 +000041function _neutron_ovs_base_install_ubuntu_dkms {
42 # install Dynamic Kernel Module Support packages if needed
43 local kernel_version=$(uname -r)
44 local kernel_major_minor=`echo $kernel_version | cut -d. -f1-2`
45 # From kernel 3.13 on, openvswitch-datapath-dkms is not needed
46 if [ `vercmp_numbers "$kernel_major_minor" "3.13"` -lt "0" ]; then
47 install_package "dkms openvswitch-datapath-dkms linux-headers-$kernel_version"
48 fi
49}
50
Ian Wienandaee18c72014-02-21 15:35:08 +110051function _neutron_ovs_base_install_agent_packages {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090052 # Install deps
Kyle Mestery86af4a02014-06-24 11:07:54 +000053 install_package $(get_packages "openvswitch")
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090054 if is_ubuntu; then
Kyle Mestery86af4a02014-06-24 11:07:54 +000055 _neutron_ovs_base_install_ubuntu_dkms
Sean M. Collinsd738a9e2014-08-28 15:32:44 -040056 restart_service openvswitch-switch
Gary Kotton5452b182013-02-25 13:02:38 +000057 elif is_fedora; then
Gary Kotton5452b182013-02-25 13:02:38 +000058 restart_service openvswitch
59 elif is_suse; then
Vincent Untzcf6d8092013-07-04 09:59:34 +020060 restart_service openvswitch-switch
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090061 fi
62}
63
Ian Wienandaee18c72014-02-21 15:35:08 +110064function _neutron_ovs_base_configure_debug_command {
YAMAMOTO Takashi98a0ad42014-11-21 10:42:18 +090065 if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then
66 iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge ""
67 else
68 iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE
69 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090070}
71
Ian Wienandaee18c72014-02-21 15:35:08 +110072function _neutron_ovs_base_configure_firewall_driver {
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090073 if [[ "$Q_USE_SECGROUP" == "True" ]]; then
Mark McClainb05c8762013-07-06 23:29:39 -040074 iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090075 else
Mark McClainb05c8762013-07-06 23:29:39 -040076 iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090077 fi
78}
79
Ian Wienandaee18c72014-02-21 15:35:08 +110080function _neutron_ovs_base_configure_l3_agent {
YAMAMOTO Takashi6a633fd2014-07-23 12:02:18 +090081 if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then
82 iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge ""
83 else
84 iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE
85 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090086
Mark McClainb05c8762013-07-06 23:29:39 -040087 neutron-ovs-cleanup
YAMAMOTO Takashi0f18c232014-09-12 23:44:58 +090088 if [[ "$Q_USE_PUBLIC_VETH" = "True" ]]; then
89 ip link show $Q_PUBLIC_VETH_INT > /dev/null 2>&1 ||
90 sudo ip link add $Q_PUBLIC_VETH_INT type veth \
91 peer name $Q_PUBLIC_VETH_EX
92 sudo ip link set $Q_PUBLIC_VETH_INT up
93 sudo ip link set $Q_PUBLIC_VETH_EX up
94 sudo ip addr flush dev $Q_PUBLIC_VETH_EX
95 else
96 # --no-wait causes a race condition if $PUBLIC_BRIDGE is not up when ip addr flush is called
97 sudo ovs-vsctl -- --may-exist add-br $PUBLIC_BRIDGE
98 sudo ovs-vsctl br-set-external-id $PUBLIC_BRIDGE bridge-id $PUBLIC_BRIDGE
99 # ensure no IP is configured on the public bridge
100 sudo ip addr flush dev $PUBLIC_BRIDGE
101 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +0900102}
103
Ian Wienandaee18c72014-02-21 15:35:08 +1100104function _neutron_ovs_base_configure_nova_vif_driver {
Aaron Rosen4540d002013-10-24 13:59:33 -0700105 :
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +0900106}
107
Isaku Yamahata0dd34df2012-12-28 13:15:31 +0900108# Restore xtrace
Dean Troyere3a91602014-03-28 12:40:56 -0500109$OVSB_XTRACE