Re: [PATCH] ata: libata-scsi: fix SYNCHRONIZE CACHE (16) command failure

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

 



On Nov 07, 2022 / 10:08, Damien Le Moal wrote:
> On 11/7/22 09:47, Shin'ichiro Kawasaki wrote:
> > SAT SCSI/ATA Translation specification requires SCSI SYNCHRONIZE CACHE
> > (10) and (16) commands both shall be translated to ATA flush command.
> > However, libata translates only SYNCHRONIZE CACHE (10). This results in
> > SYNCHRONIZE CACHE (16) command failures. To avoid the failure, add
> > support for SYNCHRONIZE CACHE (16).
> 
> Also mention that SYNCHRONIZE CACHE 16 is mandatory for ZBC drives (see
> below).
> 
> > 
> > This patch conflicts with kernels version 5.4 and older. Conflict
> > resolution will be required to back port to them.
> 
> The above is not needed.
> 
> > 
> > Signed-off-by: Shin'ichiro Kawasaki <shinichiro.kawasaki@xxxxxxx>
> > Cc: stable@xxxxxxxxxxxxxxx # v5.10+
> 
> Remove the version number.

Thanks. Will reflect these comments to v2.

> 
> > ---
> >  drivers/ata/libata-scsi.c | 3 +++
> >  1 file changed, 3 insertions(+)
> > 
> > diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c
> > index e2ebb0b065e2..61cd4e90e4e7 100644
> > --- a/drivers/ata/libata-scsi.c
> > +++ b/drivers/ata/libata-scsi.c
> > @@ -3264,6 +3264,7 @@ static unsigned int ata_scsiop_maint_in(struct ata_scsi_args *args, u8 *rbuf)
> >  	case REPORT_LUNS:
> >  	case REQUEST_SENSE:
> >  	case SYNCHRONIZE_CACHE:
> > +	case SYNCHRONIZE_CACHE_16:
> >  	case REZERO_UNIT:
> >  	case SEEK_6:
> >  	case SEEK_10:
> > @@ -3922,6 +3923,7 @@ static inline ata_xlat_func_t ata_get_xlat_func(struct ata_device *dev, u8 cmd)
> >  		return ata_scsi_write_same_xlat;
> >  
> >  	case SYNCHRONIZE_CACHE:
> > +	case SYNCHRONIZE_CACHE_16:
> >  		if (ata_try_flush_cache(dev))
> >  			return ata_scsi_flush_xlat;
> >  		break;
> > @@ -4145,6 +4147,7 @@ void ata_scsi_simulate(struct ata_device *dev, struct scsi_cmnd *cmd)
> >  	 * turning this into a no-op.
> >  	 */
> >  	case SYNCHRONIZE_CACHE:
> > +	case SYNCHRONIZE_CACHE_16:
> >  		fallthrough;
> >  
> >  	/* no-op's, complete with success */
> 
> This also needs a patch for sd.c to always use SYNCHRONIZE CACHE 16 for
> ZBC drives.

I see. Will prepare another patch and post to linux-scsi.

-- 
Shin'ichiro Kawasaki



[Index of Archives]     [Linux Filesystems]     [Linux SCSI]     [Linux RAID]     [Git]     [Kernel Newbies]     [Linux Newbie]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Samba]     [Device Mapper]

  Powered by Linux