On Sat, Nov 08, 2008 at 02:48:25AM +0800, Greg KH wrote: > On Fri, Nov 07, 2008 at 11:17:40PM +0800, Yu Zhao wrote: > > While we are arguing what the software model the SR-IOV should be, let me > > ask two simple questions first: > > > > 1, What does the SR-IOV looks like? > > 2, Why do we need to support it? > > I don't think we need to worry about those questions, as we can see what > the SR-IOV interface looks like by looking at the PCI spec, and we know > Linux needs to support it, as Linux needs to support everything :) > > (note, community members that can not see the PCI specs at this point in > time, please know that we are working on resolving these issues, > hopefully we will have some good news within a month or so.) Thanks for doing this! > > > As you know the Linux kernel is the base of various virtual machine > > monitors such as KVM, Xen, OpenVZ and VServer. We need SR-IOV support in > > the kernel because mostly it helps high-end users (IT departments, HPC, > > etc.) to share limited hardware resources among hundreds or even thousands > > virtual machines and hence reduce the cost. How can we make these virtual > > machine monitors utilize the advantage of SR-IOV without spending too much > > effort meanwhile remaining architectural correctness? I believe making VF > > represent as much closer as a normal PCI device (struct pci_dev) is the > > best way in current situation, because this is not only what the hardware > > designers expect us to do but also the usage model that KVM, Xen and other > > VMMs have already supported. > > But would such an api really take advantage of the new IOV interfaces > that are exposed by the new device type? The SR-IOV is a very straightforward capability -- it can only reside in the Physical Function's (the real device) config space and controls the allocation of the Virtual Function by several registers. What we can do in the PCI layer is to make the SR-IOV device spawn VF upon user request, and register VF to the PCI core. The functionality of SR-IOV device (both the PF and VF) can vary at a large range and their drivers (same as normal PCI device driver) are responsible for handling device specific stuff. So it looks like we can get all work done in the PCI layer with only two interfaces: one for the PF driver to register itself as a SR-IOV capable driver, expose the sysfs (or ioctl) interface to receive user request, and allocate 'pci_dev' for VF; another one to cleanup all stuff when the PF driver unregisters itself (e.g., the driver is removed or the device is going to power-saving mode.). > > > I agree that API in the SR-IOV pacth is arguable and the concerns such as > > lack of PF driver, etc. are also valid. But I personally think these stuff > > are not essential problems to me and other SR-IOV driver developers. > > How can the lack of a PF driver not be a valid concern at this point in > time? Without such a driver written, how can we know that the SR-IOV > interface as created is sufficient, or that it even works properly? > > Here's what I see we need to have before we can evaluate if the IOV core > PCI patches are acceptable: > - a driver that uses this interface > - a PF driver that uses this interface. > > Without those, we can't determine if the infrastructure provided by the > IOV core even is sufficient, right? Yes, using a PF driver to evaluate the SR-IOV core is necessary. And only the PF driver can use the interface since the VF shouldn't have the SR-IOV capability in its config space according to the spec. Regards, Yu > Rumor has it that there is both of the above things floating around, can > someone please post them to the linux-pci list so that we can see how > this all works together? > > thanks, > > greg k-h > -- > To unsubscribe from this list: send the line "unsubscribe linux-pci" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html