Do not block qos for direct-physical ports
Today the sriov qos service plugin blindly blocks creating ports with minimum bandwidth qos and with direct_physical vnic_type. This was originally added when only dataplane enforcement was the scope of the qos service plugin. However in the last many releases we created placement enforcement for this qos rule regardless of the vnic_type. So now blindly blocking the port creation is now preventing using the placement enforcement for this rule for direct_physical ports. This patch removes this limitation by marking minimum bandwidth as supported rule for the sriov qos service plugin. The limitation that data plane enforcement is not supported for this rule remains. The agent will not even try to apply any kind of rules to these ports as port binding is not forwarded for the sriov agent at all. The documentation is extended to explain that placement enforcement now works while data plane enforcement still not supported. This is somewhat similar to the case when the support for egress direction is added to the minimum bandwidth rule, while the sriov data plane enforcement was not (could not) been implemented for this direction in the sriov agent. Today the sriov agent simply ignores the egress direction rules in the minimum bandwidth qos rule during applying the data plane enforcement. Closes-Bug: #1949877 Change-Id: I20ad32eac414ff90b551bff940d92cbcfa848101
This commit is contained in:
parent
63f8a39d75
commit
abfbe5d54d
@ -177,6 +177,9 @@ supported:
|
|||||||
* Open vSwitch (``openvswitch``) vnic_types: ``normal``, ``direct``
|
* Open vSwitch (``openvswitch``) vnic_types: ``normal``, ``direct``
|
||||||
* SR-IOV (``sriovnicswitch``) vnic_types: ``direct``, ``macvtap``
|
* SR-IOV (``sriovnicswitch``) vnic_types: ``direct``, ``macvtap``
|
||||||
|
|
||||||
|
From the Yoga release the ``direct-physical`` vnic_type is now marked supported
|
||||||
|
for the SR-IOV (``sriovnicswitch``) agent.
|
||||||
|
|
||||||
neutron-server config
|
neutron-server config
|
||||||
~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
@ -82,6 +82,10 @@ traffic directions (from the VM point of view).
|
|||||||
(1) Since Newton
|
(1) Since Newton
|
||||||
(2) Since Stein
|
(2) Since Stein
|
||||||
|
|
||||||
|
.. note:: The SR-IOV agent does not support dataplane enforcement for ports
|
||||||
|
with ``direct-physical`` vnic_type. However since Yoga the Placement
|
||||||
|
enforcement is supported for this vnic_type too.
|
||||||
|
|
||||||
.. table:: **Neutron backends, supported directions and enforcement types for Minimum Packet Rate rule**
|
.. table:: **Neutron backends, supported directions and enforcement types for Minimum Packet Rate rule**
|
||||||
|
|
||||||
============================ ========================== ==================== ============== =====
|
============================ ========================== ==================== ============== =====
|
||||||
|
@ -50,7 +50,8 @@ class SRIOVNICSwitchDriver(base.DriverBase):
|
|||||||
name='sriovnicswitch',
|
name='sriovnicswitch',
|
||||||
vif_types=[portbindings.VIF_TYPE_HW_VEB],
|
vif_types=[portbindings.VIF_TYPE_HW_VEB],
|
||||||
vnic_types=[portbindings.VNIC_DIRECT,
|
vnic_types=[portbindings.VNIC_DIRECT,
|
||||||
portbindings.VNIC_MACVTAP],
|
portbindings.VNIC_MACVTAP,
|
||||||
|
portbindings.VNIC_DIRECT_PHYSICAL],
|
||||||
supported_rules=SUPPORTED_RULES,
|
supported_rules=SUPPORTED_RULES,
|
||||||
requires_rpc_notifications=True)
|
requires_rpc_notifications=True)
|
||||||
|
|
||||||
|
@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- |
|
||||||
|
Neutron now supports the placement enforcement for the guaranteed minimum
|
||||||
|
bandwidth QoS rule type with direct-phyisical vnic_type as well. The data
|
||||||
|
plane enforcement of such rule and vnic_type combination is still not
|
||||||
|
supported.
|
Loading…
x
Reference in New Issue
Block a user