Deploying with SR-IOV Support¶
TripleO can deploy Overcloud nodes with SR-IOV support. A new role ComputeSriov
has been added to create a custom roles_data.yaml
with composable SR-IOV role.
Execute below command to create the roles_data.yaml
:
openstack overcloud roles generate -o roles_data.yaml Controller ComputeSriov
Once a roles file is created, the following changes are required:
Deploy Command
Parameters
Network Config
Deploy Command¶
Deploy command should include the generated roles data file from the above command.
Deploy command should also include the SR-IOV environment file to include the neutron-sriov-agent service. All the required parameters are also specified in this environment file. The parameters has to be configured according to the baremetal on which SR-IOV needs to be enabled.
Also, SR-IOV requires mandatory kernel parameters to be set, like
intel_iommu=on iommu=pt
on Intel machines. In order to enable the
configuration of kernel parametres to the host, host-config-pre-network
environment file has to be added for the deploy command.
Adding the following arguments to the openstack overcloud deploy
command
will do the trick:
openstack overcloud deploy --templates \
-r roles_data.yaml \
-e /usr/share/openstack-tripleo-heat-templates/environments/services/neutron-sriov.yaml \
-e /usr/share/openstack-tripleo-heat-templates/environments/host-config-and-reboot.yaml \
...
Parameters¶
Following are the list of parameters which need to be provided for deploying with SR-IOV support.
NovaPCIPassthrough: Provide the list of SR-IOV device names, the logical network, PCI addresses etc. The PF/VF devices matching the criteria would be available for guests.
NeutronPhysicalDevMappings: The map of logical network name and the physical interface.
Example:
parameter_defaults:
NovaPCIPassthrough:
- devname: "p7p1"
physical_network: "sriov1_net"
- devname: "p7p2"
physical_network: "sriov2_net"
NeutronPhysicalDevMappings: "sriov1_net:p7p1,sriov2_net:p7p2"
The parameter KernelArgs
should be provided in the deployment environment
file, with the set of kernel boot parameters to be applied on the
ComputeSriov
role where SR-IOV is enabled:
parameter_defaults:
ComputeSriovParameters:
KernelArgs: "intel_iommu=on iommu=pt"
Network Config¶
SR-IOV supported network interfaces should be specified in the network config templates as sriov_pf type. This mechanism of configuring numvfs for SR-IOV device is recommended and NeutronSriovNumVFs shall be avoided.
Example:
network_config:
- type: sriov_pf
name: p7p2
mtu: 9000
numvfs: 10
use_dhcp: false
defroute: false
nm_controlled: true
promisc: false