• N
    target: Convert session_lock to irqsave · 140854cb
    Nicholas Bellinger 提交于
    This patch converts the remaining struct se_portal_group->session_lock
    usage to use irqsave+irqrestore to address the following warnings for
    hardware target mode interrupt context usage.  This change generate
    other warnings for current iscsi-target mode still using ->session_lock
    with spin_lock_bh, which will need to be converted in a seperate patch.
    
    [  492.480728] [ INFO: HARDIRQ-safe -> HARDIRQ-unsafe lock order detected ]
    [  492.488194] 3.0.0+ #23
    [  492.490820] ------------------------------------------------------
    [  492.497704] sh/7162 [HC0[0]:SC0[2]:HE0:SE0] is trying to acquire:
    [  492.504493] (&(&se_tpg->session_lock)->rlock){+.....}, at: [<ffffffffa022364d>] transport_deregister_session+0x2d/0x163 [target_core_mod]
      492.518390]
    [  492.518390] and this task is already holding:
    [  492.524897] (&(&ha->hardware_lock)->rlock){-.-...}, at: [<ffffffffa00b9146>] qla_tgt_stop_phase1+0x5e/0x27e [qla2xxx]
    [  492.536856] which would create a new lock dependency:
    [  492.542481] (&(&ha->hardware_lock)->rlock){-.-...} -> (&(&se_tpg->session_lock)->rlock){+.....}
    [  492.552321]
    [  492.552321] but this new dependency connects a HARDIRQ-irq-safe lock:
    [  492.561149] (&(&ha->hardware_lock)->rlock){-.-...}
    [  492.566400] ... which became HARDIRQ-irq-safe at:
    [  492.571841]   [<ffffffff81064720>] __lock_acquire+0x68f/0x921
    [  492.578247]   [<ffffffff81064eff>] lock_acquire+0xe0/0x10d
    [  492.584367]   [<ffffffff813a74c6>] _raw_spin_lock_irqsave+0x44/0x56
    [  492.591358]   [<ffffffffa009b1be>] qla24xx_msix_default+0x5c/0x2aa [qla2xxx]
    [  492.599227]   [<ffffffff81088582>] handle_irq_event_percpu+0x5a/0x197
    [  492.606413]   [<ffffffff810886fb>] handle_irq_event+0x3c/0x5c
    [  492.612822]   [<ffffffff8108a6dc>] handle_edge_irq+0xcc/0xf1
    [  492.619138]   [<ffffffff810039b9>] handle_irq+0x83/0x8e
    [  492.624971]   [<ffffffff8100333e>] do_IRQ+0x48/0xaf
    [  492.630413]   [<ffffffff813a7cd3>] ret_from_intr+0x0/0x1a
    [  492.636437]   [<ffffffff81001dc1>] cpu_idle+0x5b/0x8d
    [  492.642073]   [<ffffffff81392709>] rest_init+0xad/0xb4
    [  492.647809]   [<ffffffff81a1cbbc>] start_kernel+0x366/0x371
    [  492.654030]   [<ffffffff81a1c2b1>] x86_64_start_reservations+0xb8/0xbc
    [  492.661311]   [<ffffffff81a1c3b6>] x86_64_start_kernel+0x101/0x110
    [  492.668204]
    [  492.668205] to a HARDIRQ-irq-unsafe lock:
    [  492.674324] (&(&se_tpg->session_lock)->rlock){+.....}
    [  492.679862] ... which became HARDIRQ-irq-unsafe at:
    [  492.685497] ...  [<ffffffff8106479a>] __lock_acquire+0x709/0x921
    [  492.692209]   [<ffffffff81064eff>] lock_acquire+0xe0/0x10d
    [  492.698330]   [<ffffffff813a75ed>] _raw_spin_lock_bh+0x31/0x40
    [  492.704836]   [<ffffffffa021c208>] core_tpg_del_initiator_node_acl+0x89/0x336 [target_core_mod]
    [  492.714546]   [<ffffffffa02fb075>] tcm_qla2xxx_drop_nodeacl+0x20/0x2d [tcm_qla2xxx]
    [  492.723087]   [<ffffffffa02108d9>] target_fabric_nacl_base_release+0x22/0x24 [target_core_mod]
    [  492.732698]   [<ffffffffa01661c8>] config_item_release+0x7d/0xa3 [configfs]
    [  492.740465]   [<ffffffff811d48fe>] kref_put+0x43/0x4d
    [  492.746101]   [<ffffffffa0166149>] config_item_put+0x19/0x1b [configfs]
    [  492.753481]   [<ffffffffa0164987>] configfs_rmdir+0x1eb/0x258 [configfs]
    [  492.760957]   [<ffffffff810ecc54>] vfs_rmdir+0x79/0xd0
    [  492.766690]   [<ffffffff810eec4a>] do_rmdir+0xc2/0x111
    [  492.772423]   [<ffffffff810eecd0>] sys_rmdir+0x11/0x13
    [  492.778156]   [<ffffffff813ae4d2>] system_call_fastpath+0x16/0x1b
    [  492.784953]
    Signed-off-by: NNicholas Bellinger <nab@linux-iscsi.org>
    140854cb
target_core_transport.c 132.2 KB