提交 ebe61d80 编写于 作者: Y Yuval Mintz 提交者: David S. Miller

bnx2x: Clean previous IGU status before ack

When enabling interrupts, acknowledge the interrupt only
after configuring the IGU to the correct interrupt mode
(otherwise it would dirty selftests)
Signed-off-by: NYuval Mintz <yuvalmin@broadcom.com>
Signed-off-by: NAriel Elior <ariele@broadcom.com>
Signed-off-by: NEilon Greenstein <eilong@broadcom.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 823e1d90
...@@ -1681,7 +1681,6 @@ static int bnx2x_setup_irqs(struct bnx2x *bp) ...@@ -1681,7 +1681,6 @@ static int bnx2x_setup_irqs(struct bnx2x *bp)
if (rc) if (rc)
return rc; return rc;
} else { } else {
bnx2x_ack_int(bp);
rc = bnx2x_req_irq(bp); rc = bnx2x_req_irq(bp);
if (rc) { if (rc) {
BNX2X_ERR("IRQ request failed rc %d, aborting\n", rc); BNX2X_ERR("IRQ request failed rc %d, aborting\n", rc);
......
...@@ -1539,26 +1539,31 @@ static void bnx2x_igu_int_enable(struct bnx2x *bp) ...@@ -1539,26 +1539,31 @@ static void bnx2x_igu_int_enable(struct bnx2x *bp)
if (msix) { if (msix) {
val &= ~(IGU_PF_CONF_INT_LINE_EN | val &= ~(IGU_PF_CONF_INT_LINE_EN |
IGU_PF_CONF_SINGLE_ISR_EN); IGU_PF_CONF_SINGLE_ISR_EN);
val |= (IGU_PF_CONF_FUNC_EN | val |= (IGU_PF_CONF_MSI_MSIX_EN |
IGU_PF_CONF_MSI_MSIX_EN |
IGU_PF_CONF_ATTN_BIT_EN); IGU_PF_CONF_ATTN_BIT_EN);
if (single_msix) if (single_msix)
val |= IGU_PF_CONF_SINGLE_ISR_EN; val |= IGU_PF_CONF_SINGLE_ISR_EN;
} else if (msi) { } else if (msi) {
val &= ~IGU_PF_CONF_INT_LINE_EN; val &= ~IGU_PF_CONF_INT_LINE_EN;
val |= (IGU_PF_CONF_FUNC_EN | val |= (IGU_PF_CONF_MSI_MSIX_EN |
IGU_PF_CONF_MSI_MSIX_EN |
IGU_PF_CONF_ATTN_BIT_EN | IGU_PF_CONF_ATTN_BIT_EN |
IGU_PF_CONF_SINGLE_ISR_EN); IGU_PF_CONF_SINGLE_ISR_EN);
} else { } else {
val &= ~IGU_PF_CONF_MSI_MSIX_EN; val &= ~IGU_PF_CONF_MSI_MSIX_EN;
val |= (IGU_PF_CONF_FUNC_EN | val |= (IGU_PF_CONF_INT_LINE_EN |
IGU_PF_CONF_INT_LINE_EN |
IGU_PF_CONF_ATTN_BIT_EN | IGU_PF_CONF_ATTN_BIT_EN |
IGU_PF_CONF_SINGLE_ISR_EN); IGU_PF_CONF_SINGLE_ISR_EN);
} }
/* Clean previous status - need to configure igu prior to ack*/
if ((!msix) || single_msix) {
REG_WR(bp, IGU_REG_PF_CONFIGURATION, val);
bnx2x_ack_int(bp);
}
val |= IGU_PF_CONF_FUNC_EN;
DP(NETIF_MSG_IFUP, "write 0x%x to IGU mode %s\n", DP(NETIF_MSG_IFUP, "write 0x%x to IGU mode %s\n",
val, (msix ? "MSI-X" : (msi ? "MSI" : "INTx"))); val, (msix ? "MSI-X" : (msi ? "MSI" : "INTx")));
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册