sky2: set VPD size
Read configuration register during probe and use it to size the available VPD. Move existing code using same register slightly earlier in probe handling. Signed-off-by: Stephen Hemminger <shemminger@vyatta.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e4c2abe29e
commit
3834507d0c
1 changed files with 29 additions and 12 deletions
|
@ -4356,6 +4356,7 @@ static int __devinit sky2_probe(struct pci_dev *pdev,
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
struct sky2_hw *hw;
|
struct sky2_hw *hw;
|
||||||
int err, using_dac = 0, wol_default;
|
int err, using_dac = 0, wol_default;
|
||||||
|
u32 reg;
|
||||||
char buf1[16];
|
char buf1[16];
|
||||||
|
|
||||||
err = pci_enable_device(pdev);
|
err = pci_enable_device(pdev);
|
||||||
|
@ -4389,6 +4390,34 @@ static int __devinit sky2_probe(struct pci_dev *pdev,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Get configuration information
|
||||||
|
* Note: only regular PCI config access once to test for HW issues
|
||||||
|
* other PCI access through shared memory for speed and to
|
||||||
|
* avoid MMCONFIG problems.
|
||||||
|
*/
|
||||||
|
err = pci_read_config_dword(pdev, PCI_DEV_REG2, ®);
|
||||||
|
if (err) {
|
||||||
|
dev_err(&pdev->dev, "PCI read config failed\n");
|
||||||
|
goto err_out_free_regions;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* size of available VPD, only impact sysfs */
|
||||||
|
err = pci_vpd_truncate(pdev, 1ul << (((reg & PCI_VPD_ROM_SZ) >> 14) + 8));
|
||||||
|
if (err)
|
||||||
|
dev_warn(&pdev->dev, "Can't set VPD size\n");
|
||||||
|
|
||||||
|
#ifdef __BIG_ENDIAN
|
||||||
|
/* The sk98lin vendor driver uses hardware byte swapping but
|
||||||
|
* this driver uses software swapping.
|
||||||
|
*/
|
||||||
|
reg &= ~PCI_REV_DESC;
|
||||||
|
err = pci_write_config_dword(pdev,PCI_DEV_REG2, reg);
|
||||||
|
if (err) {
|
||||||
|
dev_err(&pdev->dev, "PCI write config failed\n");
|
||||||
|
goto err_out_free_regions;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
wol_default = device_may_wakeup(&pdev->dev) ? WAKE_MAGIC : 0;
|
wol_default = device_may_wakeup(&pdev->dev) ? WAKE_MAGIC : 0;
|
||||||
|
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
|
@ -4406,18 +4435,6 @@ static int __devinit sky2_probe(struct pci_dev *pdev,
|
||||||
goto err_out_free_hw;
|
goto err_out_free_hw;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __BIG_ENDIAN
|
|
||||||
/* The sk98lin vendor driver uses hardware byte swapping but
|
|
||||||
* this driver uses software swapping.
|
|
||||||
*/
|
|
||||||
{
|
|
||||||
u32 reg;
|
|
||||||
reg = sky2_pci_read32(hw, PCI_DEV_REG2);
|
|
||||||
reg &= ~PCI_REV_DESC;
|
|
||||||
sky2_pci_write32(hw, PCI_DEV_REG2, reg);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ring for status responses */
|
/* ring for status responses */
|
||||||
hw->st_le = pci_alloc_consistent(pdev, STATUS_LE_BYTES, &hw->st_dma);
|
hw->st_le = pci_alloc_consistent(pdev, STATUS_LE_BYTES, &hw->st_dma);
|
||||||
if (!hw->st_le)
|
if (!hw->st_le)
|
||||||
|
|
Loading…
Reference in a new issue