linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] powerpc/85xx: workaround for chips with MSI hareware errata to support MSI-X
@ 2012-07-16  3:35 Jia Hongtao
  2012-07-16 23:20 ` Scott Wood
  0 siblings, 1 reply; 4+ messages in thread
From: Jia Hongtao @ 2012-07-16  3:35 UTC (permalink / raw)
  To: linuxppc-dev, galak; +Cc: soniccat.liu, b38951

From: Liu Shuo <soniccat.liu@gmail.com>

The MPIC chip with version 2.0 has a MSI errata (errata PIC1 of mpc8544),
It causes that neither MSI nor MSI-X can work fine. There is a workaround
to allow MSI-X to function properly.

Signed-off-by: Liu Shuo <soniccat.liu@gmail.com>
Signed-off-by: Li Yang <leoli@freescale.com>
---
 arch/powerpc/include/asm/mpic.h |    3 ++
 arch/powerpc/sysdev/fsl_msi.c   |   63 +++++++++++++++++++++++++++++++++++++-
 arch/powerpc/sysdev/fsl_msi.h   |    3 ++
 3 files changed, 67 insertions(+), 2 deletions(-)

diff --git a/arch/powerpc/include/asm/mpic.h b/arch/powerpc/include/asm/mpic.h
index c9f698a..a9e4f937 100644
--- a/arch/powerpc/include/asm/mpic.h
+++ b/arch/powerpc/include/asm/mpic.h
@@ -110,6 +110,9 @@
 #define 	MPIC_VECPRI_SENSE_MASK			0x00400000
 #define MPIC_IRQ_DESTINATION		0x00010
 
+#define 	MPIC_FSL_BRR1				0x00000
+#define 	MPIC_FSL_BRR1_VER			0x0000ffff
+
 #define MPIC_MAX_IRQ_SOURCES	2048
 #define MPIC_MAX_CPUS		32
 #define MPIC_MAX_ISU		32
diff --git a/arch/powerpc/sysdev/fsl_msi.c b/arch/powerpc/sysdev/fsl_msi.c
index 6e097de..f2d340a 100644
--- a/arch/powerpc/sysdev/fsl_msi.c
+++ b/arch/powerpc/sysdev/fsl_msi.c
@@ -98,8 +98,23 @@ static int fsl_msi_init_allocator(struct fsl_msi *msi_data)
 
 static int fsl_msi_check_device(struct pci_dev *pdev, int nvec, int type)
 {
+	struct fsl_msi *msi;
+
 	if (type == PCI_CAP_ID_MSIX)
 		pr_debug("fslmsi: MSI-X untested, trying anyway.\n");
+	else if (type == PCI_CAP_ID_MSI) {
+		/*
+		 * MPIC chip with 2.0 version has erratum PIC1. It
+		 * causes that neither MSI nor MSI-X can work fine.
+		 * There is a workaround to allow MSI-X to function
+		 * properly.
+		 */
+		list_for_each_entry(msi, &msi_head, list) {
+			if ((msi->feature & MSI_HW_ERRATA_MASK)
+						== MSI_HW_ERRATA_ENDIAN)
+				return -EINVAL;
+		}
+	}
 
 	return 0;
 }
@@ -142,7 +157,11 @@ static void fsl_compose_msi_msg(struct pci_dev *pdev, int hwirq,
 	msg->address_lo = lower_32_bits(address);
 	msg->address_hi = upper_32_bits(address);
 
-	msg->data = hwirq;
+	/* See the comment in fsl_msi_check_device() */
+	if ((msi_data->feature & MSI_HW_ERRATA_MASK) == MSI_HW_ERRATA_ENDIAN)
+		msg->data = __swab32(hwirq);
+	else
+		msg->data = hwirq;
 
 	pr_debug("%s: allocated srs: %d, ibs: %d\n",
 		__func__, hwirq / IRQS_PER_MSI_REG, hwirq % IRQS_PER_MSI_REG);
@@ -359,13 +378,43 @@ static int __devinit fsl_msi_setup_hwirq(struct fsl_msi *msi,
 	return 0;
 }
 
+/* MPIC chip with 2.0 version has erratum PIC1 */
+static int mpic_has_errata(struct platform_device *dev)
+{
+	struct device_node *mpic_node;
+
+	mpic_node = of_irq_find_parent(dev->dev.of_node);
+	if (mpic_node) {
+		u32 *reg_base, brr1 = 0;
+		/* Get the PIC reg base */
+		reg_base = of_iomap(mpic_node, 0);
+		of_node_put(mpic_node);
+		if (!reg_base) {
+			dev_err(&dev->dev, "ioremap problem failed.\n");
+			return -EIO;
+		}
+
+		/* Get the mpic chip version from block revision register 1 */
+		brr1 = in_be32(reg_base + MPIC_FSL_BRR1);
+		iounmap(reg_base);
+		if ((brr1 & MPIC_FSL_BRR1_VER) == 0x0200)
+			return 1;
+	} else {
+		dev_err(&dev->dev, "MSI can't find his parent mpic node.\n");
+		of_node_put(mpic_node);
+		return -ENODEV;
+	}
+
+	return 0;
+}
+
 static const struct of_device_id fsl_of_msi_ids[];
 static int __devinit fsl_of_msi_probe(struct platform_device *dev)
 {
 	const struct of_device_id *match;
 	struct fsl_msi *msi;
 	struct resource res;
-	int err, i, j, irq_index, count;
+	int err, i, j, irq_index, count, errata;
 	int rc;
 	const u32 *p;
 	struct fsl_msi_feature *features;
@@ -421,6 +470,16 @@ static int __devinit fsl_of_msi_probe(struct platform_device *dev)
 
 	msi->feature = features->fsl_pic_ip;
 
+	if ((features->fsl_pic_ip & FSL_PIC_IP_MASK) == FSL_PIC_IP_MPIC) {
+		errata = mpic_has_errata(dev);
+		if (errata > 0) {
+			msi->feature |= MSI_HW_ERRATA_ENDIAN;
+		} else if (errata < 0) {
+			err = errata;
+			goto error_out;
+		}
+	}
+
 	/*
 	 * Remember the phandle, so that we can match with any PCI nodes
 	 * that have an "fsl,msi" property.
diff --git a/arch/powerpc/sysdev/fsl_msi.h b/arch/powerpc/sysdev/fsl_msi.h
index 8225f86..354d546 100644
--- a/arch/powerpc/sysdev/fsl_msi.h
+++ b/arch/powerpc/sysdev/fsl_msi.h
@@ -25,6 +25,9 @@
 #define FSL_PIC_IP_IPIC   0x00000002
 #define FSL_PIC_IP_VMPIC  0x00000003
 
+#define MSI_HW_ERRATA_MASK   0x000000F0
+#define MSI_HW_ERRATA_ENDIAN 0x00000010
+
 struct fsl_msi {
 	struct irq_domain *irqhost;
 
-- 
1.7.5.1

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

* Re: [PATCH] powerpc/85xx: workaround for chips with MSI hareware errata to support MSI-X
  2012-07-16  3:35 [PATCH] powerpc/85xx: workaround for chips with MSI hareware errata to support MSI-X Jia Hongtao
@ 2012-07-16 23:20 ` Scott Wood
  2012-07-17  2:19   ` Jia Hongtao-B38951
  2012-07-17  6:18   ` Jia Hongtao-B38951
  0 siblings, 2 replies; 4+ messages in thread
