From: Jay Vosburgh <fubar@us.ibm.com>
To: Maxim Uvarov <maxim.uvarov@oracle.com>
Cc: David Miller <davem@davemloft.net>,
netdev@vger.kernel.org, andy@greyhouse.net, amwang@redhat.com
Subject: Re: [PATCH] bond_alb: don't disable softirq under bond_alb_xmit
Date: Mon, 09 Jan 2012 11:36:29 -0800 [thread overview]
Message-ID: <15858.1326137789@death> (raw)
In-Reply-To: <4F0B3923.4020707@oracle.com>
Maxim Uvarov <maxim.uvarov@oracle.com> wrote:
>On 01/07/2012 10:14 AM, David Miller wrote:
>> From: Jay Vosburgh<fubar@us.ibm.com>
>> Date: Fri, 06 Jan 2012 13:33:25 -0800
>>
>>> Maxim Uvarov<maxim.uvarov@oracle.com> wrote:
>>>
>>>> No need to lock soft irqs under bond_alb_xmit()
>>>> which already has softirq disabled.
>>>
>>> In commit:
>>>
>>> commit 6603a6f25e4bca922a7dfbf0bf03072d98850176
>>> Author: Jay Vosburgh<fubar@us.ibm.com>
>>> Date: Wed Oct 17 17:37:50 2007 -0700
>>>
>>> bonding: Convert more locks to _bh, acquire rtnl, for new locking
>>>
>>> Convert more lock acquisitions to _bh flavor to avoid deadlock
>>> with workqueue activity and add acquisition of RTNL in appropriate places.
>>> Affects ALB mode, as well as core bonding functions and sysfs.
>>>
>>> Signed-off-by: Andy Gospodarek<andy@greyhouse.net>
>>> Signed-off-by: Jay Vosburgh<fubar@us.ibm.com>
>>> Signed-off-by: Jeff Garzik<jeff@garzik.org>
>>>
>>> the _lock_tx_hashtbl was upgraded from regular to _bh to prevent
>>> deadlocks. I don't recall right offhand what deadlock this prevented,
>>> but are we sure there are no possible issues with converting this lock
>>> back to a non-_bh acquisition?
>>
>> Maxim's patch is not changing the BH'ness of the list.
>>
>>
>> He's just avoiding a BH disable which is unnecessary because BH is
>> already disabled in the effected code path(s).
>>
>
>Yes, I only removed disabling BH for tlb_choose_channel(). In other places
>this lock still disables BH. This makes lock more accurate,
>because there are 2 paths for execution: 1. dev_queue_xmit() and BH
>are already disabled. 2. netpoll and irqs are disabled. So no need to
>enable/disable BH.
The tlb_choose_channel and rlb_choose_channel parts look to be
as you describe, but you also modify tlb_clear_slave:
--- a/drivers/net/bonding/bond_alb.c
+++ b/drivers/net/bonding/bond_alb.c
@@ -135,7 +135,7 @@ static void tlb_clear_slave(struct bonding *bond, struct slave *slave, int save_
struct tlb_client_info *tx_hash_table;
u32 index;
- _lock_tx_hashtbl(bond);
+ spin_lock(&(BOND_ALB_INFO(bond).tx_hashtbl_lock));
This makes tlb_clear_slave acquire the tx_hashtbl_lock without
_bh. The tlb_clear_slave function is called from multiple places
without already holding _bh, in addition to the call paths you list.
The cases I see are:
bond_alb_monitor (which runs from a workqueue)
bond_alb_handle_link_change (called from bond_miimon_commit,
from a workqueue)
bond_alb_deinit_slave (called during slave removal)
All three of these will call into tlb_clear_slave without
already holding something at _bh. These paths do not enter
tlb_clear_slave through tlb_choose_channel or rlb_choose_channel.
Are we sure this does not open a window wherein the non-_bh path
into tlb_clear_slave could deadlock against the with-_bh path?
-J
---
-Jay Vosburgh, IBM Linux Technology Center, fubar@us.ibm.com
next prev parent reply other threads:[~2012-01-09 19:37 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-01-06 20:23 [PATCH] bond_alb: don't disable softirq under bond_alb_xmit Maxim Uvarov
2012-01-06 21:33 ` Jay Vosburgh
2012-01-07 18:14 ` David Miller
2012-01-09 18:59 ` Maxim Uvarov
2012-01-09 19:36 ` Jay Vosburgh [this message]
2012-01-09 19:42 ` Maxim Uvarov
2012-01-09 20:32 ` Andy Gospodarek
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=15858.1326137789@death \
--to=fubar@us.ibm.com \
--cc=amwang@redhat.com \
--cc=andy@greyhouse.net \
--cc=davem@davemloft.net \
--cc=maxim.uvarov@oracle.com \
--cc=netdev@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).