Re: [PATCH 2.6.31] sata_promise: update reset code

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

 



Jeff Garzik writes:
 > On 09/15/2009 09:08 AM, Mikael Pettersson wrote:
 > > sata_promise's reset code has deviated quite a bit from
 > > the Promise reference driver's, and it has been observed
 > > to fail to recover from errors in some cases.
 > >
 > > This patch thus updates the reset code to more closely
 > > match the reference driver:
 > >
 > > - soft reset (pdc_reset_port):
 > >    * wait for ATA engine to not be in packet command mode
 > >      (2nd gen only)
 > >    * write reset bit in PDC_CTLSTAT before the first read
 > >      in the loop
 > >    * for 2nd gen SATA follow up with FPDMA reset and clearing
 > >      error status registers
 > > - hard reset (pdc_sata_hardreset):
 > >    * wait for ATA engine to not be in packet command mode
 > >      (2nd gen only)
 > >    * reset ATA engine via the PCI control register
 > >    * Tejun's change to use non-waiting hardreset + follow-up SRST
 > >
 > > I'm not changing the hotplug mask bits since they are taken care
 > > of by sata_promise's ->freeze() and ->thaw() operations. And I'm
 > > not writing the PMP port # because that's always zero (for now).
 > >
 > > Tested here on various controllers. In particular, one disk
 > > which used to timeout and fail to recover from certain hdparm
 > > and smartmonctl commands now works nicely.
 > >
 > > Signed-off-by: Mikael Pettersson<mikpe@xxxxxxxx>
 > > ---
 > > I should have submitted this long ago, sorry.
 > > This update involves a lot of details, so it should probably sit
 > > in a testing tree for a while before going upstream.
 > >
 > >   drivers/ata/sata_promise.c |  121 ++++++++++++++++++++++++++++++++++++++++++++-
 > >   1 file changed, 120 insertions(+), 1 deletion(-)
 > 
 > applied -- I would rather push it to upstream and see what happens, 
 > given that waiting would probably mean less test exposure at this point 
 > [unless we wait a full release cycle]

Agreed, using 2.6.32-rc as the testing grounds for this makes sense.

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

[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