diff options
author | Nicholas Bellinger <nab@linux-iscsi.org> | 2011-05-27 16:58:48 -0400 |
---|---|---|
committer | Nicholas Bellinger <nab@linux-iscsi.org> | 2011-07-22 05:37:47 -0400 |
commit | 2be18149d9d7ebfde7c3081d60f7c9d8d3b6f8c7 (patch) | |
tree | 2d6d602112049f4e6188d8ee3412168760e302ae /drivers/target | |
parent | a1fa3759583ef2379da6e2cc346ee9f99dfba309 (diff) |
tcm_fc: Convert to wake_up_process and schedule_timeout_interruptible
This patch converts ft_queue_cmd() to use wake_up_process() and
ft_thread() to use schedule_timeout_interruptible(MAX_SCHEDULE_TIMEOUT)
instead of wait_event_interruptible(). This fixes a potential race with
the wait_event_interruptible() conditional with qobj->queue_cnt in
ft_thread().
This patch also drops the unnecessary set_user_nice(current, -20) in
ft_thread(), and drops extra () around two if (!(acl)) conditionals in
tfc_conf.c.
Reported-by: Christoph Hellwig <hch@infradead.org>
Signed-off-by: Nicholas A. Bellinger <nab@linux-iscsi.org>
Diffstat (limited to 'drivers/target')
-rw-r--r-- | drivers/target/tcm_fc/tfc_cmd.c | 17 | ||||
-rw-r--r-- | drivers/target/tcm_fc/tfc_conf.c | 4 |
2 files changed, 10 insertions, 11 deletions
diff --git a/drivers/target/tcm_fc/tfc_cmd.c b/drivers/target/tcm_fc/tfc_cmd.c index 74d5bb766201..a00951c80324 100644 --- a/drivers/target/tcm_fc/tfc_cmd.c +++ b/drivers/target/tcm_fc/tfc_cmd.c | |||
@@ -94,15 +94,17 @@ void ft_dump_cmd(struct ft_cmd *cmd, const char *caller) | |||
94 | 94 | ||
95 | static void ft_queue_cmd(struct ft_sess *sess, struct ft_cmd *cmd) | 95 | static void ft_queue_cmd(struct ft_sess *sess, struct ft_cmd *cmd) |
96 | { | 96 | { |
97 | struct se_queue_obj *qobj; | 97 | struct ft_tpg *tpg = sess->tport->tpg; |
98 | struct se_queue_obj *qobj = &tpg->qobj; | ||
98 | unsigned long flags; | 99 | unsigned long flags; |
99 | 100 | ||
100 | qobj = &sess->tport->tpg->qobj; | 101 | qobj = &sess->tport->tpg->qobj; |
101 | spin_lock_irqsave(&qobj->cmd_queue_lock, flags); | 102 | spin_lock_irqsave(&qobj->cmd_queue_lock, flags); |
102 | list_add_tail(&cmd->se_req.qr_list, &qobj->qobj_list); | 103 | list_add_tail(&cmd->se_req.qr_list, &qobj->qobj_list); |
103 | spin_unlock_irqrestore(&qobj->cmd_queue_lock, flags); | ||
104 | atomic_inc(&qobj->queue_cnt); | 104 | atomic_inc(&qobj->queue_cnt); |
105 | wake_up_interruptible(&qobj->thread_wq); | 105 | spin_unlock_irqrestore(&qobj->cmd_queue_lock, flags); |
106 | |||
107 | wake_up_process(tpg->thread); | ||
106 | } | 108 | } |
107 | 109 | ||
108 | static struct ft_cmd *ft_dequeue_cmd(struct se_queue_obj *qobj) | 110 | static struct ft_cmd *ft_dequeue_cmd(struct se_queue_obj *qobj) |
@@ -688,15 +690,12 @@ int ft_thread(void *arg) | |||
688 | struct ft_tpg *tpg = arg; | 690 | struct ft_tpg *tpg = arg; |
689 | struct se_queue_obj *qobj = &tpg->qobj; | 691 | struct se_queue_obj *qobj = &tpg->qobj; |
690 | struct ft_cmd *cmd; | 692 | struct ft_cmd *cmd; |
691 | int ret; | ||
692 | |||
693 | set_user_nice(current, -20); | ||
694 | 693 | ||
695 | while (!kthread_should_stop()) { | 694 | while (!kthread_should_stop()) { |
696 | ret = wait_event_interruptible(qobj->thread_wq, | 695 | schedule_timeout_interruptible(MAX_SCHEDULE_TIMEOUT); |
697 | atomic_read(&qobj->queue_cnt) || kthread_should_stop()); | 696 | if (kthread_should_stop()) |
698 | if (ret < 0 || kthread_should_stop()) | ||
699 | goto out; | 697 | goto out; |
698 | |||
700 | cmd = ft_dequeue_cmd(qobj); | 699 | cmd = ft_dequeue_cmd(qobj); |
701 | if (cmd) | 700 | if (cmd) |
702 | ft_exec_req(cmd); | 701 | ft_exec_req(cmd); |
diff --git a/drivers/target/tcm_fc/tfc_conf.c b/drivers/target/tcm_fc/tfc_conf.c index 1cb3d345183f..ec9e40dc4514 100644 --- a/drivers/target/tcm_fc/tfc_conf.c +++ b/drivers/target/tcm_fc/tfc_conf.c | |||
@@ -223,7 +223,7 @@ static struct se_node_acl *ft_add_acl( | |||
223 | return ERR_PTR(-EINVAL); | 223 | return ERR_PTR(-EINVAL); |
224 | 224 | ||
225 | acl = kzalloc(sizeof(struct ft_node_acl), GFP_KERNEL); | 225 | acl = kzalloc(sizeof(struct ft_node_acl), GFP_KERNEL); |
226 | if (!(acl)) | 226 | if (!acl) |
227 | return ERR_PTR(-ENOMEM); | 227 | return ERR_PTR(-ENOMEM); |
228 | acl->node_auth.port_name = wwpn; | 228 | acl->node_auth.port_name = wwpn; |
229 | 229 | ||
@@ -280,7 +280,7 @@ struct se_node_acl *ft_tpg_alloc_fabric_acl(struct se_portal_group *se_tpg) | |||
280 | struct ft_node_acl *acl; | 280 | struct ft_node_acl *acl; |
281 | 281 | ||
282 | acl = kzalloc(sizeof(*acl), GFP_KERNEL); | 282 | acl = kzalloc(sizeof(*acl), GFP_KERNEL); |
283 | if (!(acl)) { | 283 | if (!acl) { |
284 | printk(KERN_ERR "Unable to allocate struct ft_node_acl\n"); | 284 | printk(KERN_ERR "Unable to allocate struct ft_node_acl\n"); |
285 | return NULL; | 285 | return NULL; |
286 | } | 286 | } |