blob: 81561d31148cc256c9a7592e384ba2f9418fe7da [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}
James Chapmanc83cc752014-06-11 19:29:26 +010011OVS_DATAPATH_TYPE=${OVS_DATAPATH_TYPE:-""}
JordanP614202f2013-05-16 11:16:13 +020012
Ian Wienandaee18c72014-02-21 15:35:08 +110013function is_neutron_ovs_base_plugin {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090014 # Yes, we use OVS.
15 return 0
16}
17
Ian Wienandaee18c72014-02-21 15:35:08 +110018function _neutron_ovs_base_setup_bridge {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090019 local bridge=$1
Mark McClainb05c8762013-07-06 23:29:39 -040020 neutron-ovs-cleanup
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090021 sudo ovs-vsctl --no-wait -- --may-exist add-br $bridge
James Chapmanc83cc752014-06-11 19:29:26 +010022 if [[ $OVS_DATAPATH_TYPE != "" ]]; then
23 sudo ovs-vsctl set Bridge $bridge datapath_type=${OVS_DATAPATH_TYPE}
24 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090025 sudo ovs-vsctl --no-wait br-set-external-id $bridge bridge-id $bridge
26}
27
Ian Wienandaee18c72014-02-21 15:35:08 +110028function neutron_ovs_base_cleanup {
Mark McClainb05c8762013-07-06 23:29:39 -040029 # remove all OVS ports that look like Neutron created ports
Zhenzan Zhou9a704482015-01-27 10:48:24 +080030 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 +020031 sudo ovs-vsctl del-port ${port}
32 done
33
Mark McClainb05c8762013-07-06 23:29:39 -040034 # remove all OVS bridges created by Neutron
JordanP614202f2013-05-16 11:16:13 +020035 for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${OVS_BRIDGE} -e ${PUBLIC_BRIDGE}); do
36 sudo ovs-vsctl del-br ${bridge}
37 done
38}
39
Kyle Mestery86af4a02014-06-24 11:07:54 +000040function _neutron_ovs_base_install_ubuntu_dkms {
41 # install Dynamic Kernel Module Support packages if needed
42 local kernel_version=$(uname -r)
43 local kernel_major_minor=`echo $kernel_version | cut -d. -f1-2`
44 # From kernel 3.13 on, openvswitch-datapath-dkms is not needed
45 if [ `vercmp_numbers "$kernel_major_minor" "3.13"` -lt "0" ]; then
46 install_package "dkms openvswitch-datapath-dkms linux-headers-$kernel_version"
47 fi
48}
49
Ian Wienandaee18c72014-02-21 15:35:08 +110050function _neutron_ovs_base_install_agent_packages {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090051 # Install deps
Kyle Mestery86af4a02014-06-24 11:07:54 +000052 install_package $(get_packages "openvswitch")
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090053 if is_ubuntu; then
Kyle Mestery86af4a02014-06-24 11:07:54 +000054 _neutron_ovs_base_install_ubuntu_dkms
Sean M. Collinsd738a9e2014-08-28 15:32:44 -040055 restart_service openvswitch-switch
Gary Kotton5452b182013-02-25 13:02:38 +000056 elif is_fedora; then
Gary Kotton5452b182013-02-25 13:02:38 +000057 restart_service openvswitch
58 elif is_suse; then
Vincent Untzcf6d8092013-07-04 09:59:34 +020059 restart_service openvswitch-switch
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090060 fi
61}
62
Ian Wienandaee18c72014-02-21 15:35:08 +110063function _neutron_ovs_base_configure_debug_command {
YAMAMOTO Takashi98a0ad42014-11-21 10:42:18 +090064 if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then
65 iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge ""
66 else
67 iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE
68 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090069}
70
Ian Wienandaee18c72014-02-21 15:35:08 +110071function _neutron_ovs_base_configure_firewall_driver {
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090072 if [[ "$Q_USE_SECGROUP" == "True" ]]; then
Mark McClainb05c8762013-07-06 23:29:39 -040073 iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090074 else
Mark McClainb05c8762013-07-06 23:29:39 -040075 iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090076 fi
77}
78
Ian Wienandaee18c72014-02-21 15:35:08 +110079function _neutron_ovs_base_configure_l3_agent {
YAMAMOTO Takashi6a633fd2014-07-23 12:02:18 +090080 if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then
81 iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge ""
82 else
83 iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE
84 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090085
Mark McClainb05c8762013-07-06 23:29:39 -040086 neutron-ovs-cleanup
YAMAMOTO Takashi0f18c232014-09-12 23:44:58 +090087 if [[ "$Q_USE_PUBLIC_VETH" = "True" ]]; then
88 ip link show $Q_PUBLIC_VETH_INT > /dev/null 2>&1 ||
89 sudo ip link add $Q_PUBLIC_VETH_INT type veth \
90 peer name $Q_PUBLIC_VETH_EX
91 sudo ip link set $Q_PUBLIC_VETH_INT up
92 sudo ip link set $Q_PUBLIC_VETH_EX up
93 sudo ip addr flush dev $Q_PUBLIC_VETH_EX
94 else
YAMAMOTO Takashi0f18c232014-09-12 23:44:58 +090095 sudo ovs-vsctl -- --may-exist add-br $PUBLIC_BRIDGE
96 sudo ovs-vsctl br-set-external-id $PUBLIC_BRIDGE bridge-id $PUBLIC_BRIDGE
YAMAMOTO Takashi0f18c232014-09-12 23:44:58 +090097 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090098}
99
Ian Wienandaee18c72014-02-21 15:35:08 +1100100function _neutron_ovs_base_configure_nova_vif_driver {
Aaron Rosen4540d002013-10-24 13:59:33 -0700101 :
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +0900102}
103
Isaku Yamahata0dd34df2012-12-28 13:15:31 +0900104# Restore xtrace
Dean Troyere3a91602014-03-28 12:40:56 -0500105$OVSB_XTRACE