Commit 302d242c authored by Brice Goglin's avatar Brice Goglin Committed by Jeff Garzik

myri10ge: use pcie_get/set_readrq

Based on a patch from Peter Oruba, convert myri10ge to use pcie_get_readrq()
and pcie_set_readrq() instead of our own PCI calls and arithmetics.

These driver changes incorporate the proposed PCI-X / PCI-Express read byte
count interface.  Reading and setting those values doesn't take place
"manually", instead wrapping functions are called to allow quirks for some
PCI bridges.
Signed-off-by: default avatarBrice Goglin <brice@myri.com>
Signed-off by: Peter Oruba <peter.oruba@amd.com>
Based on work by Stephen Hemminger <shemminger@linux-foundation.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarJeff Garzik <jeff@garzik.org>
parent 28721c89
...@@ -2514,26 +2514,20 @@ static void myri10ge_firmware_probe(struct myri10ge_priv *mgp) ...@@ -2514,26 +2514,20 @@ static void myri10ge_firmware_probe(struct myri10ge_priv *mgp)
{ {
struct pci_dev *pdev = mgp->pdev; struct pci_dev *pdev = mgp->pdev;
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
int cap, status; int status;
u16 val;
mgp->tx.boundary = 4096; mgp->tx.boundary = 4096;
/* /*
* Verify the max read request size was set to 4KB * Verify the max read request size was set to 4KB
* before trying the test with 4KB. * before trying the test with 4KB.
*/ */
cap = pci_find_capability(pdev, PCI_CAP_ID_EXP); status = pcie_get_readrq(pdev);
if (cap < 64) { if (status < 0) {
dev_err(dev, "Bad PCI_CAP_ID_EXP location %d\n", cap);
goto abort;
}
status = pci_read_config_word(pdev, cap + PCI_EXP_DEVCTL, &val);
if (status != 0) {
dev_err(dev, "Couldn't read max read req size: %d\n", status); dev_err(dev, "Couldn't read max read req size: %d\n", status);
goto abort; goto abort;
} }
if ((val & (5 << 12)) != (5 << 12)) { if (status != 4096) {
dev_warn(dev, "Max Read Request size != 4096 (0x%x)\n", val); dev_warn(dev, "Max Read Request size != 4096 (%d)\n", status);
mgp->tx.boundary = 2048; mgp->tx.boundary = 2048;
} }
/* /*
...@@ -2850,9 +2844,7 @@ static int myri10ge_probe(struct pci_dev *pdev, const struct pci_device_id *ent) ...@@ -2850,9 +2844,7 @@ static int myri10ge_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
size_t bytes; size_t bytes;
int i; int i;
int status = -ENXIO; int status = -ENXIO;
int cap;
int dac_enabled; int dac_enabled;
u16 val;
netdev = alloc_etherdev(sizeof(*mgp)); netdev = alloc_etherdev(sizeof(*mgp));
if (netdev == NULL) { if (netdev == NULL) {
...@@ -2884,19 +2876,7 @@ static int myri10ge_probe(struct pci_dev *pdev, const struct pci_device_id *ent) ...@@ -2884,19 +2876,7 @@ static int myri10ge_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
= pci_find_capability(pdev, PCI_CAP_ID_VNDR); = pci_find_capability(pdev, PCI_CAP_ID_VNDR);
/* Set our max read request to 4KB */ /* Set our max read request to 4KB */
cap = pci_find_capability(pdev, PCI_CAP_ID_EXP); status = pcie_set_readrq(pdev, 4096);
if (cap < 64) {
dev_err(&pdev->dev, "Bad PCI_CAP_ID_EXP location %d\n", cap);
goto abort_with_netdev;
}
status = pci_read_config_word(pdev, cap + PCI_EXP_DEVCTL, &val);
if (status != 0) {
dev_err(&pdev->dev, "Error %d reading PCI_EXP_DEVCTL\n",
status);
goto abort_with_netdev;
}
val = (val & ~PCI_EXP_DEVCTL_READRQ) | (5 << 12);
status = pci_write_config_word(pdev, cap + PCI_EXP_DEVCTL, val);
if (status != 0) { if (status != 0) {
dev_err(&pdev->dev, "Error %d writing PCI_EXP_DEVCTL\n", dev_err(&pdev->dev, "Error %d writing PCI_EXP_DEVCTL\n",
status); status);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment