Commit bda3b8a1 authored by Clemens Ladisch's avatar Clemens Ladisch

firewire: core: retry on local errors in bus manager election

When the candidate bus manager fails to do the lock request with which
it tries to become bus manager, it assumes that the current IRM is not
actually IRM capable and forces itself to become root.  However, if that
lock request failed because the local node itself was not able to send
it, then we cannot blame the current IRM and should not steal its
rootness.

In this case, RCODE_SEND_ERROR is likely to indicate a temporary error
condition such as exhausted tlabels or low memory, so we better try
again later.
Signed-off-by: default avatarClemens Ladisch <clemens@ladisch.de>
parent 153e3979
...@@ -306,6 +306,16 @@ static void fw_card_bm_work(struct work_struct *work) ...@@ -306,6 +306,16 @@ static void fw_card_bm_work(struct work_struct *work)
goto out; goto out;
} }
if (rcode == RCODE_SEND_ERROR) {
/*
* We have been unable to send the lock request due to
* some local problem. Let's try again later and hope
* that the problem has gone away by then.
*/
fw_schedule_bm_work(card, DIV_ROUND_UP(HZ, 8));
goto out;
}
spin_lock_irqsave(&card->lock, flags); spin_lock_irqsave(&card->lock, flags);
if (rcode != RCODE_COMPLETE) { if (rcode != RCODE_COMPLETE) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment