diff options
Diffstat (limited to 'drivers/net/e1000e/netdev.c')
-rw-r--r-- | drivers/net/e1000e/netdev.c | 48 |
1 files changed, 10 insertions, 38 deletions
diff --git a/drivers/net/e1000e/netdev.c b/drivers/net/e1000e/netdev.c index 18f076c01eea..05b0b2f9c54b 100644 --- a/drivers/net/e1000e/netdev.c +++ b/drivers/net/e1000e/netdev.c | |||
@@ -3991,10 +3991,7 @@ static int e1000_resume(struct pci_dev *pdev) | |||
3991 | pci_restore_state(pdev); | 3991 | pci_restore_state(pdev); |
3992 | e1000e_disable_l1aspm(pdev); | 3992 | e1000e_disable_l1aspm(pdev); |
3993 | 3993 | ||
3994 | if (adapter->need_ioport) | 3994 | err = pci_enable_device_mem(pdev); |
3995 | err = pci_enable_device(pdev); | ||
3996 | else | ||
3997 | err = pci_enable_device_mem(pdev); | ||
3998 | if (err) { | 3995 | if (err) { |
3999 | dev_err(&pdev->dev, | 3996 | dev_err(&pdev->dev, |
4000 | "Cannot enable PCI device from suspend\n"); | 3997 | "Cannot enable PCI device from suspend\n"); |
@@ -4096,10 +4093,7 @@ static pci_ers_result_t e1000_io_slot_reset(struct pci_dev *pdev) | |||
4096 | int err; | 4093 | int err; |
4097 | 4094 | ||
4098 | e1000e_disable_l1aspm(pdev); | 4095 | e1000e_disable_l1aspm(pdev); |
4099 | if (adapter->need_ioport) | 4096 | err = pci_enable_device_mem(pdev); |
4100 | err = pci_enable_device(pdev); | ||
4101 | else | ||
4102 | err = pci_enable_device_mem(pdev); | ||
4103 | if (err) { | 4097 | if (err) { |
4104 | dev_err(&pdev->dev, | 4098 | dev_err(&pdev->dev, |
4105 | "Cannot re-enable PCI device after reset.\n"); | 4099 | "Cannot re-enable PCI device after reset.\n"); |
@@ -4197,21 +4191,6 @@ static void e1000_eeprom_checks(struct e1000_adapter *adapter) | |||
4197 | } | 4191 | } |
4198 | 4192 | ||
4199 | /** | 4193 | /** |
4200 | * e1000e_is_need_ioport - determine if an adapter needs ioport resources or not | ||
4201 | * @pdev: PCI device information struct | ||
4202 | * | ||
4203 | * Returns true if an adapters needs ioport resources | ||
4204 | **/ | ||
4205 | static int e1000e_is_need_ioport(struct pci_dev *pdev) | ||
4206 | { | ||
4207 | switch (pdev->device) { | ||
4208 | /* Currently there are no adapters that need ioport resources */ | ||
4209 | default: | ||
4210 | return false; | ||
4211 | } | ||
4212 | } | ||
4213 | |||
4214 | /** | ||
4215 | * e1000_probe - Device Initialization Routine | 4194 | * e1000_probe - Device Initialization Routine |
4216 | * @pdev: PCI device information struct | 4195 | * @pdev: PCI device information struct |
4217 | * @ent: entry in e1000_pci_tbl | 4196 | * @ent: entry in e1000_pci_tbl |
@@ -4236,19 +4215,10 @@ static int __devinit e1000_probe(struct pci_dev *pdev, | |||
4236 | int i, err, pci_using_dac; | 4215 | int i, err, pci_using_dac; |
4237 | u16 eeprom_data = 0; | 4216 | u16 eeprom_data = 0; |
4238 | u16 eeprom_apme_mask = E1000_EEPROM_APME; | 4217 | u16 eeprom_apme_mask = E1000_EEPROM_APME; |
4239 | int bars, need_ioport; | ||
4240 | 4218 | ||
4241 | e1000e_disable_l1aspm(pdev); | 4219 | e1000e_disable_l1aspm(pdev); |
4242 | 4220 | ||
4243 | /* do not allocate ioport bars when not needed */ | 4221 | err = pci_enable_device_mem(pdev); |
4244 | need_ioport = e1000e_is_need_ioport(pdev); | ||
4245 | if (need_ioport) { | ||
4246 | bars = pci_select_bars(pdev, IORESOURCE_MEM | IORESOURCE_IO); | ||
4247 | err = pci_enable_device(pdev); | ||
4248 | } else { | ||
4249 | bars = pci_select_bars(pdev, IORESOURCE_MEM); | ||
4250 | err = pci_enable_device_mem(pdev); | ||
4251 | } | ||
4252 | if (err) | 4222 | if (err) |
4253 | return err; | 4223 | return err; |
4254 | 4224 | ||
@@ -4271,7 +4241,9 @@ static int __devinit e1000_probe(struct pci_dev *pdev, | |||
4271 | } | 4241 | } |
4272 | } | 4242 | } |
4273 | 4243 | ||
4274 | err = pci_request_selected_regions(pdev, bars, e1000e_driver_name); | 4244 | err = pci_request_selected_regions(pdev, |
4245 | pci_select_bars(pdev, IORESOURCE_MEM), | ||
4246 | e1000e_driver_name); | ||
4275 | if (err) | 4247 | if (err) |
4276 | goto err_pci_reg; | 4248 | goto err_pci_reg; |
4277 | 4249 | ||
@@ -4296,8 +4268,6 @@ static int __devinit e1000_probe(struct pci_dev *pdev, | |||
4296 | adapter->hw.adapter = adapter; | 4268 | adapter->hw.adapter = adapter; |
4297 | adapter->hw.mac.type = ei->mac; | 4269 | adapter->hw.mac.type = ei->mac; |
4298 | adapter->msg_enable = (1 << NETIF_MSG_DRV | NETIF_MSG_PROBE) - 1; | 4270 | adapter->msg_enable = (1 << NETIF_MSG_DRV | NETIF_MSG_PROBE) - 1; |
4299 | adapter->bars = bars; | ||
4300 | adapter->need_ioport = need_ioport; | ||
4301 | 4271 | ||
4302 | mmio_start = pci_resource_start(pdev, 0); | 4272 | mmio_start = pci_resource_start(pdev, 0); |
4303 | mmio_len = pci_resource_len(pdev, 0); | 4273 | mmio_len = pci_resource_len(pdev, 0); |
@@ -4536,7 +4506,8 @@ err_flashmap: | |||
4536 | err_ioremap: | 4506 | err_ioremap: |
4537 | free_netdev(netdev); | 4507 | free_netdev(netdev); |
4538 | err_alloc_etherdev: | 4508 | err_alloc_etherdev: |
4539 | pci_release_selected_regions(pdev, bars); | 4509 | pci_release_selected_regions(pdev, |
4510 | pci_select_bars(pdev, IORESOURCE_MEM)); | ||
4540 | err_pci_reg: | 4511 | err_pci_reg: |
4541 | err_dma: | 4512 | err_dma: |
4542 | pci_disable_device(pdev); | 4513 | pci_disable_device(pdev); |
@@ -4584,7 +4555,8 @@ static void __devexit e1000_remove(struct pci_dev *pdev) | |||
4584 | iounmap(adapter->hw.hw_addr); | 4555 | iounmap(adapter->hw.hw_addr); |
4585 | if (adapter->hw.flash_address) | 4556 | if (adapter->hw.flash_address) |
4586 | iounmap(adapter->hw.flash_address); | 4557 | iounmap(adapter->hw.flash_address); |
4587 | pci_release_selected_regions(pdev, adapter->bars); | 4558 | pci_release_selected_regions(pdev, |
4559 | pci_select_bars(pdev, IORESOURCE_MEM)); | ||
4588 | 4560 | ||
4589 | free_netdev(netdev); | 4561 | free_netdev(netdev); |
4590 | 4562 | ||