All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 1/1] Big endian swap for Marvell 6440 SAS driver
@ 2011-06-10 13:56 Cédric Cano
  2011-06-11 22:45   ` Benjamin Herrenschmidt
  0 siblings, 1 reply; 8+ messages in thread
From: Cédric Cano @ 2011-06-10 13:56 UTC (permalink / raw)
  To: linuxppc-dev

Hi,

Marvell SAS driver doesn't work on powerpc architecture due to big 
endian swap. I've tested it with the MV6440 chip.
Here you can find the patch for Linux 2.6.39.1.

Cedric Cano

Signed-off-by: Cedric Cano <ccano@interfaceconcept.com>
---
--- drivers/scsi/mvsas/mv_sas.c    2011-06-10 15:50:04.000000000 +0200
+++ drivers/scsi/mvsas/mv_sas.c    2011-06-10 15:50:12.000000000 +0200
@@ -1143,6 +1143,14 @@
      MVS_CHIP_DISP->write_port_cfg_addr(mvi, i, PHYR_SATA_SIG0);
      s[0] = MVS_CHIP_DISP->read_port_cfg_data(mvi, i);

+    /* swap for big endian devices because of use of these data in bytes */
+#ifdef __BIG_ENDIAN
+    s[0] = swab32(s[0]);
+    s[1] = swab32(s[1]);
+    s[2] = swab32(s[2]);
+    s[3] = swab32(s[3]);
+#endif /* __BIG_ENDIAN */
+
      /* Workaround: take some ATAPI devices for ATA */
      if (((s[1] & 0x00FFFFFF) == 0x00EB1401) && (*(u8 *)&s[3] == 0x01))
          s[1] = 0x00EB1401 | (*((u8 *)&s[1] + 3) & 0x10);

---

^ permalink raw reply	[flat|nested] 8+ messages in thread
* [PATCH 1/1] Big endian swap for Marvell 6440 SAS driver
@ 2011-06-14  9:31 Cédric Cano
  0 siblings, 0 replies; 8+ messages in thread
From: Cédric Cano @ 2011-06-14  9:31 UTC (permalink / raw)
  To: linux-scsi

Hi,

Marvell SAS driver doesn't work on powerpc architecture due to big 
endian swap. I've tested it with the MV6440 chip.
Here you can find the patch for Linux 2.6.39.1.

Cedric Cano

Signed-off-by: Cedric Cano<ccano@interfaceconcept.com>
---
diff -Naur drivers/scsi/mvsas/mv_sas.c drivers/scsi/mvsas/mv_sas.c
--- drivers/scsi/mvsas/mv_sas.c    2011-06-03 02:34:20.000000000 +0200
+++ drivers/scsi/mvsas/mv_sas.c    2011-06-14 09:27:15.000000000 +0200
@@ -1143,6 +1143,12 @@
      MVS_CHIP_DISP->write_port_cfg_addr(mvi, i, PHYR_SATA_SIG0);
      s[0] = MVS_CHIP_DISP->read_port_cfg_data(mvi, i);

+    /* swap for big endian devices because of use of these data in 
bytes */
+    s[0] = le32_to_cpu(s[0]);
+    s[1] = le32_to_cpu(s[1]);
+    s[2] = le32_to_cpu(s[2]);
+    s[3] = le32_to_cpu(s[3]);
+
      /* Workaround: take some ATAPI devices for ATA */
      if (((s[1]&  0x00FFFFFF) == 0x00EB1401)&&  (*(u8 *)&s[3] == 0x01))
          s[1] = 0x00EB1401 | (*((u8 *)&s[1] + 3)&  0x10);



^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2011-06-14  9:31 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-06-10 13:56 [PATCH 1/1] Big endian swap for Marvell 6440 SAS driver Cédric Cano
2011-06-11 22:45 ` Benjamin Herrenschmidt
2011-06-11 22:45   ` Benjamin Herrenschmidt
2011-06-14  6:42   ` Cédric Cano
2011-06-14  6:42     ` Cédric Cano
2011-06-14  7:05     ` Benjamin Herrenschmidt
2011-06-14  7:05       ` Benjamin Herrenschmidt
  -- strict thread matches above, loose matches on Subject: below --
2011-06-14  9:31 Cédric Cano

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.