--- On Thu, 11/6/08, Greg KH <[EMAIL PROTECTED]> wrote:
 
> On Thu, Nov 06, 2008 at 08:41:53AM -0800, H L wrote:
> > I have not modified any existing drivers, but instead
> I threw together
> > a bare-bones module enabling me to make a call to
> pci_iov_register()
> > and then poke at an SR-IOV adapter's /sys entries
> for which no driver
> > was loaded.
> > 
> > It appears from my perusal thus far that drivers using
> these new
> > SR-IOV patches will require modification; i.e. the
> driver associated
> > with the Physical Function (PF) will be required to
> make the
> > pci_iov_register() call along with the requisite
> notify() function.
> > Essentially this suggests to me a model for the PF
> driver to perform
> > any "global actions" or setup on behalf of
> VFs before enabling them
> > after which VF drivers could be associated.
> 
> Where would the VF drivers have to be associated?  On the
> "pci_dev"
> level or on a higher one?


I have not yet fully grocked Yu Zhao's model to answer this.  That said, I 
would *hope* to find it on the "pci_dev" level.


> Will all drivers that want to bind to a "VF"
> device need to be
> rewritten?

Not necessarily, or perhaps minimally; depends on hardware/firmware and actions 
the driver wants to take.  An example here might assist.  Let's just say 
someone has created, oh, I don't know, maybe an SR-IOV NIC.  Now, for 'general' 
I/O operations to pass network traffic back and forth there would ideally be no 
difference in the actions and therefore behavior of a PF driver and a VF 
driver.  But, what do you do in the instance a VF wants to change link-speed?  
As that physical characteristic affects all VFs, how do you handle that?  This 
is where the hardware/firmware implementation part comes to play.  If a VF 
driver performs some actions to initiate the change in link speed, the logic in 
the adapter could be anything like:

1.  Acknowledge the request as if it were really done, but effectively ignore 
it.  The Independent Hardware Vendor (IHV) might dictate that if you want to 
change any "global" characteristics of an adapter, you may only do so via the 
PF driver.  Granted, this, depending on the device class, may just not be 
acceptable.

2.  Acknowledge the request and then trigger an interrupt to the PF driver to 
have it assist.  The PF driver might then just set the new link-speed, or it 
could result in a PF driver communicating by some mechanism to all of the VF 
driver instances that this change of link-speed was requested.

3.  Acknowledge the request and perform inner PF and VF communication of this 
event within the logic of the card (e.g. to "vote" on whether or not to perform 
this action) with interrupts and associated status delivered to all PF and VF 
drivers.

The list goes on.

> 
> > I have so far only seen Yu Zhao's
> "7-patch" set.  I've not yet looked
> > at his subsequently tendered "15-patch" set
> so I don't know what has
> > changed.    The hardware/firmware implementation for
> any given SR-IOV
> > compatible device, will determine the extent of
> differences required
> > between a PF driver and a VF driver.
> 
> Yeah, that's what I'm worried/curious about. 
> Without seeing the code
> for such a driver, how can we properly evaluate if this
> infrastructure
> is the correct one and the proper way to do all of this?


As the example above demonstrates, that's a tough question to answer.  Ideally, 
in my view, there would only be one driver written per SR-IOV device and it 
would contain the logic to "do the right things" based on whether its running 
as a PF or VF with that determination easily accomplished by testing the 
existence of the SR-IOV extended capability.    Then, in an effort to minimize 
(if not eliminate) the complexities of driver-to-driver actions for fielding 
"global events", contain as much of the logic as is possible within the 
adapter.  Minimizing the efforts required for the device driver writers in my 
opinion paves the way to greater adoption of this technology.



      

--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to