linux-pci.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH V2] PCI: enable extended tags support for PCIe devices
@ 2017-01-20 14:20 Sinan Kaya
  2017-02-08 18:25 ` [V2] " Sinan Kaya
  0 siblings, 1 reply; 7+ messages in thread
From: Sinan Kaya @ 2017-01-20 14:20 UTC (permalink / raw)
  To: linux-pci, timur, cov
  Cc: Sinan Kaya, linux-arm-msm, open list, linux-arm-kernel

RWFjaCBQQ0llIGRldmljZSBjYW4gaXNzdWUgdXAgdG8gMzIgdHJhbnNhY3Rpb25zIGF0IGEgdGlt
ZSBieSBkZWZhdWx0LgpFYWNoIHRyYW5zYWN0aW9uIGlzIHRyYWNrZWQgYnkgYSB0YWcgbnVtYmVy
IG9uIHRoZSBidXMuIDIuMi42LjIuClRyYW5zYWN0aW9uIERlc2NyaXB0b3Ig4oCTIFRyYW5zYWN0
aW9uIElEIEZpZWxkIHNlY3Rpb24gb2YgdGhlIFBDSWUgMy4xCnNwZWNpZmljYXRpb24gZGVzY3Jp
YmVzIGV4dGVuZGVkIHRhZ3MuCgozMiB0cmFuc2FjdGlvbiBsaW1pdCBoYXMgYmVlbiBleHRlbmRl
ZCB0byAyNTYgb24gUENJIEV4cHJlc3MuIEFjY29yZGluZwp0byB0aGUgc3BlY2lmaWNhdGlvbiwg
YWxsIFBDSWUgZGV2aWNlcyBhcmUgcmVxdWlyZWQgdG8gc3VwcG9ydCByZWNlaXZpbmcKOC1iaXQg
VGFncyAoVGFnIGNvbXBsZXRlcikuIFRoZSBQQ0llLVBDSSBicmlkZ2VzIGhhbmRsZSB0aGUgdHJh
bnNsYXRpb24Kb2YgOC1iaXQgdGFncyB0byA1LWJpdCB0YWdzLgoKSG93ZXZlciwgdGhlIGdlbmVy
YXRpb24gb2YgOC1iaXQgdGFncyBpcyBsZWZ0IG9wdGlvbmFsIHRvIGEgcGFydGljdWxhciBIVwpp
bXBsZW1lbnRhdGlvbi4gVGhlIGNvZGUgbmVlZHMgdG8gY2hlY2sgSFcgc3VwcG9ydCBiZWZvcmUg
YXR0ZW1wdGluZwp0byBlbmFibGUgZXh0ZW5kZWQgdGFncyBwcm9kdWNlciBjYXBhYmlsaXR5LgoK
MzIgb3V0c3RhbmRpbmcgdHJhbnNhY3Rpb25zIGlzIG5vdCBlbm91Z2ggZm9yIHNvbWUgcGVyZm9y
bWFuY2UgY3JpdGljYWwKYXBwbGljYXRpb25zIGVzcGVjaWFsbHkgd2hlbiBhIGxvdCBvZiBzbWFs
bCBzaXplZCBmcmFtZXMgYXJlIHRyYW5zbWl0dGVkLgoKRXh0ZW5kZWQgdGFncyBzdXBwb3J0IGlu
Y3JlYXNlcyB0aGlzIG51bWJlciB0byAyNTYuIERldmljZXMgbm90CnN1cHBvcnRpbmcgZXh0ZW5k
ZWQgdGFncyB0aWUtb2ZmIHRoaXMgZmllbGQgdG8gMC4gQWNjb3JkaW5nIHRvIEVDTiwgaXQKaXMg
c2FmZSB0byBlbmFibGUgdGhpcyBmZWF0dXJlIGZvciBhbGwgUENJZSBkZXZpY2VzLgoKU2lnbmVk
LW9mZi1ieTogU2luYW4gS2F5YSA8b2theWFAY29kZWF1cm9yYS5vcmc+Ci0tLQogZHJpdmVycy9w
Y2kvcHJvYmUuYyB8IDE2ICsrKysrKysrKysrKysrKysKIDEgZmlsZSBjaGFuZ2VkLCAxNiBpbnNl
cnRpb25zKCspCgpkaWZmIC0tZ2l0IGEvZHJpdmVycy9wY2kvcHJvYmUuYyBiL2RyaXZlcnMvcGNp
L3Byb2JlLmMKaW5kZXggZTE2NGI1Yy4uMTE5MjQ3NSAxMDA2NDQKLS0tIGEvZHJpdmVycy9wY2kv
cHJvYmUuYworKysgYi9kcml2ZXJzL3BjaS9wcm9iZS5jCkBAIC0xNjUwLDEyICsxNjUwLDI4IEBA
IHN0YXRpYyB2b2lkIHByb2dyYW1faHBwX3R5cGUyKHN0cnVjdCBwY2lfZGV2ICpkZXYsIHN0cnVj
dCBocHBfdHlwZTIgKmhwcCkKIAkgKi8KIH0KIAorc3RhdGljIHZvaWQgcGNpX2NvbmZpZ3VyZV9l
eHRlbmRlZF90YWdzKHN0cnVjdCBwY2lfZGV2ICpwZGV2KQoreworCXUzMiBkZXZfY2FwOworCWlu
dCByZXQ7CisKKwlyZXQgPSBwY2llX2NhcGFiaWxpdHlfcmVhZF9kd29yZChwZGV2LCBQQ0lfRVhQ
X0RFVkNBUCwgJmRldl9jYXApOworCisJaWYgKHJldCkKKwkJcmV0dXJuOworCisJaWYgKGRldl9j
YXAgJiBQQ0lfRVhQX0RFVkNBUF9FWFRfVEFHKQorCQlwY2llX2NhcGFiaWxpdHlfc2V0X3dvcmQo
cGRldiwgUENJX0VYUF9ERVZDVEwsCisJCQkJCSBQQ0lfRVhQX0RFVkNUTF9FWFRfVEFHKTsKK30K
Kwogc3RhdGljIHZvaWQgcGNpX2NvbmZpZ3VyZV9kZXZpY2Uoc3RydWN0IHBjaV9kZXYgKmRldikK
IHsKIAlzdHJ1Y3QgaG90cGx1Z19wYXJhbXMgaHBwOwogCWludCByZXQ7CiAKIAlwY2lfY29uZmln
dXJlX21wcyhkZXYpOworCXBjaV9jb25maWd1cmVfZXh0ZW5kZWRfdGFncyhkZXYpOwogCiAJbWVt
c2V0KCZocHAsIDAsIHNpemVvZihocHApKTsKIAlyZXQgPSBwY2lfZ2V0X2hwX3BhcmFtcyhkZXYs
ICZocHApOwotLSAKMS45LjEKCgpfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f
X19fX19fX19fXwpsaW51eC1hcm0ta2VybmVsIG1haWxpbmcgbGlzdApsaW51eC1hcm0ta2VybmVs
QGxpc3RzLmluZnJhZGVhZC5vcmcKaHR0cDovL2xpc3RzLmluZnJhZGVhZC5vcmcvbWFpbG1hbi9s
aXN0aW5mby9saW51eC1hcm0ta2VybmVsCg==

^ permalink raw reply	[flat|nested] 7+ messages in thread
* [PATCH V2] PCI: enable extended tags support for PCIe devices
@ 2017-01-20 14:19 Sinan Kaya
  0 siblings, 0 replies; 7+ messages in thread
From: Sinan Kaya @ 2017-01-20 14:19 UTC (permalink / raw)
  To: okaya; +Cc: Bjorn Helgaas, linux-pci, linux-kernel

Each PCIe device can issue up to 32 transactions at a time by default.
Each transaction is tracked by a tag number on the bus. 2.2.6.2.
Transaction Descriptor – Transaction ID Field section of the PCIe 3.1
specification describes extended tags.

32 transaction limit has been extended to 256 on PCI Express. According
to the specification, all PCIe devices are required to support receiving
8-bit Tags (Tag completer). The PCIe-PCI bridges handle the translation
of 8-bit tags to 5-bit tags.

However, the generation of 8-bit tags is left optional to a particular HW
implementation. The code needs to check HW support before attempting
to enable extended tags producer capability.

32 outstanding transactions is not enough for some performance critical
applications especially when a lot of small sized frames are transmitted.

Extended tags support increases this number to 256. Devices not
supporting extended tags tie-off this field to 0. According to ECN, it
is safe to enable this feature for all PCIe devices.

Signed-off-by: Sinan Kaya <okaya@codeaurora.org>
---
 drivers/pci/probe.c | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)

diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
index e164b5c..1192475 100644
--- a/drivers/pci/probe.c
+++ b/drivers/pci/probe.c
@@ -1650,12 +1650,28 @@ static void program_hpp_type2(struct pci_dev *dev, struct hpp_type2 *hpp)
 	 */
 }
 
+static void pci_configure_extended_tags(struct pci_dev *pdev)
+{
+	u32 dev_cap;
+	int ret;
+
+	ret = pcie_capability_read_dword(pdev, PCI_EXP_DEVCAP, &dev_cap);
+
+	if (ret)
+		return;
+
+	if (dev_cap & PCI_EXP_DEVCAP_EXT_TAG)
+		pcie_capability_set_word(pdev, PCI_EXP_DEVCTL,
+					 PCI_EXP_DEVCTL_EXT_TAG);
+}
+
 static void pci_configure_device(struct pci_dev *dev)
 {
 	struct hotplug_params hpp;
 	int ret;
 
 	pci_configure_mps(dev);
+	pci_configure_extended_tags(dev);
 
 	memset(&hpp, 0, sizeof(hpp));
 	ret = pci_get_hp_params(dev, &hpp);
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 7+ messages in thread
* [PATCH V2] PCI: enable extended tags support for PCIe devices
@ 2017-01-20 14:16 Sinan Kaya
  2017-01-20 14:36 ` Sinan Kaya
  2017-02-09 23:33 ` Bjorn Helgaas
  0 siblings, 2 replies; 7+ messages in thread
From: Sinan Kaya @ 2017-01-20 14:16 UTC (permalink / raw)
  To: okaya; +Cc: Bjorn Helgaas, linux-pci, linux-kernel

Each PCIe device can issue up to 32 transactions at a time by default.
This limitation is historically coming from PCI. Each transaction is
tracked by a tag number on the bus. 2.2.6.2. Transaction Descriptor
– Transaction ID Field section of the PCIe 3.1 specification describes
extended tags.

PCI supports 32 outstanding non-posted requests at a given time. This
number has been extended to 256 on PCI Express. According to the
specification, all PCIe devices are required to support receiving
8-bit Tags (Tag completer). The PCIe-PCI bridges handle the translation
of 8-bit tags to 5-bit tags.

However, the generation of 8-bit tags is left optional to a particular HW
implementation. The code needs to check HW support before attempting
to enable extended tags producer capability.

32 outstanding transactions is not enough for some performance critical
applications especially when a lot of small sized frames are transmitted.

Extended tags support increases this number to 256. Devices not
supporting extended tags tie-off this field to 0. According to ECN, it
is safe to enable this feature for all PCIe devices.

Signed-off-by: Sinan Kaya <okaya@codeaurora.org>
---
 drivers/pci/probe.c | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)

diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
index e164b5c..1192475 100644
--- a/drivers/pci/probe.c
+++ b/drivers/pci/probe.c
@@ -1650,12 +1650,28 @@ static void program_hpp_type2(struct pci_dev *dev, struct hpp_type2 *hpp)
 	 */
 }
 
+static void pci_configure_extended_tags(struct pci_dev *pdev)
+{
+	u32 dev_cap;
+	int ret;
+
+	ret = pcie_capability_read_dword(pdev, PCI_EXP_DEVCAP, &dev_cap);
+
+	if (ret)
+		return;
+
+	if (dev_cap & PCI_EXP_DEVCAP_EXT_TAG)
+		pcie_capability_set_word(pdev, PCI_EXP_DEVCTL,
+					 PCI_EXP_DEVCTL_EXT_TAG);
+}
+
 static void pci_configure_device(struct pci_dev *dev)
 {
 	struct hotplug_params hpp;
 	int ret;
 
 	pci_configure_mps(dev);
+	pci_configure_extended_tags(dev);
 
 	memset(&hpp, 0, sizeof(hpp));
 	ret = pci_get_hp_params(dev, &hpp);
-- 
1.9.1

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

end of thread, other threads:[~2017-02-09 23:40 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-01-20 14:20 [PATCH V2] PCI: enable extended tags support for PCIe devices Sinan Kaya
2017-02-08 18:25 ` [V2] " Sinan Kaya
  -- strict thread matches above, loose matches on Subject: below --
2017-01-20 14:19 [PATCH V2] " Sinan Kaya
2017-01-20 14:16 Sinan Kaya
2017-01-20 14:36 ` Sinan Kaya
2017-02-09 23:33 ` Bjorn Helgaas
2017-02-09 23:40   ` Sinan Kaya

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).