libata-pmp.c patch for Silicon Image 3826 port multiplier

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

 



Hello linux-ide mailing list,

I recently purchased and equipped one of my Slackware boxes with a
Rosewill RAID enclosure (RSV-S8), which claimed to use a Sil3726 PMP
chipset, but which actually uses a Sil3826 chipset.  This appears to
be some relatively new silicon, and (presumably) a replacement for the
3726 going forward.

I had some difficulties using this hardware at first - excessively
long delays linking to the PMP at startup - but once I discovered the
chipset version issue, it was simple to fix -- libata just needs to
apply the same PMP quirks that are currently used on the 3726, to the
3826.  I've done this in a local kernel build and it's working great
so far.

The same bug/fix has been posted to the Red Hat bug tracker:
https://bugzilla.redhat.com/show_bug.cgi?id=890237 -- although the
patch noted there (in the PDF (!?) attachment) appears incomplete.

My somewhat-redundant patch, based on the current linux-stable version
from git, is pasted inline below.  It should be very simple and
unsurprising.

Best,

Terry Suereth
terry.suereth@xxxxxxxxx



--- libata-pmp.c.old 2013-01-13 13:42:56.582780772 -0800
+++ libata-pmp.c 2013-01-13 13:43:33.670964680 -0800
@@ -289,24 +289,24 @@

  /* Disable sending Early R_OK.
  * With "cached read" HDD testing and multiple ports busy on a SATA
- * host controller, 3726 PMP will very rarely drop a deferred
+ * host controller, 3x26 PMP will very rarely drop a deferred
  * R_OK that was intended for the host. Symptom will be all
  * 5 drives under test will timeout, get reset, and recover.
  */
- if (vendor == 0x1095 && devid == 0x3726) {
+ if (vendor == 0x1095 && (devid == 0x3726 || devid == 0x3826)) {
  u32 reg;

  err_mask = sata_pmp_read(&ap->link, PMP_GSCR_SII_POL, &reg);
  if (err_mask) {
  rc = -EIO;
- reason = "failed to read Sil3726 Private Register";
+ reason = "failed to read Sil3x26 Private Register";
  goto fail;
  }
  reg &= ~0x1;
  err_mask = sata_pmp_write(&ap->link, PMP_GSCR_SII_POL, reg);
  if (err_mask) {
  rc = -EIO;
- reason = "failed to write Sil3726 Private Register";
+ reason = "failed to write Sil3x26 Private Register";
  goto fail;
  }
  }
@@ -383,8 +383,8 @@
  u16 devid = sata_pmp_gscr_devid(gscr);
  struct ata_link *link;

- if (vendor == 0x1095 && devid == 0x3726) {
- /* sil3726 quirks */
+ if (vendor == 0x1095 && (devid == 0x3726 || devid == 0x3826)) {
+ /* sil3x26 quirks */
  ata_for_each_link(link, ap, EDGE) {
  /* link reports offline after LPM */
  link->flags |= ATA_LFLAG_NO_LPM;
--
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