dda5081883
In addition to binding:vif_type, the neutron core plugin needs to supply various information to nova's VIF driver, such as VIF security details and PCI details when SR-IOV is being used. This information is read-only, requires admin privileges, and is not intended for normal users. Rather than add separate mechanisms throughout the stack for each such requirement, the binding:capabilities port attibute, which is a dictionary and is not currently not used by nova, is renamed to binding:vif_details to serve as a general-purpose mechanism for supplying binding-specific details to the VIF driver. This patch does not remove or replace the CAP_PORT_FILTER boolean previously used in binding:capabilities. A separate patch should implement the specific key/value pairs carried by binding:vif_details to implement VIF security. Another patch will implement the key/value pairs needed for SR-IOV. The ML2 plugin now allows the bound mechanism driver to supply the binding:vif_details dictionary content, instead of just the CAP_PORT_FILTER boolean previously carried by the binding:capabilities attribute. DocImpact: Need to update portbinding extension API, but no impact on user or administrator documentation. Implements: blueprint vif-details Related-Bug: 1112912 Change-Id: I34be746fcfa73c70f72b4f9add8eff3ac88c723f
58 lines
2.1 KiB
Python
58 lines
2.1 KiB
Python
# Copyright (c) 2013 OpenStack Foundation
|
|
# All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
import re
|
|
|
|
from neutron.common import constants
|
|
from neutron.extensions import portbindings
|
|
from neutron.openstack.common import log
|
|
from neutron.plugins.ml2 import driver_api as api
|
|
from neutron.plugins.ml2.drivers import mech_agent
|
|
|
|
LOG = log.getLogger(__name__)
|
|
|
|
|
|
class HypervMechanismDriver(mech_agent.SimpleAgentMechanismDriverBase):
|
|
"""Attach to networks using hyperv L2 agent.
|
|
|
|
The HypervMechanismDriver integrates the ml2 plugin with the
|
|
hyperv L2 agent. Port binding with this driver requires the hyperv
|
|
agent to be running on the port's host, and that agent to have
|
|
connectivity to at least one segment of the port's network.
|
|
"""
|
|
|
|
def __init__(self):
|
|
super(HypervMechanismDriver, self).__init__(
|
|
constants.AGENT_TYPE_HYPERV,
|
|
portbindings.VIF_TYPE_HYPERV,
|
|
{portbindings.CAP_PORT_FILTER: False})
|
|
|
|
def check_segment_for_agent(self, segment, agent):
|
|
mappings = agent['configurations'].get('vswitch_mappings', {})
|
|
LOG.debug(_("Checking segment: %(segment)s "
|
|
"for mappings: %(mappings)s"),
|
|
{'segment': segment, 'mappings': mappings})
|
|
network_type = segment[api.NETWORK_TYPE]
|
|
if network_type == 'local':
|
|
return True
|
|
elif network_type in ['flat', 'vlan']:
|
|
for pattern in mappings:
|
|
if re.match(pattern, segment[api.PHYSICAL_NETWORK]):
|
|
return True
|
|
else:
|
|
return False
|
|
else:
|
|
return False
|