From: Scott Wood @ 2012-07-16 23:20 UTC (permalink / raw)
  To: Jia Hongtao; +Cc: linuxppc-dev, soniccat.liu

On 07/15/2012 10:35 PM, Jia Hongtao wrote:
> From: Liu Shuo <soniccat.liu@gmail.com>
> 
> The MPIC chip with version 2.0 has a MSI errata (errata PIC1 of mpc8544),
> It causes that neither MSI nor MSI-X can work fine. There is a workaround
> to allow MSI-X to function properly.

s/There is/This is/

There is also a workaround for regular MSI to function properly, though
this patch does not implement it.

> +/* MPIC chip with 2.0 version has erratum PIC1 */
> +static int mpic_has_errata(struct platform_device *dev)
> +{
> +	struct device_node *mpic_node;
> +
> +	mpic_node = of_irq_find_parent(dev->dev.of_node);
> +	if (mpic_node) {
> +		u32 *reg_base, brr1 = 0;
> +		/* Get the PIC reg base */
> +		reg_base = of_iomap(mpic_node, 0);
> +		of_node_put(mpic_node);
> +		if (!reg_base) {
> +			dev_err(&dev->dev, "ioremap problem failed.\n");
> +			return -EIO;
> +		}
> +
> +		/* Get the mpic chip version from block revision register 1 */
> +		brr1 = in_be32(reg_base + MPIC_FSL_BRR1);
> +		iounmap(reg_base);
> +		if ((brr1 & MPIC_FSL_BRR1_VER) == 0x0200)
> +			return 1;

There's already been a patch posted that includes BRR1 checking:
http://patchwork.ozlabs.org/patch/169713/

Please coordinate with that.  Have the MPIC code read the version once,
and expose it to the MSI driver, rather than digging directly into the
non-MSI MPIC registers from here.

> diff --git a/arch/powerpc/sysdev/fsl_msi.h b/arch/powerpc/sysdev/fsl_msi.h
> index 8225f86..354d546 100644
> --- a/arch/powerpc/sysdev/fsl_msi.h
> +++ b/arch/powerpc/sysdev/fsl_msi.h
> @@ -25,6 +25,9 @@
>  #define FSL_PIC_IP_IPIC   0x00000002
>  #define FSL_PIC_IP_VMPIC  0x00000003
>  
> +#define MSI_HW_ERRATA_MASK   0x000000F0
> +#define MSI_HW_ERRATA_ENDIAN 0x00000010

Why do we need a mask for this?

-Scott

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

* RE: [PATCH] powerpc/85xx: workaround for chips with MSI hareware errata to support MSI-X
  2012-07-16 23:20 ` Scott Wood
@ 2012-07-17  2:19   ` Jia Hongtao-B38951
  2012-07-17  6:18   ` Jia Hongtao-B38951
  1 sibling, 0 replies; 4+ messages in thread
From: Jia Hongtao-B38951 @ 2012-07-17  2:19 UTC (permalink / raw)
  To: Wood Scott-B07421; +Cc: linuxppc-dev@lists.ozlabs.org, soniccat.liu@gmail.com

DQoNCj4gLS0tLS1PcmlnaW5hbCBNZXNzYWdlLS0tLS0NCj4gRnJvbTogV29vZCBTY290dC1CMDc0
MjENCj4gU2VudDogVHVlc2RheSwgSnVseSAxNywgMjAxMiA3OjIwIEFNDQo+IFRvOiBKaWEgSG9u
Z3Rhby1CMzg5NTENCj4gQ2M6IGxpbnV4cHBjLWRldkBsaXN0cy5vemxhYnMub3JnOyBnYWxha0Br
ZXJuZWwuY3Jhc2hpbmcub3JnOw0KPiBzb25pY2NhdC5saXVAZ21haWwuY29tDQo+IFN1YmplY3Q6
IFJlOiBbUEFUQ0hdIHBvd2VycGMvODV4eDogd29ya2Fyb3VuZCBmb3IgY2hpcHMgd2l0aCBNU0kg
aGFyZXdhcmUNCj4gZXJyYXRhIHRvIHN1cHBvcnQgTVNJLVgNCj4gDQo+IE9uIDA3LzE1LzIwMTIg
MTA6MzUgUE0sIEppYSBIb25ndGFvIHdyb3RlOg0KPiA+IEZyb206IExpdSBTaHVvIDxzb25pY2Nh
dC5saXVAZ21haWwuY29tPg0KPiA+DQo+ID4gVGhlIE1QSUMgY2hpcCB3aXRoIHZlcnNpb24gMi4w
IGhhcyBhIE1TSSBlcnJhdGEgKGVycmF0YSBQSUMxIG9mDQo+IG1wYzg1NDQpLA0KPiA+IEl0IGNh
dXNlcyB0aGF0IG5laXRoZXIgTVNJIG5vciBNU0ktWCBjYW4gd29yayBmaW5lLiBUaGVyZSBpcyBh
DQo+IHdvcmthcm91bmQNCj4gPiB0byBhbGxvdyBNU0ktWCB0byBmdW5jdGlvbiBwcm9wZXJseS4N
Cj4gDQo+IHMvVGhlcmUgaXMvVGhpcyBpcy8NCj4gDQo+IFRoZXJlIGlzIGFsc28gYSB3b3JrYXJv
dW5kIGZvciByZWd1bGFyIE1TSSB0byBmdW5jdGlvbiBwcm9wZXJseSwgdGhvdWdoDQo+IHRoaXMg
cGF0Y2ggZG9lcyBub3QgaW1wbGVtZW50IGl0Lg0KDQpZb3UgYXJlIHJpZ2h0LCB0aGlzIHBhdGNo
IG9ubHkgdG8gbWFrZSBNU0ktWCB3b3JrLiBGb3Igbm93IHdlIGhhdmUgbm8gcGxhbg0KdG8gbWFr
ZSBNU0kgd29yayB0b28uDQoNCj4gDQo+ID4gKy8qIE1QSUMgY2hpcCB3aXRoIDIuMCB2ZXJzaW9u
IGhhcyBlcnJhdHVtIFBJQzEgKi8NCj4gPiArc3RhdGljIGludCBtcGljX2hhc19lcnJhdGEoc3Ry
dWN0IHBsYXRmb3JtX2RldmljZSAqZGV2KQ0KPiA+ICt7DQo+ID4gKwlzdHJ1Y3QgZGV2aWNlX25v
ZGUgKm1waWNfbm9kZTsNCj4gPiArDQo+ID4gKwltcGljX25vZGUgPSBvZl9pcnFfZmluZF9wYXJl
bnQoZGV2LT5kZXYub2Zfbm9kZSk7DQo+ID4gKwlpZiAobXBpY19ub2RlKSB7DQo+ID4gKwkJdTMy
ICpyZWdfYmFzZSwgYnJyMSA9IDA7DQo+ID4gKwkJLyogR2V0IHRoZSBQSUMgcmVnIGJhc2UgKi8N
Cj4gPiArCQlyZWdfYmFzZSA9IG9mX2lvbWFwKG1waWNfbm9kZSwgMCk7DQo+ID4gKwkJb2Zfbm9k
ZV9wdXQobXBpY19ub2RlKTsNCj4gPiArCQlpZiAoIXJlZ19iYXNlKSB7DQo+ID4gKwkJCWRldl9l
cnIoJmRldi0+ZGV2LCAiaW9yZW1hcCBwcm9ibGVtIGZhaWxlZC5cbiIpOw0KPiA+ICsJCQlyZXR1
cm4gLUVJTzsNCj4gPiArCQl9DQo+ID4gKw0KPiA+ICsJCS8qIEdldCB0aGUgbXBpYyBjaGlwIHZl
cnNpb24gZnJvbSBibG9jayByZXZpc2lvbiByZWdpc3RlciAxDQo+ICovDQo+ID4gKwkJYnJyMSA9
IGluX2JlMzIocmVnX2Jhc2UgKyBNUElDX0ZTTF9CUlIxKTsNCj4gPiArCQlpb3VubWFwKHJlZ19i
YXNlKTsNCj4gPiArCQlpZiAoKGJycjEgJiBNUElDX0ZTTF9CUlIxX1ZFUikgPT0gMHgwMjAwKQ0K
PiA+ICsJCQlyZXR1cm4gMTsNCj4gDQo+IFRoZXJlJ3MgYWxyZWFkeSBiZWVuIGEgcGF0Y2ggcG9z
dGVkIHRoYXQgaW5jbHVkZXMgQlJSMSBjaGVja2luZzoNCj4gaHR0cDovL3BhdGNod29yay5vemxh
YnMub3JnL3BhdGNoLzE2OTcxMy8NCj4gDQo+IFBsZWFzZSBjb29yZGluYXRlIHdpdGggdGhhdC4g
IEhhdmUgdGhlIE1QSUMgY29kZSByZWFkIHRoZSB2ZXJzaW9uIG9uY2UsDQo+IGFuZCBleHBvc2Ug
aXQgdG8gdGhlIE1TSSBkcml2ZXIsIHJhdGhlciB0aGFuIGRpZ2dpbmcgZGlyZWN0bHkgaW50byB0
aGUNCj4gbm9uLU1TSSBNUElDIHJlZ2lzdGVycyBmcm9tIGhlcmUuDQoNCk9rLCBJIHJlYmFzZWQg
dGhlIHBhdGNoIGFnYWluc3Qga3VtYXJfbmV4dCBicmFuY2ggYW5kIHRoZSBwYXRjaCB5b3UgbWVu
dGlvbmVkDQpoYXMgbm90IGFwcGxpZWQgeWV0LiBBbnl3YXkgSSB3aWxsIGZpeCB0aGlzLg0KDQoN
Cj4gDQo+ID4gZGlmZiAtLWdpdCBhL2FyY2gvcG93ZXJwYy9zeXNkZXYvZnNsX21zaS5oDQo+IGIv
YXJjaC9wb3dlcnBjL3N5c2Rldi9mc2xfbXNpLmgNCj4gPiBpbmRleCA4MjI1Zjg2Li4zNTRkNTQ2
IDEwMDY0NA0KPiA+IC0tLSBhL2FyY2gvcG93ZXJwYy9zeXNkZXYvZnNsX21zaS5oDQo+ID4gKysr
IGIvYXJjaC9wb3dlcnBjL3N5c2Rldi9mc2xfbXNpLmgNCj4gPiBAQCAtMjUsNiArMjUsOSBAQA0K
PiA+ICAjZGVmaW5lIEZTTF9QSUNfSVBfSVBJQyAgIDB4MDAwMDAwMDINCj4gPiAgI2RlZmluZSBG
U0xfUElDX0lQX1ZNUElDICAweDAwMDAwMDAzDQo+ID4NCj4gPiArI2RlZmluZSBNU0lfSFdfRVJS
QVRBX01BU0sgICAweDAwMDAwMEYwDQo+ID4gKyNkZWZpbmUgTVNJX0hXX0VSUkFUQV9FTkRJQU4g
MHgwMDAwMDAxMA0KPiANCj4gV2h5IGRvIHdlIG5lZWQgYSBtYXNrIGZvciB0aGlzPw0KPiANCg0K
SSBkb24ndCBrbm93IHlldCBidXQgSSB3aWxsIGZpbmQgb3V0Lg0KVGhpcyBwYXRjaCB3YXMgZnJv
bSBMaXUgU2h1byBzbyBJIG5lZWQgdG8gZG8gbW9yZSBpbnZlc3RpZ2F0aW9uLg0KDQotSmlhIEhv
bmd0YW8uDQoNCg0K

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

* RE: [PATCH] powerpc/85xx: workaround for chips with MSI hareware errata to support MSI-X
  2012-07-16 23:20 ` Scott Wood
  2012-07-17  2:19   ` Jia Hongtao-B38951
@ 2012-07-17  6:18   ` Jia Hongtao-B38951
  1 sibling, 0 replies; 4+ messages in thread
From: Jia Hongtao-B38951 @ 2012-07-17  6:18 UTC (permalink / raw)
  To: Wood Scott-B07421; +Cc: linuxppc-dev@lists.ozlabs.org, soniccat.liu@gmail.com

DQo+IC0tLS0tT3JpZ2luYWwgTWVzc2FnZS0tLS0tDQo+IEZyb206IFdvb2QgU2NvdHQtQjA3NDIx
DQo+IFNlbnQ6IFR1ZXNkYXksIEp1bHkgMTcsIDIwMTIgNzoyMCBBTQ0KPiBUbzogSmlhIEhvbmd0
YW8tQjM4OTUxDQo+IENjOiBsaW51eHBwYy1kZXZAbGlzdHMub3psYWJzLm9yZzsgZ2FsYWtAa2Vy
bmVsLmNyYXNoaW5nLm9yZzsNCj4gc29uaWNjYXQubGl1QGdtYWlsLmNvbQ0KPiBTdWJqZWN0OiBS
ZTogW1BBVENIXSBwb3dlcnBjLzg1eHg6IHdvcmthcm91bmQgZm9yIGNoaXBzIHdpdGggTVNJIGhh
cmV3YXJlDQo+IGVycmF0YSB0byBzdXBwb3J0IE1TSS1YDQo+ID4gZGlmZiAtLWdpdCBhL2FyY2gv
cG93ZXJwYy9zeXNkZXYvZnNsX21zaS5oDQo+IGIvYXJjaC9wb3dlcnBjL3N5c2Rldi9mc2xfbXNp
LmgNCj4gPiBpbmRleCA4MjI1Zjg2Li4zNTRkNTQ2IDEwMDY0NA0KPiA+IC0tLSBhL2FyY2gvcG93
ZXJwYy9zeXNkZXYvZnNsX21zaS5oDQo+ID4gKysrIGIvYXJjaC9wb3dlcnBjL3N5c2Rldi9mc2xf
bXNpLmgNCj4gPiBAQCAtMjUsNiArMjUsOSBAQA0KPiA+ICAjZGVmaW5lIEZTTF9QSUNfSVBfSVBJ
QyAgIDB4MDAwMDAwMDINCj4gPiAgI2RlZmluZSBGU0xfUElDX0lQX1ZNUElDICAweDAwMDAwMDAz
DQo+ID4NCj4gPiArI2RlZmluZSBNU0lfSFdfRVJSQVRBX01BU0sgICAweDAwMDAwMEYwDQo+ID4g
KyNkZWZpbmUgTVNJX0hXX0VSUkFUQV9FTkRJQU4gMHgwMDAwMDAxMA0KPiANCj4gV2h5IGRvIHdl
IG5lZWQgYSBtYXNrIGZvciB0aGlzPw0KPiANCg0KSXQgc2VlbXMgdGhpcyBtYXNrIGlzIG5vdCBu
ZWVkZWQuDQpJIHdpbGwgZml4IHRoaXMgaW4gdGhlIG5leHQgdmVyc2lvbi4NCg0KVGhhbmtzLg0K
LUhvbmd0YW8uDQo=

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

end of thread, other threads:[~2012-07-17  6:18 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-07-16  3:35 [PATCH] powerpc/85xx: workaround for chips with MSI hareware errata to support MSI-X Jia Hongtao
2012-07-16 23:20 ` Scott Wood
2012-07-17  2:19   ` Jia Hongtao-B38951
2012-07-17  6:18   ` Jia Hongtao-B38951

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).