Move SR-IOV VIF type constants to the portbindings extension
While referencing VIF types during the QoS plugin drivers refactor I noticed that SR-IOV had the VIF type constants defined in the mech_driver itself, instead of the portbindings extension. I wanted to make all the VIF type constants available from a single place instead of scattered. Change-Id: Iabb7e5e953c4509c39b2029839752b88af87387b
This commit is contained in:
parent
d41bed0ee6
commit
299c3f8871
@ -89,6 +89,9 @@ VIF_TYPE_OTHER = 'other'
|
|||||||
# which is defined further below. E.g. Macvtap agent uses
|
# which is defined further below. E.g. Macvtap agent uses
|
||||||
# vnic_type 'normal'.
|
# vnic_type 'normal'.
|
||||||
VIF_TYPE_MACVTAP = 'macvtap'
|
VIF_TYPE_MACVTAP = 'macvtap'
|
||||||
|
# SR-IOV VIF types
|
||||||
|
VIF_TYPE_HW_VEB = 'hw_veb'
|
||||||
|
VIF_TYPE_HOSTDEV_PHY = 'hostdev_physical'
|
||||||
|
|
||||||
# VNIC_TYPE: It's used to determine which mechanism driver to use to bind a
|
# VNIC_TYPE: It's used to determine which mechanism driver to use to bind a
|
||||||
# port. It can be specified via the Neutron API. Default is normal,
|
# port. It can be specified via the Neutron API. Default is normal,
|
||||||
|
@ -27,8 +27,6 @@ from neutron.services.qos import qos_consts
|
|||||||
|
|
||||||
|
|
||||||
LOG = log.getLogger(__name__)
|
LOG = log.getLogger(__name__)
|
||||||
VIF_TYPE_HW_VEB = 'hw_veb'
|
|
||||||
VIF_TYPE_HOSTDEV_PHY = 'hostdev_physical'
|
|
||||||
FLAT_VLAN = 0
|
FLAT_VLAN = 0
|
||||||
|
|
||||||
|
|
||||||
@ -66,9 +64,9 @@ class SriovNicSwitchMechanismDriver(mech_agent.SimpleAgentMechanismDriverBase):
|
|||||||
self.supported_vnic_types = supported_vnic_types
|
self.supported_vnic_types = supported_vnic_types
|
||||||
# NOTE(ndipanov): PF passthrough requires a different vif type
|
# NOTE(ndipanov): PF passthrough requires a different vif type
|
||||||
self.vnic_type_for_vif_type = (
|
self.vnic_type_for_vif_type = (
|
||||||
{vtype: VIF_TYPE_HOSTDEV_PHY
|
{vtype: portbindings.VIF_TYPE_HOSTDEV_PHY
|
||||||
if vtype == portbindings.VNIC_DIRECT_PHYSICAL
|
if vtype == portbindings.VNIC_DIRECT_PHYSICAL
|
||||||
else VIF_TYPE_HW_VEB
|
else portbindings.VIF_TYPE_HW_VEB
|
||||||
for vtype in self.supported_vnic_types})
|
for vtype in self.supported_vnic_types})
|
||||||
self.vif_details = vif_details
|
self.vif_details = vif_details
|
||||||
|
|
||||||
@ -118,8 +116,9 @@ class SriovNicSwitchMechanismDriver(mech_agent.SimpleAgentMechanismDriverBase):
|
|||||||
def try_to_bind_segment_for_agent(self, context, segment, agent):
|
def try_to_bind_segment_for_agent(self, context, segment, agent):
|
||||||
vnic_type = context.current.get(portbindings.VNIC_TYPE,
|
vnic_type = context.current.get(portbindings.VNIC_TYPE,
|
||||||
portbindings.VNIC_DIRECT)
|
portbindings.VNIC_DIRECT)
|
||||||
vif_type = self.vnic_type_for_vif_type.get(vnic_type,
|
vif_type = self.vnic_type_for_vif_type.get(
|
||||||
VIF_TYPE_HW_VEB)
|
vnic_type, portbindings.VIF_TYPE_HW_VEB)
|
||||||
|
|
||||||
if not self.check_segment_for_agent(segment, agent):
|
if not self.check_segment_for_agent(segment, agent):
|
||||||
return False
|
return False
|
||||||
port_status = (constants.PORT_STATUS_ACTIVE if agent is None
|
port_status = (constants.PORT_STATUS_ACTIVE if agent is None
|
||||||
|
@ -52,7 +52,7 @@ class TestFakePortContext(base.FakePortContext):
|
|||||||
|
|
||||||
|
|
||||||
class SriovNicSwitchMechanismBaseTestCase(base.AgentMechanismBaseTestCase):
|
class SriovNicSwitchMechanismBaseTestCase(base.AgentMechanismBaseTestCase):
|
||||||
VIF_TYPE = mech_driver.VIF_TYPE_HW_VEB
|
VIF_TYPE = portbindings.VIF_TYPE_HW_VEB
|
||||||
CAP_PORT_FILTER = False
|
CAP_PORT_FILTER = False
|
||||||
AGENT_TYPE = constants.AGENT_TYPE_NIC_SWITCH
|
AGENT_TYPE = constants.AGENT_TYPE_NIC_SWITCH
|
||||||
VLAN_SEGMENTS = base.AgentMechanismVlanTestCase.VLAN_SEGMENTS
|
VLAN_SEGMENTS = base.AgentMechanismVlanTestCase.VLAN_SEGMENTS
|
||||||
@ -135,15 +135,15 @@ class SriovSwitchMechVnicTypeTestCase(SriovNicSwitchMechanismBaseTestCase):
|
|||||||
|
|
||||||
def test_vnic_type_direct(self):
|
def test_vnic_type_direct(self):
|
||||||
self._check_vif_type_for_vnic_type(portbindings.VNIC_DIRECT,
|
self._check_vif_type_for_vnic_type(portbindings.VNIC_DIRECT,
|
||||||
mech_driver.VIF_TYPE_HW_VEB)
|
portbindings.VIF_TYPE_HW_VEB)
|
||||||
|
|
||||||
def test_vnic_type_macvtap(self):
|
def test_vnic_type_macvtap(self):
|
||||||
self._check_vif_type_for_vnic_type(portbindings.VNIC_MACVTAP,
|
self._check_vif_type_for_vnic_type(portbindings.VNIC_MACVTAP,
|
||||||
mech_driver.VIF_TYPE_HW_VEB)
|
portbindings.VIF_TYPE_HW_VEB)
|
||||||
|
|
||||||
def test_vnic_type_direct_physical(self):
|
def test_vnic_type_direct_physical(self):
|
||||||
self._check_vif_type_for_vnic_type(portbindings.VNIC_DIRECT_PHYSICAL,
|
self._check_vif_type_for_vnic_type(portbindings.VNIC_DIRECT_PHYSICAL,
|
||||||
mech_driver.VIF_TYPE_HOSTDEV_PHY)
|
portbindings.VIF_TYPE_HOSTDEV_PHY)
|
||||||
|
|
||||||
|
|
||||||
class SriovSwitchMechVifDetailsTestCase(SriovNicSwitchMechanismBaseTestCase):
|
class SriovSwitchMechVifDetailsTestCase(SriovNicSwitchMechanismBaseTestCase):
|
||||||
|
Loading…
Reference in New Issue
Block a user