<div dir="ltr"><div class="gmail_extra"><br><div class="gmail_quote">John:<br></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">At a high level:<br>


<br>
Neutron:<br>
* user wants to connect to a particular neutron network<br>
* user wants a super-fast SRIOV connection</blockquote><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

Administration:<br>
* needs to map PCI device to what neutron network the connect to<br></blockquote><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
The big question is:<br>
* is this a specific SRIOV only (provider) network<br>
* OR... are other non-SRIOV connections also made to that same network<br>
<br>
I feel we have to go for that latter. Imagine a network on VLAN 42,<br>
you might want some SRIOV into that network, and some OVS connecting<br>
into the same network. The user might have VMs connected using both<br>
methods, so wants the same IP address ranges and same network id<br>
spanning both.<br></blockquote><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
If we go for that latter new either need:<br>
* some kind of nic-flavor<br>
** boot ... -nic nic-id:"public-id:,nic-flavor:"10GBpassthrough"<br>
** but neutron could store nic-flavor, and pass it through to VIF<br>
driver, and user says port-id<br>
* OR add NIC config into the server flavor<br>
** extra spec to say, tell VIF driver it could use on of this list of<br>
PCI devices: (list pci-flavors)<br>
* OR do both<br>
<br>
I vote for nic-flavor only, because it matches the volume-type we have<br>
with cinder.<br></blockquote><div><br></div><div>I think the issue there is that Nova is managing the supply of PCI devices (which is limited and limited on a per-machine basis).  Indisputably you need to select the NIC you want to use as a passthrough rather than a vnic device, so there's something in the --nic argument, but you have to answer two questions:<br>

</div><div><br>- how many devices do you need (which is now not a flavor property but in the --nic list, which seems to me an odd place to be defining billable resources)<br></div><div>- what happens when someone does nova interface-attach?<br>

<br></div><div>Cinder's an indirect parallel because the resources it's adding to the hypervisor are virtual and unlimited, I think, or am I missing something here?<br></div> <br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">



However, it does suggest that Nova should leave all the SRIOV work to<br>
the VIF driver.<br>
So the VIF driver, as activate by neutron, will understand which PCI<br>
devices to passthrough.<br>
<br>
Similar to the plan with brick, we could have an oslo lib that helps<br>
you attach SRIOV devices that could be used by the neturon VIF drivers<br>
and the nova PCI passthrough code.<br></blockquote><div><br></div><div>I'm not clear that this is necessary.<br><br>At the moment with vNICs, you pass through devices by having a co-operation between Neutron (which configures a way of attaching them to put them on a certain network) and the hypervisor specific code (which creates them in the instance and attaches them as instructed by Neutron).  Why would we not follow the same pattern with passthrough devices?  In this instance, neutron would tell nova that when it's plugging this device it should be a passthrough device, and pass any additional parameters like the VF encap, and Nova would do as instructed, then Neutron would reconfigure whatever parts of the network need to be reconfigured in concert with the hypervisor's settings to make the NIC a part of the specified network.</div>

<div>-- <br></div><div>Ian.<br></div><div> <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Thanks,<br>
John<br>
<div class="HOEnZb"><div class="h5"><br>
_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</div></div></blockquote></div><br></div></div>