mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
scsi: Revert "scsi: fcoe: Fix potential deadlock on &fip->ctlr_lock"
This reverts commit1a19755519
. This commit causes interrupts to be lost for FCoE devices, since it changed sping locks from "bh" to "irqsave". Instead, a work queue should be used, and will be addressed in a separate commit. Fixes:1a19755519
("scsi: fcoe: Fix potential deadlock on &fip->ctlr_lock") Signed-off-by: Lee Duncan <lduncan@suse.com> Link: https://lore.kernel.org/r/c578cdcd46b60470535c4c4a953e6a1feca0dffd.1707500786.git.lduncan@suse.com Reviewed-by: Hannes Reinecke <hare@suse.de> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
4cbec7e89a
commit
977fe773dc
@ -319,17 +319,16 @@ static void fcoe_ctlr_announce(struct fcoe_ctlr *fip)
|
||||
{
|
||||
struct fcoe_fcf *sel;
|
||||
struct fcoe_fcf *fcf;
|
||||
unsigned long flags;
|
||||
|
||||
mutex_lock(&fip->ctlr_mutex);
|
||||
spin_lock_irqsave(&fip->ctlr_lock, flags);
|
||||
spin_lock_bh(&fip->ctlr_lock);
|
||||
|
||||
kfree_skb(fip->flogi_req);
|
||||
fip->flogi_req = NULL;
|
||||
list_for_each_entry(fcf, &fip->fcfs, list)
|
||||
fcf->flogi_sent = 0;
|
||||
|
||||
spin_unlock_irqrestore(&fip->ctlr_lock, flags);
|
||||
spin_unlock_bh(&fip->ctlr_lock);
|
||||
sel = fip->sel_fcf;
|
||||
|
||||
if (sel && ether_addr_equal(sel->fcf_mac, fip->dest_addr))
|
||||
@ -700,7 +699,6 @@ int fcoe_ctlr_els_send(struct fcoe_ctlr *fip, struct fc_lport *lport,
|
||||
{
|
||||
struct fc_frame *fp;
|
||||
struct fc_frame_header *fh;
|
||||
unsigned long flags;
|
||||
u16 old_xid;
|
||||
u8 op;
|
||||
u8 mac[ETH_ALEN];
|
||||
@ -734,11 +732,11 @@ int fcoe_ctlr_els_send(struct fcoe_ctlr *fip, struct fc_lport *lport,
|
||||
op = FIP_DT_FLOGI;
|
||||
if (fip->mode == FIP_MODE_VN2VN)
|
||||
break;
|
||||
spin_lock_irqsave(&fip->ctlr_lock, flags);
|
||||
spin_lock_bh(&fip->ctlr_lock);
|
||||
kfree_skb(fip->flogi_req);
|
||||
fip->flogi_req = skb;
|
||||
fip->flogi_req_send = 1;
|
||||
spin_unlock_irqrestore(&fip->ctlr_lock, flags);
|
||||
spin_unlock_bh(&fip->ctlr_lock);
|
||||
schedule_work(&fip->timer_work);
|
||||
return -EINPROGRESS;
|
||||
case ELS_FDISC:
|
||||
@ -1707,11 +1705,10 @@ static int fcoe_ctlr_flogi_send_locked(struct fcoe_ctlr *fip)
|
||||
static int fcoe_ctlr_flogi_retry(struct fcoe_ctlr *fip)
|
||||
{
|
||||
struct fcoe_fcf *fcf;
|
||||
unsigned long flags;
|
||||
int error;
|
||||
|
||||
mutex_lock(&fip->ctlr_mutex);
|
||||
spin_lock_irqsave(&fip->ctlr_lock, flags);
|
||||
spin_lock_bh(&fip->ctlr_lock);
|
||||
LIBFCOE_FIP_DBG(fip, "re-sending FLOGI - reselect\n");
|
||||
fcf = fcoe_ctlr_select(fip);
|
||||
if (!fcf || fcf->flogi_sent) {
|
||||
@ -1722,7 +1719,7 @@ static int fcoe_ctlr_flogi_retry(struct fcoe_ctlr *fip)
|
||||
fcoe_ctlr_solicit(fip, NULL);
|
||||
error = fcoe_ctlr_flogi_send_locked(fip);
|
||||
}
|
||||
spin_unlock_irqrestore(&fip->ctlr_lock, flags);
|
||||
spin_unlock_bh(&fip->ctlr_lock);
|
||||
mutex_unlock(&fip->ctlr_mutex);
|
||||
return error;
|
||||
}
|
||||
@ -1739,9 +1736,8 @@ static int fcoe_ctlr_flogi_retry(struct fcoe_ctlr *fip)
|
||||
static void fcoe_ctlr_flogi_send(struct fcoe_ctlr *fip)
|
||||
{
|
||||
struct fcoe_fcf *fcf;
|
||||
unsigned long flags;
|
||||
|
||||
spin_lock_irqsave(&fip->ctlr_lock, flags);
|
||||
spin_lock_bh(&fip->ctlr_lock);
|
||||
fcf = fip->sel_fcf;
|
||||
if (!fcf || !fip->flogi_req_send)
|
||||
goto unlock;
|
||||
@ -1768,7 +1764,7 @@ static void fcoe_ctlr_flogi_send(struct fcoe_ctlr *fip)
|
||||
} else /* XXX */
|
||||
LIBFCOE_FIP_DBG(fip, "No FCF selected - defer send\n");
|
||||
unlock:
|
||||
spin_unlock_irqrestore(&fip->ctlr_lock, flags);
|
||||
spin_unlock_bh(&fip->ctlr_lock);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user