et131x: uncloak PCIe capabilities.
authorFrancois Romieu <romieu@fr.zoreil.com>
Sun, 23 Oct 2011 17:12:14 +0000 (19:12 +0200)
committerGreg Kroah-Hartman <gregkh@suse.de>
Sun, 27 Nov 2011 00:21:24 +0000 (16:21 -0800)
FIXME: it should be possible to get rid of ET1310_PCI_L0L1LATENCY as well.

Signed-off-by: Francois Romieu <romieu@fr.zoreil.com>
Acked-by: Mark Einon <mark.einon@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/staging/et131x/et131x.c

index 6bcdd77..819ef10 100644 (file)
@@ -155,7 +155,6 @@ MODULE_DESCRIPTION("10/100/1000 Base-T Ethernet Driver "
 #define fMP_ADAPTER_FAIL_SEND_MASK     0x3ff00000
 
 /* Some offsets in PCI config space that are actually used. */
-#define ET1310_PCI_MAX_PYLD            0x4C
 #define ET1310_PCI_MAC_ADDRESS         0xA4
 #define ET1310_PCI_EEPROM_STATUS       0xB2
 #define ET1310_PCI_ACK_NACK            0xC0
@@ -4024,24 +4023,31 @@ static void et131x_hwaddr_init(struct et131x_adapter *adapter)
 static int et131x_pci_init(struct et131x_adapter *adapter,
                                                struct pci_dev *pdev)
 {
-       int i;
-       u8 max_payload;
-       u8 read_size_reg;
+       int cap = pci_pcie_cap(pdev);
+       u16 max_payload;
+       u16 ctl;
+       int i, rc;
 
-       if (et131x_init_eeprom(adapter) < 0)
-               return -EIO;
+       rc = et131x_init_eeprom(adapter);
+       if (rc < 0)
+               goto out;
 
+       if (!cap) {
+               dev_err(&pdev->dev, "Missing PCIe capabilities\n");
+               goto err_out;
+       }
+               
        /* Let's set up the PORT LOGIC Register.  First we need to know what
         * the max_payload_size is
         */
-       if (pci_read_config_byte(pdev, ET1310_PCI_MAX_PYLD, &max_payload)) {
+       if (pci_read_config_word(pdev, cap + PCI_EXP_DEVCAP, &max_payload)) {
                dev_err(&pdev->dev,
                    "Could not read PCI config space for Max Payload Size\n");
-               return -EIO;
+               goto err_out;
        }
 
        /* Program the Ack/Nak latency and replay timers */
-       max_payload &= 0x07;    /* Only the lower 3 bits are valid */
+       max_payload &= 0x07;
 
        if (max_payload < 2) {
                static const u16 acknak[2] = { 0x76, 0xD0 };
@@ -4051,13 +4057,13 @@ static int et131x_pci_init(struct et131x_adapter *adapter,
                                               acknak[max_payload])) {
                        dev_err(&pdev->dev,
                          "Could not write PCI config space for ACK/NAK\n");
-                       return -EIO;
+                       goto err_out;
                }
                if (pci_write_config_word(pdev, ET1310_PCI_REPLAY,
                                               replay[max_payload])) {
                        dev_err(&pdev->dev,
                          "Could not write PCI config space for Replay Timer\n");
-                       return -EIO;
+                       goto err_out;
                }
        }
 
@@ -4067,23 +4073,22 @@ static int et131x_pci_init(struct et131x_adapter *adapter,
        if (pci_write_config_byte(pdev, ET1310_PCI_L0L1LATENCY, 0x11)) {
                dev_err(&pdev->dev,
                  "Could not write PCI config space for Latency Timers\n");
-               return -EIO;
+               goto err_out;
        }
 
        /* Change the max read size to 2k */
-       if (pci_read_config_byte(pdev, 0x51, &read_size_reg)) {
+       if (pci_read_config_word(pdev, cap + PCI_EXP_DEVCTL, &ctl)) {
                dev_err(&pdev->dev,
                        "Could not read PCI config space for Max read size\n");
-               return -EIO;
+               goto err_out;
        }
 
-       read_size_reg &= 0x8f;
-       read_size_reg |= 0x40;
+       ctl = (ctl & ~PCI_EXP_DEVCTL_READRQ) | ( 0x04 << 12);
 
-       if (pci_write_config_byte(pdev, 0x51, read_size_reg)) {
+       if (pci_write_config_word(pdev, cap + PCI_EXP_DEVCTL, ctl)) {
                dev_err(&pdev->dev,
                      "Could not write PCI config space for Max read size\n");
-               return -EIO;
+               goto err_out;
        }
 
        /* Get MAC address from config space if an eeprom exists, otherwise
@@ -4098,11 +4103,15 @@ static int et131x_pci_init(struct et131x_adapter *adapter,
                if (pci_read_config_byte(pdev, ET1310_PCI_MAC_ADDRESS + i,
                                        adapter->rom_addr + i)) {
                        dev_err(&pdev->dev, "Could not read PCI config space for MAC address\n");
-                       return -EIO;
+                       goto err_out;
                }
        }
        memcpy(adapter->addr, adapter->rom_addr, ETH_ALEN);
-       return 0;
+out:
+       return rc;
+err_out:
+       rc = -EIO;
+       goto out;
 }
 
 /**