| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 1 | # common functions for ovs based plugin | 
|  | 2 | # ------------------------------------- | 
|  | 3 |  | 
|  | 4 | # Save trace setting | 
| Dean Troyer | 8d55be3 | 2013-02-07 17:16:35 -0600 | [diff] [blame] | 5 | MY_XTRACE=$(set +o | grep xtrace) | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 6 | set +o xtrace | 
|  | 7 |  | 
| JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 8 | OVS_BRIDGE=${OVS_BRIDGE:-br-int} | 
|  | 9 | PUBLIC_BRIDGE=${PUBLIC_BRIDGE:-br-ex} | 
|  | 10 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 11 | function is_neutron_ovs_base_plugin() { | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 12 | # Yes, we use OVS. | 
|  | 13 | return 0 | 
|  | 14 | } | 
|  | 15 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 16 | function _neutron_ovs_base_setup_bridge() { | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 17 | local bridge=$1 | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 18 | neutron-ovs-cleanup | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 19 | sudo ovs-vsctl --no-wait -- --may-exist add-br $bridge | 
|  | 20 | sudo ovs-vsctl --no-wait br-set-external-id $bridge bridge-id $bridge | 
|  | 21 | } | 
|  | 22 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 23 | function neutron_ovs_base_cleanup() { | 
|  | 24 | # remove all OVS ports that look like Neutron created ports | 
| JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 25 | for port in $(sudo ovs-vsctl list port | grep -o -e tap[0-9a-f\-]* -e q[rg]-[0-9a-f\-]*); do | 
|  | 26 | sudo ovs-vsctl del-port ${port} | 
|  | 27 | done | 
|  | 28 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 29 | # remove all OVS bridges created by Neutron | 
| JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 30 | for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${OVS_BRIDGE} -e ${PUBLIC_BRIDGE}); do | 
|  | 31 | sudo ovs-vsctl del-br ${bridge} | 
|  | 32 | done | 
|  | 33 | } | 
|  | 34 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 35 | function _neutron_ovs_base_install_agent_packages() { | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 36 | local kernel_version | 
|  | 37 | # Install deps | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 38 | # FIXME add to ``files/apts/neutron``, but don't install if not needed! | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 39 | if is_ubuntu; then | 
|  | 40 | kernel_version=`cat /proc/version | cut -d " " -f3` | 
|  | 41 | install_package make fakeroot dkms openvswitch-switch openvswitch-datapath-dkms linux-headers-$kernel_version | 
| Gary Kotton | 5452b18 | 2013-02-25 13:02:38 +0000 | [diff] [blame] | 42 | elif is_fedora; then | 
|  | 43 | install_package openvswitch | 
|  | 44 | # Ensure that the service is started | 
|  | 45 | restart_service openvswitch | 
|  | 46 | elif is_suse; then | 
| Vincent Untz | cf6d809 | 2013-07-04 09:59:34 +0200 | [diff] [blame] | 47 | install_package openvswitch | 
|  | 48 | restart_service openvswitch-switch | 
|  | 49 | restart_service openvswitch-controller | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 50 | fi | 
|  | 51 | } | 
|  | 52 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 53 | function _neutron_ovs_base_configure_debug_command() { | 
|  | 54 | iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 55 | } | 
|  | 56 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 57 | function _neutron_ovs_base_configure_firewall_driver() { | 
| Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 58 | if [[ "$Q_USE_SECGROUP" == "True" ]]; then | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 59 | 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] | 60 | else | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 61 | iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver | 
| Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 62 | fi | 
|  | 63 | } | 
|  | 64 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 65 | function _neutron_ovs_base_configure_l3_agent() { | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 66 | iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE | 
|  | 67 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 68 | neutron-ovs-cleanup | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 69 | sudo ovs-vsctl --no-wait -- --may-exist add-br $PUBLIC_BRIDGE | 
| Gary Kotton | 503e9ac | 2013-07-15 09:41:25 -0700 | [diff] [blame] | 70 | sudo ovs-vsctl --no-wait br-set-external-id $PUBLIC_BRIDGE bridge-id $PUBLIC_BRIDGE | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 71 | # ensure no IP is configured on the public bridge | 
|  | 72 | sudo ip addr flush dev $PUBLIC_BRIDGE | 
|  | 73 | } | 
|  | 74 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 75 | function _neutron_ovs_base_configure_nova_vif_driver() { | 
|  | 76 | # The hybrid VIF driver needs to be specified when Neutron Security Group | 
| Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 77 | # is enabled (until vif_security attributes are supported in VIF extension) | 
|  | 78 | if [[ "$Q_USE_SECGROUP" == "True" ]]; then | 
|  | 79 | NOVA_VIF_DRIVER=${NOVA_VIF_DRIVER:-"nova.virt.libvirt.vif.LibvirtHybridOVSBridgeDriver"} | 
|  | 80 | else | 
|  | 81 | NOVA_VIF_DRIVER=${NOVA_VIF_DRIVER:-"nova.virt.libvirt.vif.LibvirtGenericVIFDriver"} | 
|  | 82 | fi | 
|  | 83 | } | 
|  | 84 |  | 
| Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 85 | # Restore xtrace | 
| Dean Troyer | 8d55be3 | 2013-02-07 17:16:35 -0600 | [diff] [blame] | 86 | $MY_XTRACE |