Re: [PATCH 1/1] Staging: hv: storvsc: Move the storage driver outof staging
From: James Bottomley
Date: Sat Oct 15 2011 - 17:27:32 EST
On Fri, 2011-10-14 at 23:28 -0700, K. Y. Srinivasan wrote:
> In preparation for moving the storage driver out of staging, seek community
> review of the storage driver code.
That's not exactly a very descriptive commit message for me to put into
SCSI. It doesn't have to be huge, just something like "driver to enable
hyperv windows guest on Linux" or something.
> drivers/scsi/Kconfig | 7 +
> drivers/scsi/Makefile | 3 +
> drivers/scsi/storvsc_drv.c | 1480 ++++++++++++++++++++++++++++++++++++++
> drivers/staging/hv/Kconfig | 6 -
> drivers/staging/hv/Makefile | 2 -
> drivers/staging/hv/storvsc_drv.c | 1480 --------------------------------------
> 6 files changed, 1490 insertions(+), 1488 deletions(-)
What tree is this against? The hv/storvsc_drv.c in upstream only has
jejb@dabdike> wc -l drivers/staging/hv/storvsc_drv.c
792 drivers/staging/hv/storvsc_drv.c
i.e. whatever you're sending is double the length (and obviously I have
trouble applying the patch.
> +++ b/drivers/scsi/storvsc_drv.c
> @@ -0,0 +1,1480 @@
So not a detailed review, but a couple of structural observations:
The whole driver is a writeout deadlock trap since I assume you intend
for it to be used as root/swap of a linux guest? The writeout deadlock
occurs when we can't make forward progress on a direct writeout I/O
because one of the GFP_ATOMIC memory allocations in your driver fails.
The only way to fix this is to back the allocations with mempools (one
per actual device) so you can guarantee that whatever memory pressure
the system is under, one command can always make the round trip to
storage and back.
You use the locked version of queuecommand, but it looks like you don't
need the host lock in the submit path, so why not just use the unlocked
version?
The bounce buffer handling for discontiguous sg lists is a complete
nightmare. And can't you just fix the hypervisor instead of pulling
this level of nastiness in the driver, I mean really, the last piece of
real SCSI hardware that failed this badly was produced in the dark ages.
Assuming the answer is "no", I really think you need to set the minimum
block size to 4k, which will completely avoid the situation.
Minor, but use accessors like shost_priv()
The SET WINDOW command is an obsolete scanner command ... the comment
about smart issuing it looks completely bogus, but even if there's
something issuing scanner commands and your hypervisor crashes on them,
you need to reject it with ILLEGAL_REQUEST not DID_ERROR.
All the business around max segment size and supplying your own merge
biovec function looks a bit bogus, don't you just want to disable
clustering? This looks like another knock on from the weird hypervisor
sg list handling, where you apparently need one sg entry per page. This
was originally a bug in the circa 1990 era NCR 53c800 host controllers
we then had, so that's actually why the clustering parameter exists ...
it's sort of nostalgic to see you resurrecting such an ancient bug.
James
--
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/