RE: Hyper-V vmbus driver
From: KY Srinivasan
Date: Sun Apr 24 2011 - 12:18:31 EST
> -----Original Message-----
> From: Greg KH [mailto:greg@xxxxxxxxx]
> Sent: Saturday, April 23, 2011 11:21 AM
> To: Greg KH
> Cc: KY Srinivasan; devel@xxxxxxxxxxxxxxxxxxxxxx; linux-kernel@xxxxxxxxxxxxxxx;
> virtualization@xxxxxxxxxxxxxx
> Subject: Re: Hyper-V vmbus driver
>
> On Mon, Apr 11, 2011 at 12:07:08PM -0700, Greg KH wrote:
>
> Due to other external issues, my patch backlog is still not gotten
> through yet, sorry. Sometimes "real life" intrudes on the best of
> plans.
>
> I'll get to this when I get through the rest of your hv patches, and the
> other patches pending that I have in my queues.
Thanks Greg. The latest re-send of my hv patches are against the tree:
git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging-2.6.git
that I picked up on April 22, 2011. I hope there won't be any issues
this time around.
>
> But, I would recommend you going through and looking at the code and
> verifying that you feel the bus code is "ready". At a very quick
> glance, you should not have individual drivers have to set their 'struct
> device' pointers directly, that is something that the bus does, not the
> driver. The driver core will call your bus and your bus will then do
> the matching and call the probe function of the driver if needed.
Are you referring to the fact that in the vmbus_match function,
the current code binds the device specific driver to the
corresponding hv_device structure?
>
> See the PCI driver structure for an example of this if you are curious.
> It should also allow you to get rid of that unneeded *priv pointer in
> the struct hv_driver.
I am pretty sure, I can get rid of this. The way this code was originally
structured, in the vmbus_match() function, you needed to get at the
device specific driver pointer so that we could do the binding between
the hv_device and the correspond device specific driver. The earlier code
depended on the structure layout to map a pointer to the hv_driver to
the corresponding device specific driver (net, block etc.) To get rid of
this layout dependency, I introduced an addition field (priv) in the hv_driver.
There is, I suspect sufficient state available to:
(a) Not require the vmbus_match() function to do the binding.
(b) And to get at the device specific driver structure from the generic
driver structure without having to have an explicit mapping
maintained in the hv_driver structure.
Before, I go ahead and make these changes, Greg, can you confirm
if I have captured your concerns correctly.
> You should be able to set that structure
> constant, like all other busses. Right now you can not which shows a
> design issue.
I am a little confused here. While I agree with you that perhaps we could
get rid the priv element in the hv_driver structure, what else would you
want done here.
>
> So, take a look at that and let me know what you think.
Once I hear from you, I will work on getting rid of the
priv pointer from hv_driver structure as well as the code that
currently does the binding in vmbus_match.
Regards,
K. Y
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/