|
@@ -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;
|
|
|
}
|
|
|
|
|
|
/**
|