提交 d14e3d05 编写于 作者: F Francois Romieu 提交者: Greg Kroah-Hartman

et131x: uncloak PCIe capabilities.

FIXME: it should be possible to get rid of ET1310_PCI_L0L1LATENCY as well.
Signed-off-by: NFrancois Romieu <romieu@fr.zoreil.com>
Acked-by: NMark Einon <mark.einon@gmail.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 5f3eb881
...@@ -155,7 +155,6 @@ MODULE_DESCRIPTION("10/100/1000 Base-T Ethernet Driver " ...@@ -155,7 +155,6 @@ MODULE_DESCRIPTION("10/100/1000 Base-T Ethernet Driver "
#define fMP_ADAPTER_FAIL_SEND_MASK 0x3ff00000 #define fMP_ADAPTER_FAIL_SEND_MASK 0x3ff00000
/* Some offsets in PCI config space that are actually used. */ /* 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_MAC_ADDRESS 0xA4
#define ET1310_PCI_EEPROM_STATUS 0xB2 #define ET1310_PCI_EEPROM_STATUS 0xB2
#define ET1310_PCI_ACK_NACK 0xC0 #define ET1310_PCI_ACK_NACK 0xC0
...@@ -4024,24 +4023,31 @@ static void et131x_hwaddr_init(struct et131x_adapter *adapter) ...@@ -4024,24 +4023,31 @@ static void et131x_hwaddr_init(struct et131x_adapter *adapter)
static int et131x_pci_init(struct et131x_adapter *adapter, static int et131x_pci_init(struct et131x_adapter *adapter,
struct pci_dev *pdev) struct pci_dev *pdev)
{ {
int i; int cap = pci_pcie_cap(pdev);
u8 max_payload; u16 max_payload;
u8 read_size_reg; u16 ctl;
int i, rc;
if (et131x_init_eeprom(adapter) < 0) rc = et131x_init_eeprom(adapter);
return -EIO; 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 /* Let's set up the PORT LOGIC Register. First we need to know what
* the max_payload_size is * 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, dev_err(&pdev->dev,
"Could not read PCI config space for Max Payload Size\n"); "Could not read PCI config space for Max Payload Size\n");
return -EIO; goto err_out;
} }
/* Program the Ack/Nak latency and replay timers */ /* 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) { if (max_payload < 2) {
static const u16 acknak[2] = { 0x76, 0xD0 }; static const u16 acknak[2] = { 0x76, 0xD0 };
...@@ -4051,13 +4057,13 @@ static int et131x_pci_init(struct et131x_adapter *adapter, ...@@ -4051,13 +4057,13 @@ static int et131x_pci_init(struct et131x_adapter *adapter,
acknak[max_payload])) { acknak[max_payload])) {
dev_err(&pdev->dev, dev_err(&pdev->dev,
"Could not write PCI config space for ACK/NAK\n"); "Could not write PCI config space for ACK/NAK\n");
return -EIO; goto err_out;
} }
if (pci_write_config_word(pdev, ET1310_PCI_REPLAY, if (pci_write_config_word(pdev, ET1310_PCI_REPLAY,
replay[max_payload])) { replay[max_payload])) {
dev_err(&pdev->dev, dev_err(&pdev->dev,
"Could not write PCI config space for Replay Timer\n"); "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, ...@@ -4067,23 +4073,22 @@ static int et131x_pci_init(struct et131x_adapter *adapter,
if (pci_write_config_byte(pdev, ET1310_PCI_L0L1LATENCY, 0x11)) { if (pci_write_config_byte(pdev, ET1310_PCI_L0L1LATENCY, 0x11)) {
dev_err(&pdev->dev, dev_err(&pdev->dev,
"Could not write PCI config space for Latency Timers\n"); "Could not write PCI config space for Latency Timers\n");
return -EIO; goto err_out;
} }
/* Change the max read size to 2k */ /* 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, dev_err(&pdev->dev,
"Could not read PCI config space for Max read size\n"); "Could not read PCI config space for Max read size\n");
return -EIO; goto err_out;
} }
read_size_reg &= 0x8f; ctl = (ctl & ~PCI_EXP_DEVCTL_READRQ) | ( 0x04 << 12);
read_size_reg |= 0x40;
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, dev_err(&pdev->dev,
"Could not write PCI config space for Max read size\n"); "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 /* Get MAC address from config space if an eeprom exists, otherwise
...@@ -4098,11 +4103,15 @@ static int et131x_pci_init(struct et131x_adapter *adapter, ...@@ -4098,11 +4103,15 @@ static int et131x_pci_init(struct et131x_adapter *adapter,
if (pci_read_config_byte(pdev, ET1310_PCI_MAC_ADDRESS + i, if (pci_read_config_byte(pdev, ET1310_PCI_MAC_ADDRESS + i,
adapter->rom_addr + i)) { adapter->rom_addr + i)) {
dev_err(&pdev->dev, "Could not read PCI config space for MAC address\n"); 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); memcpy(adapter->addr, adapter->rom_addr, ETH_ALEN);
return 0; out:
return rc;
err_out:
rc = -EIO;
goto out;
} }
/** /**
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册