blob: 2e63fe3c7b98139d4242fdcf830974be9ffe0f7e [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
Ian Wienand523f4882015-10-13 11:03:03 +11007_XTRACE_NEUTRON_OVS_BASE=$(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}
Michal Ptacekc1605552015-09-23 21:02:02 +010011# OVS recognize default 'system' datapath or 'netdev' for userspace datapath
12OVS_DATAPATH_TYPE=${OVS_DATAPATH_TYPE:-system}
Hirofumi Ichiharad48d6722015-07-04 22:58:44 +090013OVS_TUNNEL_BRIDGE=${OVS_TUNNEL_BRIDGE:-br-tun}
JordanP614202f2013-05-16 11:16:13 +020014
Ian Wienandaee18c72014-02-21 15:35:08 +110015function is_neutron_ovs_base_plugin {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090016 # Yes, we use OVS.
17 return 0
18}
19
Waldemar Znoinskid4c89282015-05-07 17:14:21 +010020function _neutron_ovs_base_add_bridge {
21 local bridge=$1
Sean M. Collins75a64542016-08-01 14:41:10 -040022 local addbr_cmd="sudo ovs-vsctl -- --may-exist add-br $bridge"
Waldemar Znoinskid4c89282015-05-07 17:14:21 +010023
Michal Ptacekc1605552015-09-23 21:02:02 +010024 if [ "$OVS_DATAPATH_TYPE" != "system" ] ; then
Waldemar Znoinskid4c89282015-05-07 17:14:21 +010025 addbr_cmd="$addbr_cmd -- set Bridge $bridge datapath_type=${OVS_DATAPATH_TYPE}"
26 fi
27
28 $addbr_cmd
29}
30
Ian Wienandaee18c72014-02-21 15:35:08 +110031function _neutron_ovs_base_setup_bridge {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090032 local bridge=$1
Gary Kotton2a598142016-11-29 03:48:34 -080033 neutron-ovs-cleanup --config-file $NEUTRON_CONF
Waldemar Znoinskid4c89282015-05-07 17:14:21 +010034 _neutron_ovs_base_add_bridge $bridge
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090035 sudo ovs-vsctl --no-wait br-set-external-id $bridge bridge-id $bridge
36}
37
Ian Wienandaee18c72014-02-21 15:35:08 +110038function neutron_ovs_base_cleanup {
Mark McClainb05c8762013-07-06 23:29:39 -040039 # remove all OVS ports that look like Neutron created ports
Zhenzan Zhou9a704482015-01-27 10:48:24 +080040 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 +020041 sudo ovs-vsctl del-port ${port}
42 done
43
Mark McClainb05c8762013-07-06 23:29:39 -040044 # remove all OVS bridges created by Neutron
Hirofumi Ichihara7ab3e392015-07-04 23:11:52 +090045 for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${OVS_BRIDGE} -e ${PUBLIC_BRIDGE} -e ${OVS_TUNNEL_BRIDGE}); do
JordanP614202f2013-05-16 11:16:13 +020046 sudo ovs-vsctl del-br ${bridge}
47 done
48}
49
Kyle Mestery86af4a02014-06-24 11:07:54 +000050function _neutron_ovs_base_install_ubuntu_dkms {
51 # install Dynamic Kernel Module Support packages if needed
Ian Wienandada886d2015-10-07 14:06:26 +110052 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 Mestery86af4a02014-06-24 11:07:54 +000056 # From kernel 3.13 on, openvswitch-datapath-dkms is not needed
Yi Zhao2ae8b092016-05-12 12:11:24 +080057 if vercmp "$kernel_major_minor" "<" "3.13" ; then
Kyle Mestery86af4a02014-06-24 11:07:54 +000058 install_package "dkms openvswitch-datapath-dkms linux-headers-$kernel_version"
59 fi
60}
61
Ian Wienandaee18c72014-02-21 15:35:08 +110062function _neutron_ovs_base_install_agent_packages {
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090063 # Install deps
Kyle Mestery86af4a02014-06-24 11:07:54 +000064 install_package $(get_packages "openvswitch")
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090065 if is_ubuntu; then
Kyle Mestery86af4a02014-06-24 11:07:54 +000066 _neutron_ovs_base_install_ubuntu_dkms
Sean M. Collinsd738a9e2014-08-28 15:32:44 -040067 restart_service openvswitch-switch
Gary Kotton5452b182013-02-25 13:02:38 +000068 elif is_fedora; then
Gary Kotton5452b182013-02-25 13:02:38 +000069 restart_service openvswitch
Zhang Jinnan4d8c03a2015-08-20 10:00:20 -040070 sudo systemctl enable openvswitch
Gary Kotton5452b182013-02-25 13:02:38 +000071 elif is_suse; then
Adam Spiersbbb6b0c2019-01-25 00:29:42 +000072 if [[ $DISTRO == "sle12" ]] && vercmp "$os_RELEASE" "<" "12.2" ; then
Dirk Mueller30b58bf2016-12-09 00:58:54 +010073 restart_service openvswitch-switch
74 else
Dirk Mueller486057f2018-03-21 13:59:18 +010075 # workaround for https://bugzilla.suse.com/show_bug.cgi?id=1085971
76 if [[ $DISTRO =~ "tumbleweed" ]]; then
77 sudo sed -i -e "s,^OVS_USER_ID=.*,OVS_USER_ID='root:root'," /etc/sysconfig/openvswitch
78 fi
79 restart_service openvswitch || {
80 journalctl -xe || :
81 systemctl status openvswitch
82 }
Dirk Mueller30b58bf2016-12-09 00:58:54 +010083 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +090084 fi
85}
86
Ian Wienandaee18c72014-02-21 15:35:08 +110087function _neutron_ovs_base_configure_firewall_driver {
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090088 if [[ "$Q_USE_SECGROUP" == "True" ]]; then
Jakub Libosvara99ab702018-05-14 16:12:52 +020089 iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver openvswitch
Denis Buliga0bf75a42017-02-06 16:56:46 +020090 if ! running_in_container; then
91 enable_kernel_bridge_firewall
92 fi
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090093 else
Brian Haley30ab23c2016-11-02 16:30:31 -040094 iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver noop
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +090095 fi
96}
97
Ian Wienandaee18c72014-02-21 15:35:08 +110098function _neutron_ovs_base_configure_l3_agent {
Gary Kotton2a598142016-11-29 03:48:34 -080099 neutron-ovs-cleanup --config-file $NEUTRON_CONF
YAMAMOTO Takashi0f18c232014-09-12 23:44:58 +0900100 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
Ihar Hrachyshka7b5c7dc2016-07-15 20:17:13 +0200108 _neutron_ovs_base_add_public_bridge
YAMAMOTO Takashi0f18c232014-09-12 23:44:58 +0900109 sudo ovs-vsctl br-set-external-id $PUBLIC_BRIDGE bridge-id $PUBLIC_BRIDGE
YAMAMOTO Takashi0f18c232014-09-12 23:44:58 +0900110 fi
Isaku Yamahata0dd34df2012-12-28 13:15:31 +0900111}
112
Ihar Hrachyshka7b5c7dc2016-07-15 20:17:13 +0200113function _neutron_ovs_base_add_public_bridge {
114 _neutron_ovs_base_add_bridge $PUBLIC_BRIDGE
115 set_mtu $PUBLIC_BRIDGE $PUBLIC_BRIDGE_MTU
116}
117
Ian Wienandaee18c72014-02-21 15:35:08 +1100118function _neutron_ovs_base_configure_nova_vif_driver {
Aaron Rosen4540d002013-10-24 13:59:33 -0700119 :
Akihiro MOTOKI3452f8e2013-03-21 14:11:27 +0900120}
121
Isaku Yamahata0dd34df2012-12-28 13:15:31 +0900122# Restore xtrace
Ian Wienand523f4882015-10-13 11:03:03 +1100123$_XTRACE_NEUTRON_OVS_BASE