On 03/25/2013 10:28:47 PM, Jia Hongtao wrote:
The MPIC version 2.0 has a MSI errata (errata PIC1 of mpc8544), It causes that neither MSI nor MSI-X can work fine. This is a workaround to allow
MSI-X to function properly.

Signed-off-by: Liu Shuo <soniccat....@gmail.com>
Signed-off-by: Li Yang <le...@freescale.com>
Signed-off-by: Jia Hongtao <hongtao....@freescale.com>
---
arch/powerpc/sysdev/fsl_msi.c | 47 ++++++++++++++++++++++++++++++++++++++++---
 1 file changed, 44 insertions(+), 3 deletions(-)

diff --git a/arch/powerpc/sysdev/fsl_msi.c b/arch/powerpc/sysdev/fsl_msi.c
index 178c994..d2f8040 100644
--- a/arch/powerpc/sysdev/fsl_msi.c
+++ b/arch/powerpc/sysdev/fsl_msi.c
@@ -28,6 +28,8 @@
 #include "fsl_msi.h"
 #include "fsl_pci.h"

+#define MSI_HW_ERRATA_ENDIAN 0x00000010

This should probably be kept in the same place as the other msi->features definitions (e.g. FSL_PIC_IP_*).

+/* MPIC version 2.0 has erratum PIC1 */
+static int mpic_has_errata(void)
+{
+       if (mpic_primary_get_version() == 0x0200)
+               return 1;
+
+       return 0;
+}

mpic_has_erratum_pic1()

+ if ((features->fsl_pic_ip & FSL_PIC_IP_MASK) == FSL_PIC_IP_MPIC) {
+               rc = mpic_has_errata();
+               if (rc > 0) {
+                       msi->feature |= MSI_HW_ERRATA_ENDIAN;
+               } else if (rc < 0) {
+                       err = rc;
+                       goto error_out;
+               }

When would mpic_has_errata() ever return a negative value (maybe mpic_primary_get_version could fail, but you don't allow for that in the interface)?

If you're not going to add a way for errors to be returned back, just do:

if (mpic_has_erratum_pic1())
        msi->feature |= MSI_HW_ERRATA_ENDIAN;

-Scott
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to