提交 b83082e9 编写于 作者: Y Yijing Wang 提交者: David S. Miller

netxen: clean up unnecessary MSI/MSI-X capability find

PCI core will initialize device MSI/MSI-X capability in
pci_msi_init_pci_dev(). So device driver should use
pci_dev->msi_cap/msix_cap to determine whether the device
support MSI/MSI-X instead of using
pci_find_capability(pci_dev, PCI_CAP_ID_MSI/MSIX).
Access to PCIe device config space again will consume more time.
Signed-off-by: NYijing Wang <wangyijing@huawei.com>
Cc: Manish Chopra <manish.chopra@qlogic.com>
Cc: Sony Chacko <sony.chacko@qlogic.com>
Cc: Rajesh Borundia <rajesh.borundia@qlogic.com>
Cc: netdev@vger.kernel.org
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 40b29562
...@@ -459,16 +459,14 @@ static void netxen_pcie_strap_init(struct netxen_adapter *adapter) ...@@ -459,16 +459,14 @@ static void netxen_pcie_strap_init(struct netxen_adapter *adapter)
static void netxen_set_msix_bit(struct pci_dev *pdev, int enable) static void netxen_set_msix_bit(struct pci_dev *pdev, int enable)
{ {
u32 control; u32 control;
int pos;
pos = pci_find_capability(pdev, PCI_CAP_ID_MSIX); if (pdev->msix_cap) {
if (pos) { pci_read_config_dword(pdev, pdev->msix_cap, &control);
pci_read_config_dword(pdev, pos, &control);
if (enable) if (enable)
control |= PCI_MSIX_FLAGS_ENABLE; control |= PCI_MSIX_FLAGS_ENABLE;
else else
control = 0; control = 0;
pci_write_config_dword(pdev, pos, control); pci_write_config_dword(pdev, pdev->msix_cap, control);
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册