Skip to content

Commit 8d27167

Browse files
biger410roxanan1996
authored andcommitted
scsi: target: core: Fix deadlock due to recursive locking
BugLink: https://bugs.launchpad.net/bugs/2045809 [ Upstream commit a154f5f ] The following call trace shows a deadlock issue due to recursive locking of mutex "device_mutex". First lock acquire is in target_for_each_device() and second in target_free_device(). PID: 148266 TASK: ffff8be21ffb5d00 CPU: 10 COMMAND: "iscsi_ttx" #0 [ffffa2bfc9ec3b18] __schedule at ffffffffa8060e7f #1 [ffffa2bfc9ec3ba0] schedule at ffffffffa8061224 #2 [ffffa2bfc9ec3bb8] schedule_preempt_disabled at ffffffffa80615ee #3 [ffffa2bfc9ec3bc8] __mutex_lock at ffffffffa8062fd7 #4 [ffffa2bfc9ec3c40] __mutex_lock_slowpath at ffffffffa80631d3 #5 [ffffa2bfc9ec3c50] mutex_lock at ffffffffa806320c #6 [ffffa2bfc9ec3c68] target_free_device at ffffffffc0935998 [target_core_mod] #7 [ffffa2bfc9ec3c90] target_core_dev_release at ffffffffc092f975 [target_core_mod] #8 [ffffa2bfc9ec3ca0] config_item_put at ffffffffa79d250f #9 [ffffa2bfc9ec3cd0] config_item_put at ffffffffa79d2583 #10 [ffffa2bfc9ec3ce0] target_devices_idr_iter at ffffffffc0933f3a [target_core_mod] #11 [ffffa2bfc9ec3d00] idr_for_each at ffffffffa803f6fc #12 [ffffa2bfc9ec3d60] target_for_each_device at ffffffffc0935670 [target_core_mod] #13 [ffffa2bfc9ec3d98] transport_deregister_session at ffffffffc0946408 [target_core_mod] #14 [ffffa2bfc9ec3dc8] iscsit_close_session at ffffffffc09a44a6 [iscsi_target_mod] #15 [ffffa2bfc9ec3df0] iscsit_close_connection at ffffffffc09a4a88 [iscsi_target_mod] #16 [ffffa2bfc9ec3df8] finish_task_switch at ffffffffa76e5d07 #17 [ffffa2bfc9ec3e78] iscsit_take_action_for_connection_exit at ffffffffc0991c23 [iscsi_target_mod] #18 [ffffa2bfc9ec3ea0] iscsi_target_tx_thread at ffffffffc09a403b [iscsi_target_mod] #19 [ffffa2bfc9ec3f08] kthread at ffffffffa76d8080 #20 [ffffa2bfc9ec3f50] ret_from_fork at ffffffffa8200364 Fixes: 36d4cb4 ("scsi: target: Avoid that EXTENDED COPY commands trigger lock inversion") Signed-off-by: Junxiao Bi <[email protected]> Link: https://lore.kernel.org/r/[email protected] Reviewed-by: Mike Christie <[email protected]> Signed-off-by: Martin K. Petersen <[email protected]> Signed-off-by: Sasha Levin <[email protected]> Signed-off-by: Kamal Mostafa <[email protected]> Signed-off-by: Stefan Bader <[email protected]>
1 parent 06dc8b9 commit 8d27167

File tree

1 file changed

+4
-7
lines changed

1 file changed

+4
-7
lines changed

drivers/target/target_core_device.c

Lines changed: 4 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -875,7 +875,6 @@ sector_t target_to_linux_sector(struct se_device *dev, sector_t lb)
875875
EXPORT_SYMBOL(target_to_linux_sector);
876876

877877
struct devices_idr_iter {
878-
struct config_item *prev_item;
879878
int (*fn)(struct se_device *dev, void *data);
880879
void *data;
881880
};
@@ -885,11 +884,9 @@ static int target_devices_idr_iter(int id, void *p, void *data)
885884
{
886885
struct devices_idr_iter *iter = data;
887886
struct se_device *dev = p;
887+
struct config_item *item;
888888
int ret;
889889

890-
config_item_put(iter->prev_item);
891-
iter->prev_item = NULL;
892-
893890
/*
894891
* We add the device early to the idr, so it can be used
895892
* by backend modules during configuration. We do not want
@@ -899,12 +896,13 @@ static int target_devices_idr_iter(int id, void *p, void *data)
899896
if (!target_dev_configured(dev))
900897
return 0;
901898

902-
iter->prev_item = config_item_get_unless_zero(&dev->dev_group.cg_item);
903-
if (!iter->prev_item)
899+
item = config_item_get_unless_zero(&dev->dev_group.cg_item);
900+
if (!item)
904901
return 0;
905902
mutex_unlock(&device_mutex);
906903

907904
ret = iter->fn(dev, iter->data);
905+
config_item_put(item);
908906

909907
mutex_lock(&device_mutex);
910908
return ret;
@@ -927,7 +925,6 @@ int target_for_each_device(int (*fn)(struct se_device *dev, void *data),
927925
mutex_lock(&device_mutex);
928926
ret = idr_for_each(&devices_idr, target_devices_idr_iter, &iter);
929927
mutex_unlock(&device_mutex);
930-
config_item_put(iter.prev_item);
931928
return ret;
932929
}
933930

0 commit comments

Comments
 (0)