Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 135042
b: refs/heads/master
c: eae6b58
h: refs/heads/master
v: v3
  • Loading branch information
Ron Mercer authored and David S. Miller committed Mar 4, 2009
1 parent 9014f4a commit 94fb069
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 1 deletion.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 38d408152a86598a50680a82fe3353b506630409
refs/heads/master: eae6b58fb229bd17fea38d596020b80547e51381
38 changes: 38 additions & 0 deletions trunk/drivers/net/qlge/qlge_mpi.c
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,36 @@ static void ql_link_down(struct ql_adapter *qdev, struct mbox_params *mbcp)
ql_write32(qdev, CSR, CSR_CMD_CLR_R2PCI_INT);
}

static int ql_sfp_in(struct ql_adapter *qdev, struct mbox_params *mbcp)
{
int status;

mbcp->out_count = 5;

status = ql_get_mb_sts(qdev, mbcp);
if (status)
QPRINTK(qdev, DRV, ERR, "SFP in AEN broken!\n");
else
QPRINTK(qdev, DRV, ERR, "SFP insertion detected.\n");

return status;
}

static int ql_sfp_out(struct ql_adapter *qdev, struct mbox_params *mbcp)
{
int status;

mbcp->out_count = 1;

status = ql_get_mb_sts(qdev, mbcp);
if (status)
QPRINTK(qdev, DRV, ERR, "SFP out AEN broken!\n");
else
QPRINTK(qdev, DRV, ERR, "SFP removal detected.\n");

return status;
}

static void ql_init_fw_done(struct ql_adapter *qdev, struct mbox_params *mbcp)
{
mbcp->out_count = 2;
Expand Down Expand Up @@ -284,6 +314,14 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp)
ql_init_fw_done(qdev, mbcp);
break;

case AEN_AEN_SFP_IN:
ql_sfp_in(qdev, mbcp);
break;

case AEN_AEN_SFP_OUT:
ql_sfp_out(qdev, mbcp);
break;

case AEN_FW_INIT_FAIL:
case AEN_SYS_ERR:
ql_queue_fw_error(qdev);
Expand Down

0 comments on commit 94fb069

Please sign in to comment.