Re: [patch 1/1] scsi: fix check of PQ and PDT bits for WLUNs

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thursday 21 August 2008 22:14, James Bottomley wrote:
> On Tue, 2008-08-12 at 13:40 +0200, Martin Petermann wrote:
> > plain text document attachment (scsi_scan.diff)
> > From: Martin Petermann <martin@xxxxxxxxxxxxxxxxxx>
> > 
> > With kernel version 2.6.19 a check was introduced not to create a generic
> > SCSI device for devices that return PQ=1 and PDT=0x1f. For WLUNs (see 
> > SAM-3, p. 41ff) generic SCSI devices should be created unconditionally
> > without looking at the PQ bit. I'm referring here to the thread "With kernel
> > 2.6.19 no sg devices for devices that return PQ=1, PDT=0x1f" of the 
> > linux-scsi forum. This is my proposed fix.
> > 
> > Signed-off-by: Martin Petermann <martin@xxxxxxxxxxxxxxxxxx>
> > 
> > ---
> >  drivers/scsi/scsi_scan.c |    7 ++++++-
> >  1 file changed, 6 insertions(+), 1 deletion(-)
> > 
> > --- a/drivers/scsi/scsi_scan.c	2008-08-12 12:51:32.000000000 +0200
> > +++ b/drivers/scsi/scsi_scan.c	2008-08-12 12:58:16.000000000 +0200
> > @@ -75,6 +75,11 @@
> >  #define SCSI_SCAN_TARGET_PRESENT	1
> >  #define SCSI_SCAN_LUN_PRESENT		2
> >  
> > +#define SCSI_W_LUN_BASE 0xc100
> > +#define SCSI_W_LUN_REPORT_LUNS (SCSI_W_LUN_BASE + 1)
> > +#define SCSI_W_LUN_ACCESS_CONTROL (SCSI_W_LUN_BASE + 2)
> > +#define SCSI_W_LUN_TARGET_LOG_PAGE (SCSI_W_LUN_BASE + 3)
> 
> These need to be in a header file, I think, probably scsi.h
> 
> >  static const char *scsi_null_device_strs = "nullnullnullnull";
> >  
> >  #define MAX_SCSI_LUNS	512
> > @@ -1080,7 +1085,7 @@ static int scsi_probe_and_add_lun(struct
> >  	 * PDT=1Fh none (no FDD connected to the requested logical unit)
> >  	 */
> >  	if (((result[0] >> 5) == 1 || starget->pdt_1f_for_no_lun) &&
> > -	     (result[0] & 0x1f) == 0x1f) {
> > +	    (result[0] & 0x1f) == 0x1f && (lun & 0xff00) != SCSI_W_LUN_BASE) {
> 
> And this should probably be wrapped nicely too.
> 
> >  		SCSI_LOG_SCAN_BUS(3, printk(KERN_INFO
> >  					"scsi scan: peripheral device type"
> >  					" of 31, no device added\n"));
> 
> Does this look OK?
> 
> James
> 
> ---
> 
> diff --git a/drivers/scsi/scsi_scan.c b/drivers/scsi/scsi_scan.c
> index 84b4879..34d0de6 100644
> --- a/drivers/scsi/scsi_scan.c
> +++ b/drivers/scsi/scsi_scan.c
> @@ -1080,7 +1080,8 @@ static int scsi_probe_and_add_lun(struct scsi_target *starget,
>  	 * PDT=1Fh none (no FDD connected to the requested logical unit)
>  	 */
>  	if (((result[0] >> 5) == 1 || starget->pdt_1f_for_no_lun) &&
> -	     (result[0] & 0x1f) == 0x1f) {
> +	    (result[0] & 0x1f) == 0x1f &&
> +	    !scsi_is_wlun(lun)) {
>  		SCSI_LOG_SCAN_BUS(3, printk(KERN_INFO
>  					"scsi scan: peripheral device type"
>  					" of 31, no device added\n"));
> diff --git a/include/scsi/scsi.h b/include/scsi/scsi.h
> index 5c40cc5..192f871 100644
> --- a/include/scsi/scsi.h
> +++ b/include/scsi/scsi.h
> @@ -309,6 +309,20 @@ struct scsi_lun {
>  };
> 
>  /*
> + * The Well Known LUNS (SAM-3) in our int representation of a LUN
> + */
> +#define SCSI_W_LUN_BASE 0xc100
> +#define SCSI_W_LUN_REPORT_LUNS (SCSI_W_LUN_BASE + 1)
> +#define SCSI_W_LUN_ACCESS_CONTROL (SCSI_W_LUN_BASE + 2)
> +#define SCSI_W_LUN_TARGET_LOG_PAGE (SCSI_W_LUN_BASE + 3)
> +
> +static inline int scsi_is_wlun(unsigned int lun)
> +{
> +	return (lun & 0xff00) == SCSI_W_LUN_BASE;
> +}
> +
> +
> +/*
>   *  MESSAGE CODES
>   */


Looks ok.

So ACK from my side, if required.

Cheers Swen
--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]
  Powered by Linux